summaryrefslogtreecommitdiff
path: root/src/operatorbasic.cpp
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/operatorbasic.cpp
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 'src/operatorbasic.cpp')
-rw-r--r--src/operatorbasic.cpp19
1 files changed, 9 insertions, 10 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