NAME
Algorithm::Evolutionary::Op::IncMutation - Increments/decrements by one the value of one of the components of the string, takes into account the char class
SYNOPSIS
my $xmlStr2=<<EOC;
<op name='IncMutation' type='unary' rate='0.5' />
EOC
my $ref2 = XMLin($xmlStr2);
my $op2 = Algorithm::Evolutionary::Op::Base->fromXML( $ref2 );
print $op2->asXML(), "\n*Arity ", $op->arity(), "\n";
my $op = new Algorithm::Evolutionary::Op::IncMutation; #Create from scratch
Base Class
Algorithm::Evolutionary::Op::Base
DESCRIPTION
Mutation operator for a GA; changes a single element in a string by
changing it to the next in the sequence deducted from the chromosome
itself.
create()
Creates a new mutation operator.
apply( $indiv )
Applies mutation operator to a "Chromosome", a string, really. Can be applied only to victims with the _str
instance variable; but it checks before application that both operands are of the required type. The chosen character is changed to the next or previous in the array of chars used for coding the the string my $strChrom = new Algorithm::Evolutionary::Individual::String ['a','c','g','t'] 10; my $xmen = new Algorithm::Evolutionary::Op::IncMutation; $xmen->apply( $strChrom ) # will change 'acgt' into 'aagt' or # 'aggt', for instance
Issues an error if there is no _chars
array, which is needed for computing the next.
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/02/04 20:43:14 $
$Header: /cvsroot/opeal/Algorithm-Evolutionary/lib/Algorithm/Evolutionary/Op/IncMutation.pm,v 2.1 2009/02/04 20:43:14 jmerelo Exp $
$Author: jmerelo $
$Revision: 2.1 $
$Name $