NAME

Algorithm::Evolutionary::Op::GaussianMutation - Changes numeric chromosome components following the gaussian distribution

SYNOPSIS

my $xmlStr4=<<EOC; # From XML
<op name='GaussianMutation' type='unary' rate='1'>
  <param name='avg' value='0' />
  <param name='stddev' value='0.1' />
</op>
EOC
my $ref4 = XMLin($xmlStr4);
my $op4 = Algorithm::Evolutionary::Op::Base->fromXML( $ref4 );
print $op4->asXML(), "\n";

my $op = new Algorithm::Evolutionary::Op::GaussianMutation( 0, 0.05) # With average 0, and 0.05 standard deviation

Base Class

Algorithm::Evolutionary::Op::Base

DESCRIPTION

Mutation operator for a GA: applies gaussian mutation to a number

new( [$average = 0] [, $standard deviation = 1] [, $rate = 1 ]

Creates a new mutation operator with an application rate. Rate defaults to 1.

create

Creates a new mutation operator with an application rate. Rate defaults to 0.1.

Called create to distinguish from the classwide ctor, new. It just makes simpler to create a Mutation Operator

apply( $chromosome )

Applies mutation operator to a "Chromosome", a vector of stuff, really. Can be applied only to victims with the _array instance variable; but it checks before application that both operands are of type Algorithm::Evolutionary::Individual::Vector.

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: 2008/09/12 18:31:02 $ 
$Header: /cvsroot/opeal/Algorithm-Evolutionary/lib/Algorithm/Evolutionary/Op/GaussianMutation.pm,v 1.4 2008/09/12 18:31:02 jmerelo Exp $ 
$Author: jmerelo $ 
$Revision: 1.4 $
$Name $