Algorithm-Evolutionary
view release on metacpan or search on metacpan
t/0600-ez-moga.t view on Meta::CPAN
#-*-CPerl-*-
#########################
use strict;
use warnings;
use Test::More tests => 4;
use lib qw( lib ../lib ../../lib ); #Just in case we are testing it in-place
use Algorithm::Evolutionary qw(Fitness::ZDT1 Individual::BitString);
BEGIN {
use_ok( "Algorithm::Evolutionary::Op::Easy_MO" );
}
#########################
my $number_of_bits = 10;
my $zdt1 = new Algorithm::Evolutionary::Fitness::ZDT1 $number_of_bits;
my @pop;
my $population_size = 100;
for ( 1..$population_size ) {
my $indi = new Algorithm::Evolutionary::Individual::BitString 30*$number_of_bits ; #Creates random individual
push( @pop, $indi );
}
my $e = new Algorithm::Evolutionary::Op::Easy_MO $zdt1;
isa_ok( $e, "Algorithm::Evolutionary::Op::Easy_MO");
$e->apply( \@pop);
my $best_fitness = $pop[0]->Fitness();
is ( $best_fitness == 1, 1, "First generation" );
$e->apply( \@pop);
is( $pop[0]->Fitness() == 1, 1, "Improving fitness" );
=cut
( run in 0.779 second using v1.01-cache-2.11-cpan-e93a5daba3e )