J. J. Merelo-Guervós > Algorithm-Evolutionary-0.71 > Algorithm::Evolutionary::Op::QuadXOver

Download:
Algorithm-Evolutionary-0.71.tar.gz

Dependencies

Annotate this POD

CPAN RT

Open  0
Report a bug
Module Version: 3.0   Source  

NAME ^

Algorithm::Evolutionary::Op::QuadXOver - n-point crossover operator; puts a part of the second operand into the first operand; can be 1 or 2 points.

SYNOPSIS ^

  my $xmlStr3=<<EOC;
  <op name='QuadXOver' type='binary' rate='1'>
    <param name='numPoints' value='3' /> #Max is 2, anyways
  </op>
  EOC
  my $ref3 = XMLin($xmlStr3);

  my $op3 = Algorithm::Evolutionary::Op::Base->fromXML( $ref3 );
  print $op3->asXML(), "\n";

  my $indi = new Algorithm::Evolutionary::Individual::BitString 10;
  my $indi2 = $indi->clone();
  my $indi3 = $indi->clone();
  $op3->apply( $indi2, $indi3 );

  my $op4 = new Algorithm::Evolutionary::Op::QuadXOver 3; #QuadXOver with 3 crossover points

Base Class ^

Algorithm::Evolutionary::Op::Base

DESCRIPTION ^

Crossover operator for a GA, takes args by reference and issues two children from two parents

METHODS ^

apply( $parent_1, $parent_2 )

Same as Algorithm::Evolutionary::Op::Crossover, but changes parents, does not return anything; that is, $parent_1 and $parent_2 interchange genetic material

Copyright ^

  This file is released under the GPL. See the LICENSE file included in this distribution,
  or go to http://www.fsf.org/licenses/gpl.txt

  CVS Info: $Date: 2009/07/24 08:46:59 $ 
  $Header: /cvsroot/opeal/Algorithm-Evolutionary/lib/Algorithm/Evolutionary/Op/QuadXOver.pm,v 3.0 2009/07/24 08:46:59 jmerelo Exp $ 
  $Author: jmerelo $ 
  $Revision: 3.0 $
  $Name $