summaryrefslogtreecommitdiff
path: root/src/population.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/population.cpp77
1 files changed, 76 insertions, 1 deletions
diff --git a/src/population.cpp b/src/population.cpp
index 85b859e..fbd6d6c 100644
--- a/src/population.cpp
+++ b/src/population.cpp
@@ -1,10 +1,85 @@
1#include "genetic/population.h" 1#include "genetic/population.h"
2#include "genetic/phenotype.h"
2 3
3Genetic::Population::Population() 4#include <bu/mutexlocker.h>
5
6Genetic::Population::Population() :
7 uNextId( 0 ),
8 uTime( 0 )
4{ 9{
5} 10}
6 11
7Genetic::Population::~Population() 12Genetic::Population::~Population()
8{ 13{
14 for( PhenotypeHash::iterator i = hPhenotype.begin(); i; i++ )
15 delete *i;
16}
17
18Genetic::PhenotypeId Genetic::Population::addPhenotype(
19 Genetic::Phenotype *pNew )
20{
21 Bu::MutexLocker ml( mGeneral );
22 if( !pNew->isActive() )
23 pNew->setCreated( uTime, uNextId++ );
24
25 hPhenotype.insert( pNew->getId(), pNew );
26 return pNew->getId();
27}
28
29bool Genetic::Population::hasProperty( Genetic::PhenotypeId id,
30 const Bu::String &sKey ) const
31{
32 Bu::MutexLocker ml( mGeneral );
33 return hPhenotype.get( id )->hasProperty( sKey );
34}
35
36Bu::Variant Genetic::Population::getProperty(
37 Genetic::PhenotypeId id, const Bu::String &sKey ) const
38{
39 Bu::MutexLocker ml( mGeneral );
40 return hPhenotype.get( id )->getProperty( sKey );
41}
42
43void Genetic::Population::setProperty( Genetic::PhenotypeId id,
44 const Bu::String &sKey, Bu::Variant vValue )
45{
46 Bu::MutexLocker ml( mGeneral );
47
48 hPhenotype.get( id )->setProperty( sKey, vValue );
49}
50
51void Genetic::Population::delPhenotype( PhenotypeId id )
52{
53 Bu::MutexLocker ml( mGeneral );
54 delete hPhenotype.get( id );
55 hPhenotype.erase( id );
56}
57
58Genetic::Phenotype *Genetic::Population::takePhenotype( PhenotypeId id )
59{
60 Bu::MutexLocker ml( mGeneral );
61 Phenotype *pRet = hPhenotype.get( id );
62 hPhenotype.erase( id );
63 return pRet;
64}
65
66void Genetic::Population::clear()
67{
68 Bu::MutexLocker ml( mGeneral );
69 for( PhenotypeHash::iterator i = hPhenotype.begin(); i; i++ )
70 delete *i;
71 hPhenotype.clear();
72}
73
74Genetic::PhenotypeId Genetic::Population::timestep()
75{
76 Bu::MutexLocker ml( mGeneral );
77 return (++uTime);
78}
79
80Genetic::PhenotypeId Genetic::Population::time() const
81{
82 Bu::MutexLocker ml( mGeneral );
83 return uTime;
9} 84}
10 85