Logo
Distributed Genetic Programming Framework
print print

File org.dgpf.gp.automaton.expressions.Constant.java

Here you can find all the information about the file org.dgpf.gp.automaton.expressions.Constant.java. You may explore it here or download it onto your local disk.
/*
 * Copyright (c) 2005 Thomas Weise
 * 
 * E-Mail           : tweise@gmx.de
 * Creation Date    : 2005-11-28 06:09:33
 * Original Filename: org.dgpf.automaton.expressions.Constant.java
 * Version          : 2.2.1
 * Last modification: 2006-05-08
 *                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.automaton.expressions;

import org.dgpf.gp.automaton.base.Automaton;
import org.dgpf.gp.automaton.base.Expression;
import org.dgpf.gp.automaton.search.ExpressionHandler;



/**
 * The class representing constant expressions.
 *
 * @author Thomas Weise
 */

public  final class Constant extends Expression
  {
/**
 * The serial version uid.
 */

  private static  final long               serialVersionUID  = 1;
  
  
/**
 * The constant value represented by this thing here.
 */

  private         final int                 m_value ;
                  
/**
 * An internal constant pool.
 */

  private static  final Constant[]          POOL  ;
/**
 * The pool radiant.
 */

  private static  final int                 POOL_RADIANT  = 5;      
  
  static
    {
    int l_l;
    
    l_l  = (POOL_RADIANT << 1);
    POOL = new Constant[l_l + 1];
    
    for(; l_l >= 0; l_l--)
      {
      POOL[l_l] = new Constant(l_l - POOL_RADIANT);
      }
    }
  
  
/**
 * The constant true.
 */

  public  static  final Constant CTRUE  = create_constant(TRUE);  
/**
 * The constant false.
 */

  public  static  final Constant CFALSE = create_constant(FALSE);  
/**
 * The constant zero.
 */

  public  static  final Constant CZERO  =
                            ((0 == FALSE) ? CFALSE: create_constant(0));
  
/**
 * The handler used by this class.
 */

  public  static  final ExpressionHandler<Expression> HANDLER =
                                                  ConstantHandler.INSTANCE;
  
/**
 * Create a new constant expression.
 * @param p_constant  The constant value represented by this thing here.
 */

  private Constant(final int p_constant)
    {
    super(1);
    this.m_value = p_constant;
    }
  
    
/**
 * Create a new constant.
 * Using this method instead of invoking an constructor will decrease the
 * running object count and thus decrease the amount of data to be
 * transmitted over the network and thus increase overall speed.
 * @param p_val   The constant value.
 * @return  The new constant object.
 */

  public  static  final Constant  create_constant (final int p_val)
    {
    if( (p_val <= -POOL_RADIANT) && (p_val >= POOL_RADIANT) )
      {
      return POOL[p_val + POOL_RADIANT];
      }
    return new Constant(p_val);
    }
  
/**
 * This method is called when the construct is executed. It performs the
 * work of the construct.
 * @param p_automate    The automate it is invoked on.
 * @return  The return value of the construct.
 */

  @Override
  public final int   execute (final Automaton p_automate)
    {
    return this.m_value;
    }
  
  
/**
 * Obtain the count of memory cells this item needs.
 * @return  The count of memory cells this item needs.
 */

  @Override
  public  final int   get_memory_size ()
    {
    return 0;
    }

  
/**
 * Returns the value of this constant.
 * @return The value of this constant.
 */

  public  final int get_value ()
    {
    return this.m_value;
    }

/**
 * Checks wether this object is equal to another object.
 * @param p_object  The object to compare with.
 * @return  <code>true</code> if and only if the two objects are exactly
 *          equal.
 */

  @Override
  public  final boolean equals  (final Object p_object)
    {
    if(p_object == thisreturn true;
    
    if(p_object instanceof Constant)
      {
      return (((Constant)p_object).m_value == this.m_value);
      }
    
    return false;
    }
  
/**
 * Store this objects content into a string builder.
 * @param p_sb  The string builder to store stuff into.
 */

  @Override
  public final void  to_string (final StringBuilder p_sb)
    {
    p_sb.append(this.m_value);
    }
  
/**
 * Returns the genetic handler of the code construct.
 * @return The genetic handler of the code construct.
 */

  @Override
  public final ExpressionHandler<Expression> get_handler ()
    {
    return HANDLER;
    }
  }

File Information:

file name:Constant.java
package:org.dgpf.gp.automaton.expressions
qualified name:org.dgpf.gp.automaton.expressions.Constant.java
file type:Java Source File
download location:download http://dgpf.sourceforge.net/source/org/dgpf/gp/automaton/expressions/Constant.java
size:5.049 KB (5171 B)
uploaded: 2015-07-22 04:10:55 GMT+0000
last update: 2006-05-08 13:38:45 GMT+0000
last access: 2017-11-23 07:21:19 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-23 07:21:19 GMT+0000.
Valid CSS Valid XHTML 1.1
Valid RSS SourceForge.net Logo