Logo
Distributed Genetic Programming Framework
print print

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

Here you can find all the information about the file org.dgpf.gp.automaton.expressions.ReadHandler.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-02-07 06:34:26
 * Original Filename: org.dgpf.automaton.expressions.ReadHandler.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.Expression;
import org.dgpf.gp.automaton.search.ExpressionHandler;
import org.dgpf.gp.automaton.search.Mutator;
import org.dgpf.gp.automaton.search.ProgramContext;
import org.sfc.collections.Arrays;
import org.sfc.math.stochastic.Randomizer;
import org.sfc.utils.Typesafe;

/**
 * This class is used to handle read-expressions.
 *
 * @author Thomas Weise
 */

final class ReadHandler extends ExpressionHandler<Read>
  {

/**
 * Mutate the address to read at.
 */

  private static  final Mutator<Expression, Read>
    MUTATE_ADDRESS = new Mutator<Expression, Read>()
    {
/**
 * Mutate an existing instance of the genotype.
 * @param p_source        The source instance.
 * @param p_context       The (calling) context to be used.
 * @param p_is_decisional <code>==DECISIONAL_EXPR</code> if the expression
 *                        is decisional,
 *                        <code>==CALCULATIVE_EXPR</code> if the expression
 *                        is calculative.
 * @param p_memory_size   The memory size currently available.
 * @return The randomly mutated copy of the source or <code>p_source</code>
 *         itself if it cannot be mutated in any way. 
 */

    @Override
    protected Expression  mutate(final  Read              p_source,
                                 final  ProgramContext    p_context,
                                 final  int               p_is_decisional,
                                 final  int               p_memory_size)
      {
      int         l_i;
      Randomizer  l_r;
      
      l_r = p_context.get_randomizer();
      
      l_i = ProgramContext.random_address(p_memory_size, l_r);
      if( (p_memory_size <= 1) && (l_i == 0) ) return p_source;
              
      while(l_i == p_source.get_address())
        {
        l_i = ProgramContext.random_address(p_memory_size, l_r);
        }
      
      return Read.create_read( l_i, p_source.is_indirect());
      }
    };
      

/**
 * Mutate the addressing type to use.
 */

  private static  final Mutator<Expression, Read>
    MUTATE_ADDRESSING = new Mutator<Expression, Read>()
    {
/**
 * Mutate an existing instance of the genotype.
 * @param p_source        The source instance.
 * @param p_context       The (calling) context to be used.
 * @param p_is_decisional <code>==DECISIONAL_EXPR</code> if the expression
 *                        is decisional,
 *                        <code>==CALCULATIVE_EXPR</code> if the expression
 *                        is calculative.
 * @param p_memory_size   The memory size currently available.
 * @return The randomly mutated copy of the source or <code>p_source</code>
 *         itself if it cannot be mutated in any way. 
 */

    @Override
    protected Expression  mutate(final  Read              p_source,
                                 final  ProgramContext    p_context,
                                 final  int               p_is_decisional,
                                 final  int               p_memory_size)
      {
      return Read.create_read(p_source.get_address(),
                             !(p_source.is_indirect()));       
      }
    };
    
/**
 * Wrap the read.
 */

  private static  final Mutator<Expression, Read>
    MUTATE_WRAP = new Mutator<Expression, Read>()
    {
/**
 * Mutate an existing instance of the genotype.
 * @param p_source        The source instance.
 * @param p_context       The (calling) context to be used.
 * @param p_is_decisional <code>==DECISIONAL_EXPR</code> if the expression
 *                        is decisional,
 *                        <code>==CALCULATIVE_EXPR</code> if the expression
 *                        is calculative.
 * @param p_memory_size   The memory size currently available.
 * @return The randomly mutated copy of the source or <code>p_source</code>
 *         itself if it cannot be mutated in any way. 
 */

    @Override
    protected Expression  mutate(final  Read              p_source,
                                 final  ProgramContext    p_context,
                                 final  int               p_is_decisional,
                                 final  int               p_memory_size)
      {
      return  p_context.wrap_expression(p_source, 
                                    (p_is_decisional != DECISIONAL_EXPR),
                                         p_memory_size); 
      }
    };
    
/**
 * The possible mutators of the write instruction.
 */

  private static  final Mutator<Expression, Read>[] MUTATORS =
       Arrays.create(MUTATE_ADDRESS, MUTATE_ADDRESSING, MUTATE_WRAP);
/**
 * The frequencies at which the mutations are selected.
 */

  private static  final double[]  FREQUENCIES = {1.5d, 1.5d, 4.0d};
    
/**
 * The shared singleton handler instance.
 */

  static  final ExpressionHandler<Expression>  INSTANCE 
                              = Typesafe.cast(new ReadHandler());
  
/**
 * Create a new constant handler.
 */

  private ReadHandler()
    {
    super(MUTATORS, FREQUENCIES);
    }
/**
 * 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.
 */

  @Override
  protected  final  Expression  create(final ProgramContext  p_context,
                                       final boolean         p_decision,
                                       final int             p_memory_size)
    {    
    Randomizer  l_r;
    l_r = p_context.get_randomizer();
    return Read.create_read(ProgramContext.random_address(
                            p_memory_size, l_r),
                            (l_r.nextDouble() < 0.2d));
    }
  
/**
 * 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.
 */

  @Override
  public  final Expression  optimize   (final Read p_source)
    {
    return p_source;
    }
    
/**
 * Checks wether this instruction 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 random genotype instance.
 */

  @Override
  public final boolean can_produce (final boolean p_decision)
    {
    return true;
    }
  
/**
 * If this expression referes to a memory cell (like the Read-expression
 * does), this method should return its refered memory cell. If the
 * expression contains one or more such sub-expressions, it should return
 * a randomly selected 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.
 */

  @Override
  public  final int  get_internal_address(final Read            p_source,
                                          final Randomizer      p_random)
    {
    return p_source.get_address();
    }
  }

File Information:

file name:ReadHandler.java
package:org.dgpf.gp.automaton.expressions
qualified name:org.dgpf.gp.automaton.expressions.ReadHandler.java
file type:Java Source File
download location:download http://dgpf.sourceforge.net/source/org/dgpf/gp/automaton/expressions/ReadHandler.java
size:8.781 KB (8992 B)
uploaded: 2015-07-22 04:10:55 GMT+0000
last update: 2006-06-08 08:15:49 GMT+0000
last access: 2017-11-18 06:37:40 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:37:40 GMT+0000.
Valid CSS Valid XHTML 1.1
Valid RSS SourceForge.net Logo