Logo
Distributed Genetic Programming Framework
print print

File org.dgpf.gp.automaton.search.ExpressionHandler.java

Here you can find all the information about the file org.dgpf.gp.automaton.search.ExpressionHandler.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-12-28 12:15:51
 * Original Filename: org.dgpf.automaton.genetics.ExpressionHandler.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.search;

import org.dgpf.gp.automaton.base.Expression;
import org.sfc.math.stochastic.Randomizer;

/**
 * The genetic handler for expressions.
 * Every expression handler <strong>must</strong> provide at least one
 * option to change the returned value of the expression in a way that is
 * is not constant anymore, or at least contains another value than before.
 * 
 * @param <Genotype> The sort of instructions handled.
 * @author Thomas Weise
 */

public abstract class   ExpressionHandler<Genotype extends Expression> 
                extends MutationDispatcher<Expression, Genotype>
  {
  
/**
 * Create a new expression handler.
 * @param p_mutators    The array of mutators to dispatch to.
 * @param p_weight      The array with the relative importance of the
 *                      different mutations. The higher the according
 *                      value, the heigher the probability of the mutation.
 */

  public ExpressionHandler
            (final Mutator<Expression, Genotype>[] p_mutators,
             final double[]                        p_weight)
    {
    super(p_mutators, p_weight);
    }
  
/**
 * Create a new, random instance of the genotype.
 * 
 * @param p_context       The (calling) context to be used.
 * @param p_decision    <code>true</code> if and only if the expression
 *                      required is a decisional expression.
 *                      <code>false</code> if it is an arithmetical
 *                      expression.
 * @param p_memory_size   The memory size currently available.
 *                        
 * @return  The random genotype instance.
 */

  protected abstract Expression create(final ProgramContext  p_context,
                                       final boolean         p_decision,
                                       final int             p_memory_size);
      
  
/**
 * Checks wether this expression handler is able to produce decisional or
 * non-decisional expressions.
 * 
 * @param p_decision    <code>true</code> if and only if the expressions
 *                      required are a decisional expression.
 *                      <code>false</code> if they are arithmetical
 *                      expression.
 *                        
 * @return  The newly created random genotype instance.
 */

  public abstract boolean can_produce    (final boolean p_decision);
                             
/**
 * If this expression referes to a memory cell (like the ReadDirect-expression
 * does), this method should return its refered memory cell. If the
 * expression contains one or more such sub-expressions, it can also return
 * a randomly selected refered memory cell of them.
 * 
 * @param p_source  The source object.
 * @param p_random  The randomizer.
 * @return  A memory cell refered by this expression, or <code>-1</code>
 *          if this expression does not refere any memory cell.
 */

  public           int get_internal_address(final Genotype        p_source,
                                            final Randomizer      p_random)
    {
    return -1;
    }
  
/**
 * This method returns an optimized version of the source expression,
 * or the source expression itself if it cannot be optimized.
 * @param p_source  The source expression.
 * @return  An optimized version of the source expression,
 *          or the source expression itself if it cannot be optimized.
 */

  public            Expression  optimize     (final Genotype   p_source)
    {
    return p_source;
    }
  }

File Information:

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