blob: 2ac2b0f3cf91f9393642be9fdad0666fe0477b56 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
#include "genetic/operatorbasic.h"
#include "genetic/phenotype.h"
#include <bu/random.h>
#include <bu/sio.h>
using namespace Bu;
Genetic::OperatorBasic::OperatorBasic( Phenotype *pProgenitor,
float fMutationRate ) :
pProgenitor( pProgenitor ),
fMutationRate( fMutationRate )
{
}
Genetic::OperatorBasic::~OperatorBasic()
{
delete pProgenitor;
}
Genetic::Phenotype *Genetic::OperatorBasic::random()
{
Genetic::Phenotype *pNew = pProgenitor->makeEmptyOffspring();
pNew->randomize();
return pNew;
}
Genetic::Phenotype *Genetic::OperatorBasic::mate(
const Genetic::PhenotypeList &lParents )
{
Genetic::Phenotype *pChild = lParents.first()->makeEmptyOffspring();
int iBits = lParents.first()->getSize();
// Right now, we assume both parents have the same amount of "DNA"
int iSplitPoint = ((uint32_t)Bu::Random::rand())%iBits;
pChild->copyFrom( *lParents.first(), 0, iSplitPoint );
pChild->copyFrom( *lParents.last(), iSplitPoint, iBits-iSplitPoint );
int iChange = iBits * (Bu::Random::randNorm() * fMutationRate * 1.25);
for( int j = 0; j < iChange; j++ )
{
pChild->mutate( Bu::Random::rand( 0, iBits ), 1.0 );
}
return pChild;
}
|