Logo
Distributed Genetic Programming Framework
print print

File org.dgpf.gp.vm.mutation.MutationInfo.java

Here you can find all the information about the file org.dgpf.gp.vm.mutation.MutationInfo.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-06-27 11:54:23
 * Original Filename: org.dgpf.gp.vm.mutation.MutationInfo.java
 * Version          : 1.0.0
 * Last modification: 2006-06-27
 *                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.vm.mutation;

import org.dgpf.gp.vm.base.Instruction;

/**
 * The mutation info class used to hold parameters needed by the mutators.
 *
 * @author Thomas Weise
 */

public class MutationInfo
  {
/**
 * The procedure count.
 */

  int m_proc_count  ;
/**
 * The lowest directly accessed address. 
 */

  int m_lowest_addr    ;
/**
 * The highest directly accessed address. 
 */

  int m_highest_addr    ;
/**
 * The lowest directly accessed address. 
 */

  int m_lowest_proc_addr    ;
/**
 * The highest directly accessed address. 
 */

  int m_highest_proc_addr    ;
/**
 * The procedure currently used.
 */

  int m_cur_proc    ;
/**
 * The length of the procedure currently in use.
 */

  int m_cur_proc_len  ;
/**
 * The index of the current instruction.
 */

  int m_instr_index ;
  
/**
 * Obtain the count of procedures of the current program.
 * @return The count of procedures of the current program.   
 */

  public  final int get_proc_count  ()
    {
    return this.m_proc_count;
    }
  
/**
 * Obtain the lowest directly accessed address of the current program.
 * @return The lowest directly accessed address of the current program.   
 */
  
  public  final int get_lowest_addr()
    {
    return this.m_lowest_addr;
    }
  
/**
 * Obtain the highest directly accessed address of the current program.
 * @return The highest directly accessed address of the current program.
 */
  
  public  final int get_highest_addr()
    {
    return this.m_highest_addr;
    }
  

/**
 * Obtain the lowest directly accessed address of the current procedure.
 * @return The lowest directly accessed address of the current procedure.
 */
  
  public  final int get_lowest_proc_addr()
    {
    return this.m_lowest_addr;
    }
  
/**
 * Obtain the highest directly accessed address of the current procedure.
 * @return The highest directly accessed address of the current procedure.   
 */
  
  public  final int get_highest_proc_addr()
    {
    return this.m_highest_addr;
    }
  
/**
 * Obtain the procedure currently used.
 * @return  The procedure currently used.
 */

  public  final int get_cur_proc    ()
    {
    return this.m_cur_proc;
    }
  
/**
 * Obtain the length of the procedure currently in use.
 * @return  The length of the procedure currently in use.
 */

  public  final int get_cur_proc_len  ()
    {
    return this.m_cur_proc_len;
    }
/**
 * Obtain the index of the current instruction.
 * @return  The index of the current instruction.
 */

  public  final int get_instr_index()
    {
    return this.m_instr_index;
    }
  
/**
 * Assign this info to the specified code.
 * @param p_code  The code to assign to.
 */

  final void  assign_code  (final Instruction[][] p_code)
    {
    int           l_i, l_j, l_mmi, l_mmm, l_z;
    Instruction[] l_ins;
    
    l_mmi             = 0;
    l_mmm             = 0;
    l_i               = p_code.length;
    this.m_proc_count = l_i;
    
    for(--l_i; l_i >= 0; l_i--)
      {
      l_ins = p_code[l_i];
      for(l_j = (l_ins.length-1); l_j >= 0; l_j--)
        {
        l_z = l_ins[l_j].get_highest_address();
        if(l_z > l_mmm) l_mmm = l_z;
        l_z = l_ins[l_j].get_lowest_address();
        if(l_z < l_mmi) l_mmi = l_z;
        }
      }
    
    this.m_highest_addr = l_mmm;
    this.m_lowest_addr  = l_mmi;
    }
  
/**
 * Assign this info to the specified code.
 * @param p_code  The code to assign to.
 * @param p_index The index of the procedure.
 */

  final void  assign_proc  (final Instruction[] p_code,
                            final int           p_index)
    {
    int           l_i, l_j, l_mmi, l_mmm, l_z;
    
    l_mmi               = 0;
    l_mmm               = 0;
    l_i                 = p_code.length;
    this.m_cur_proc_len = l_i;
    this.m_cur_proc     = p_index;
    
    for(l_j = (p_code.length-1); l_j >= 0; l_j--)
      {
      l_z = p_code[l_j].get_highest_address();
      if(l_z > l_mmm) l_mmm = l_z;
      l_z = p_code[l_j].get_lowest_address();
      if(l_z < l_mmi) l_mmi = l_z;
      }
    
    this.m_highest_proc_addr = l_mmm;
    this.m_lowest_proc_addr  = l_mmi;
    }
  
  
/**
 * Assign this info to the specified instruction code.
 * @param p_instruction  The instruction to assign to.
 */

  final void  assign_instr  (final Instruction p_instruction)
    {
    int l_i;
    
    l_i = p_instruction.get_highest_address();
    if(l_i > this.m_highest_proc_addr)
      {
      this.m_highest_proc_addr = l_i;
      if(l_i > this.m_highest_addr)
        {
        this.m_highest_addr = l_i;
        }
      }
    else
      {
      if(l_i < this.m_lowest_proc_addr)
        {
        this.m_lowest_proc_addr = l_i;
        if(l_i < this.m_lowest_addr)
          {
          this.m_lowest_addr = l_i;
          }
        }
      }
    }
  }

File Information:

file name:MutationInfo.java
package:org.dgpf.gp.vm.mutation
qualified name:org.dgpf.gp.vm.mutation.MutationInfo.java
file type:Java Source File
download location:download http://dgpf.sourceforge.net/source/org/dgpf/gp/vm/mutation/MutationInfo.java
size:5.967 KB (6111 B)
uploaded: 2015-07-22 04:10:58 GMT+0000
last update: 2006-07-04 02:09:21 GMT+0000
last access: 2017-11-18 23:16:08 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 23:16:08 GMT+0000.
Valid CSS Valid XHTML 1.1
Valid RSS SourceForge.net Logo