Logo
Distributed Genetic Programming Framework
print print

File org.dgpf.gp.regression.expressions.binary.BinaryExpression.java

Here you can find all the information about the file org.dgpf.gp.regression.expressions.binary.BinaryExpression.java. You may explore it here or download it onto your local disk.
/*
 * Copyright (c) 2006 Thomas Weise
 * 
 * E-Mail           : tweise@gmx.de
 * Creation Date    : 2006-07-25 13:44:34
 * Original Filename: org.dgpf.gp.regression.expressions.binary.BinaryExpression.java
 * Version          : 1.0.0
 * Last modification: 2006-07-25
 *                by: Thomas Weise
 * 
 * License          : GNU LESSER GENERAL PUBLIC LICENSE
 *                    Version 2.1, February 1999
 *                    You should have received a copy of this license along
 *                    with this library; if not, write to the Free Software
 *                    Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 *                    MA 02111-1307, USA or download the license under
 *                    http://www.gnu.org/copyleft/lesser.html.
 *                    
 * Warranty         : This software is provided "as is" without any
 *                    warranty; without even the implied warranty of
 *                    merchantability or fitness for a particular purpose.
 *                    See the Gnu Lesser General Public License for more
 *                    details.
 */

 
package org.dgpf.gp.regression.expressions.binary;

import org.dgpf.gp.regression.base.Expression;


/**
 * This is the base class for all binary expressions.
 *
 * @author Thomas Weise
 */

public abstract class BinaryExpression extends Expression
  {
/**
 * The first sub-expression.
 */

  Expression  m_sub_1 ;
/**
 * The second sub-expression.
 */

  Expression  m_sub_2 ;
  
/**
 * Create a binary expression.
 * @param p_sub_1   The first sub-expression.
 * @param p_sub_2   The second sub-expression.
 */

  public  BinaryExpression  (final Expression p_sub_1,
                             final Expression p_sub_2)
    {
    super();
    this.set_sub_1(p_sub_1);
    this.set_sub_2(p_sub_2);
    }
  
/**
 * Set the first sub-expression
 * @param p_ex  The sub-expression to be set.
 */

  final void  set_sub_1(final Expression p_ex)
    {
    this.m_sub_1 = p_ex.get_handler().optimize(p_ex);
    }
  
/**
 * Set the first sub-expression
 * @param p_ex  The sub-expression to be set.
 */

  final void  set_sub_2(final Expression p_ex)
    {
    this.m_sub_2 = p_ex.get_handler().optimize(p_ex);
    }
   
  
/**
 * Obtain the first sub-expression.
 * @return  The first sub-expression.
 */

  public  final Expression  get_sub_1 ()
    {
    return this.m_sub_1;
    }
  
/**
 * Obtain the second sub-expression.
 * @return  The second sub-expression.
 */

  public  final Expression  get_sub_2 ()
    {
    return this.m_sub_2;
    }
  

/**
 * Returns the costs that will arise when executing this expression.
 * This is defined as the costs of exactly this expression plus the costs
 * of all sub-expressions.
 * @return The costs of executing this expression.
 */

  @Override
  public  double  get_costs  ()
    {
    return (this.m_sub_1.get_costs() + this.m_sub_2.get_costs());
    }
  
  
/**
 * Check if another object is equal to this one.
 * @param p_o   The object to check.
 * @return  <code>true</code> if and only if <code>p_o</code> is exactly
 *          the same object than this one.
 */

  @Override
  public  boolean equals  (final Object p_o)
    {
    BinaryExpression  l_be;
    
    if(p_o == thisreturn true;
    if(p_o == null) return false;
    
    if(p_o.getClass().equals(this.getClass()))
      {
      l_be = ((BinaryExpression)p_o);
      return ( (l_be.m_sub_1.equals(this.m_sub_1)) &&
               (l_be.m_sub_2.equals(this.m_sub_2)) );
      }
    
    return false;    
    }
  
/**
 * Get a string that can be copy-pasted into a java file an that creates
 * this construct.
 * @param p_b The string builder to add with. 
 */

  @Override
  public void    to_creation_string (final StringBuilder p_b)
    {
    p_b.append("new ");
    p_b.append(this.getClass().getSimpleName());
    p_b.append('(');
    this.m_sub_1.to_creation_string(p_b);
    p_b.append(", ");
    this.m_sub_2.to_creation_string(p_b);
    p_b.append(')');
    }
  

/**
 * Check whether an expression is constant or not.
 * @return  <code>true</code> if and only if the specified expression is
 *          constant.
 */

  @Override
  public  boolean             is_constant()
    {
    return (this.m_sub_1.is_constant() && this.m_sub_2.is_constant());
    }
  
  
/**
 * Check how the specified variable is used.
 * @param p_index The index of the variable.
 * @return  An or-combination of <code>1</code> if the variable is read and
 *          <code>2</code> if it is written to.
 */

  @Override
  public  final int  get_variable_usage       (final int p_index)
    {
    return (((this.m_sub_1.get_variable_usage(p_index) != 0) ||
             (this.m_sub_2.get_variable_usage(p_index) != 0)) ? 1 : 0);
    }
  

/**
 * Returns the count of variable used.
 * @return The count of variable used.
 */

  @Override
  public  final int     get_variable_count  ()
    {
    return Math.max(this.m_sub_1.get_variable_count(),
                    this.m_sub_2.get_variable_count());
    }
  

/**
 * Obtain the depth of the construct.
 * @return The depth of the construct.
 */

  @Override
  public  int     get_depth           ()
    {
    return (1 + Math.max(this.m_sub_1.get_depth(), this.m_sub_2.get_depth()));
    }
  }

File Information:

file name:BinaryExpression.java
package:org.dgpf.gp.regression.expressions.binary
qualified name:org.dgpf.gp.regression.expressions.binary.BinaryExpression.java
file type:Java Source File
download location:download http://dgpf.sourceforge.net/source/org/dgpf/gp/regression/expressions/binary/BinaryExpression.java
size:5.327 KB (5455 B)
uploaded: 2015-07-22 04:10:56 GMT+0000
last update: 2006-08-15 04:57:48 GMT+0000
last access: 2017-11-21 01:32:45 GMT+0000

statistics online since 2006-01-02.   RSS Feed
Contact us by sending an email to tweise@gmx.de to receive further information, to report errors, or to join our project.
All content on this site (http://dgpf.sourceforge.net/) is LGPL-licensed.
http://dgpf.sourceforge.net/scripts/source/source.php last modified at 2015-07-22 04:10:53 GMT+0000 served at 2017-11-21 15:39:56 GMT+0000.
Valid CSS Valid XHTML 1.1
Valid RSS SourceForge.net Logo