summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMike Buland <mike@xagasoft.com>2012-08-04 16:59:49 -0600
committerMike Buland <mike@xagasoft.com>2012-08-04 16:59:49 -0600
commitaaa733d789612289396d69bb6cf3a0e5de1798a8 (patch)
tree9004c335d19bad5357737d34615572e002d583ee /src
parent3cdf68e08d438a0ced0f5f8d957a6aafd68cb43a (diff)
downloadlibgenetic-aaa733d789612289396d69bb6cf3a0e5de1798a8.tar.gz
libgenetic-aaa733d789612289396d69bb6cf3a0e5de1798a8.tar.bz2
libgenetic-aaa733d789612289396d69bb6cf3a0e5de1798a8.tar.xz
libgenetic-aaa733d789612289396d69bb6cf3a0e5de1798a8.zip
Optomized the mating / mutation setup.
It should work the same, but it selects the number of bits to mutate first, then selects the individual bits instead of testing a random number on each bit. For very large phenotypes this will be significantly faster while producing about the same result.
Diffstat (limited to '')
-rw-r--r--src/operatorbasic.cpp19
-rw-r--r--src/tests/binary.cpp3
2 files changed, 11 insertions, 11 deletions
diff --git a/src/operatorbasic.cpp b/src/operatorbasic.cpp
index ce37f78..2ac2b0f 100644
--- a/src/operatorbasic.cpp
+++ b/src/operatorbasic.cpp
@@ -28,21 +28,20 @@ Genetic::Phenotype *Genetic::OperatorBasic::mate(
28 const Genetic::PhenotypeList &lParents ) 28 const Genetic::PhenotypeList &lParents )
29{ 29{
30 Genetic::Phenotype *pChild = lParents.first()->makeEmptyOffspring(); 30 Genetic::Phenotype *pChild = lParents.first()->makeEmptyOffspring();
31 31
32 int iBits = lParents.first()->getSize();
32 // Right now, we assume both parents have the same amount of "DNA" 33 // Right now, we assume both parents have the same amount of "DNA"
33 int iSplitPoint = ((uint32_t)Bu::Random::rand())%lParents.first()->getSize(); 34 int iSplitPoint = ((uint32_t)Bu::Random::rand())%iBits;
34 pChild->copyFrom( *lParents.first(), 0, iSplitPoint ); 35 pChild->copyFrom( *lParents.first(), 0, iSplitPoint );
35 pChild->copyFrom( *lParents.last(), iSplitPoint, 36 pChild->copyFrom( *lParents.last(), iSplitPoint, iBits-iSplitPoint );
36 lParents.last()->getSize()-iSplitPoint ); 37
38 int iChange = iBits * (Bu::Random::randNorm() * fMutationRate * 1.25);
37 39
38 // Mutate the child some 40 for( int j = 0; j < iChange; j++ )
39 for( int j = 0; j < pChild->getSize(); j++ )
40 { 41 {
41 //sio << Bu::Random::randNorm() << sio.nl; 42 pChild->mutate( Bu::Random::rand( 0, iBits ), 1.0 );
42 if( Bu::Random::randNorm() <= fMutationRate )
43 pChild->mutate( j, 1.0 );
44 } 43 }
45 44
46 return pChild; 45 return pChild;
47} 46}
48 47
diff --git a/src/tests/binary.cpp b/src/tests/binary.cpp
index 727feec..3e2cbc7 100644
--- a/src/tests/binary.cpp
+++ b/src/tests/binary.cpp
@@ -4,6 +4,7 @@
4#include <bu/sio.h> 4#include <bu/sio.h>
5#include <bu/random.h> 5#include <bu/random.h>
6#include <bu/randomcmwc.h> 6#include <bu/randomcmwc.h>
7#include <bu/randomsystem.h>
7#include <time.h> 8#include <time.h>
8 9
9using namespace Bu; 10using namespace Bu;
@@ -13,7 +14,7 @@ int main( int argc, char *argv[] )
13 Bu::Random::setGenerator<Bu::RandomCmwc>(); 14 Bu::Random::setGenerator<Bu::RandomCmwc>();
14 Bu::Random::seed( time( NULL ) ); 15 Bu::Random::seed( time( NULL ) );
15 16
16 Genetic::OperatorBasic op( new Genetic::PhenotypeBinary( 422*1024 ), 0.0 ); 17 Genetic::OperatorBasic op( new Genetic::PhenotypeBinary( 3453120 ), 0.000125 );
17 Genetic::Phenotype *pPb1 = op.random(); 18 Genetic::Phenotype *pPb1 = op.random();
18 Genetic::Phenotype *pPb2 = op.random(); 19 Genetic::Phenotype *pPb2 = op.random();
19 Genetic::Phenotype *pPb3; 20 Genetic::Phenotype *pPb3;