Nemo  2.4.0b
Simulate forward-in-time genetic evolution in a spatially explicit, individual-based stochastic simulator
ttdispersal.h
Go to the documentation of this file.
1 
30 #ifndef TTDISPERSALGENE_H
31 #define TTDISPERSALGENE_H
32 
33 #include "ttrait.h"
34 #include "types.h"
35 #include "stathandler.h"
36 #include "metapop.h"
37 #include "binarystoragebuffer.h"
38 
39 class TTDispersalSH;
40 class TProtoDispersal;
41 
43 class TTDispersal : public TTrait
44 {
47  double _mut_rate;
49  double _mut_mean;
54 
56 
60 // trait_t _type;
62  double _sequence[2];
63  double _phenotype;
64 
65 public:
67  TTDispersal (sex_t sex);
70  _init_rate_mal(TP._init_rate_mal), _myProto(TP._myProto), _gender(TP._gender), _phenotype(0) //, _type(TP._type)
71  {}
72  virtual ~TTDispersal () { }
73 
76  void set_mut_rate (double val) {_mut_rate = val;}
77  void set_mut_mean (double val) {_mut_mean = val;}
78  void set_init_rate_fem (double val) {_init_rate_fem = val;}
79  void set_init_rate_mal (double val) {_init_rate_mal = val;}
80  void set_gender (sex_t val) {_gender = val;}
81 // void set_type (trait_t val) {_type = val;}
86  virtual void init ( ) { _sequence[0] = 0.0; _sequence[1] = 0.0; }
87  virtual void init_sequence ( );
88  virtual void reset ( ) {init();}
89  virtual void inherit (const TTrait* mother, const TTrait* father);
90  virtual void mutate ( );
91  virtual trait_t get_type ( ) const {return (_gender == FEM ? FDISP : MDISP);}
92  virtual void set_value ( ) {_phenotype = (_sequence[0] + _sequence[1])/2.0;}
94  virtual void* getValue ( ) const {return (void*)&_phenotype;}
96  virtual void** get_sequence ( ) const {return 0;}
97  virtual unsigned int get_allele (int loc, int all) const {return ( !(all<2) ? 0 : _sequence[all] );}
98  virtual double get_allele_value (int loc, int all) const {return ( !(all<2) ? 0 : _sequence[all] );}
99  virtual void set_allele_value (unsigned int locus, unsigned int allele, double value)
100  {assert(allele < 2); _sequence[allele] = value;}
101  virtual void set_sequence (void** seq) { }
102  virtual void* set_trait (void* value) {return value;}
103  virtual void show_up ( );
104  virtual TTDispersal* clone ( ) {return new TTDispersal(*this);}
105  virtual TTDispersal& operator= (const TTrait& TP);
106  virtual bool operator== (const TTrait& TP);
107  virtual bool operator!= (const TTrait& TP);
108 
109  //implements StorableComponent:
110  virtual void store_data (BinaryStorageBuffer* saver) {saver->store(&_sequence, 2 * sizeof(double));}
111  virtual bool retrieve_data (BinaryStorageBuffer* reader) {reader->read(&_sequence, 2 * sizeof(double));return true;}
113 };
114 // ------------------------------------------------------------------------------
115 
116 // TProtoDispersal
117 
118 // ------------------------------------------------------------------------------
121 
122 public:
123  TProtoDispersal(sex_t sex);
124 
125  TProtoDispersal(const TProtoDispersal& TP);
126 
127  virtual ~TProtoDispersal();
128 
131  virtual void init (){}
132  virtual void reset (){}
133  virtual TTDispersal* hatch ();
134  virtual TProtoDispersal* clone () {return new TProtoDispersal(*this);}
135  virtual trait_t get_type () const {return (_gender == FEM ? FDISP : MDISP);}
137  virtual int get_phenotype_dimension () {return 1;}
139  virtual int get_allele_number () {return 3;} // 3 > 2 means it's not di-allelic
141  virtual int get_locus_number () {return 2;}
143  virtual bool is_mappable () {return false;}
145  virtual bool is_mapped () {return false;}
147  virtual vector< unsigned int > get_locus_map_positions () {return vector<unsigned int>(2,0);}
151  virtual void store_data (BinaryStorageBuffer* saver) {saver->store(&_gender, sizeof(sex_t));}
152  virtual bool retrieve_data (BinaryStorageBuffer* reader) {reader->read(&_gender, sizeof(sex_t));return true;}
156  virtual bool setParameters();
157  virtual void loadFileServices ( FileServices* loader ) {}
158  virtual void loadStatServices ( StatServices* loader );
159  virtual bool resetParameterFromSource (std::string param, SimComponent* cmpt) {return false;}
161 
162  bool setNonRandom ();
163  bool setRandom ();
164 
165  bool get_init_mode () {return _init_random;}
167  string get_init_dist () {return _init_dist;}
168 
169 private:
171  double _mut_rate;
173  double _mut_mean;
178 
179  string _init_dist;
182 
186 // trait_t _type;
189 };
190 
191 // ------------------------------------------------------------------------------
192 
193 // TTDispersalSH
194 
195 // ------------------------------------------------------------------------------
197 class TTDispersalSH: public StatHandler<TTDispersalSH> {
198 
200 
202 
204 
205 public:
206 
209 
210  virtual ~TTDispersalSH ( ) { }
211  virtual void init ( )
212  {
216  }
217 
218  virtual bool setStatRecorders (std::string& token);
219 
220  void addDispPerPatch (sex_t SEX, age_t AGE);
221 
222  double getmeanOFD () {return _meanOffFemDisp;}
223  double getmeanOMD () {return _meanOffMalDisp;}
224  double getmeanFD () {return _meanFemDisp;}
225  double getmeanMD () {return _meanMalDisp;}
226  double getMeanDispRate ();
227  double getOffsprgMeanDispRate ();
228  double getMeanDispRate (sex_t sex);
229  double getOffsprgMeanDispRate (sex_t sex);
230  double getMeanFemDispRate ();
231  double getMeanMalDispRate ();
232  double getMeanDispRateInPatch (sex_t SEX, age_idx age, unsigned int traitidx, unsigned int i);
233 
234  double getPatchDisp_OF (unsigned int patch)
235  {
236  return getMeanDispRateInPatch(FEM, OFFSx, _fdispIdx, patch);
237  }
238 
239  double getPatchDisp_OM (unsigned int patch)
240  {
241  return getMeanDispRateInPatch(MAL, OFFSx, _mdispIdx, patch);
242  }
243 
244  double getPatchDisp_AF (unsigned int patch)
245  {
246  return getMeanDispRateInPatch(FEM, ADLTx, _fdispIdx, patch);
247  }
248 
249  double getPatchDisp_AM (unsigned int patch)
250  {
251  return getMeanDispRateInPatch(MAL, ADLTx, _mdispIdx, patch);
252  }
253 };
254 #endif //TTDISPERSALGENE_H
255 
A class to store any kind of data in a char buffer before unloading it in a binary data file.
Definition: binarystoragebuffer.h:44
void read(void *out, unsigned int nb_bytes)
Definition: binarystoragebuffer.h:162
void store(void *stream, unsigned int nb_bytes)
Definition: binarystoragebuffer.cc:16
A class to manage the files associated with each components of the simulation.
Definition: fileservices.h:52
int getTraitIndex(trait_t type)
Gives the index of trait with type.
Definition: indfactory.cc:128
Interface to all basic components of a simulation (traits, life cycle events, pop,...
Definition: simcomponent.h:45
virtual void init()
Definition: stathandler.cc:39
Metapop * _pop
Link to the current population, set through the link to the StatService.
Definition: stathandler.h:61
A class to compute and store the summary statistics associated with a SimComponent.
Definition: stathandler.h:110
The Service class used to manage the StatHandler objects.
Definition: statservices.h:50
A class to handle matrix in params, coerces matrix into a vector of same total size.
Definition: tmatrix.h:50
Prototype of the evolving dispersal trait, defines the sex-specific trait type.
Definition: ttdispersal.h:120
TTDispersalSH * _stats
The trait's type.
Definition: ttdispersal.h:188
double _init_rate_mal
Initial allele for male dispersal.
Definition: ttdispersal.h:177
bool get_init_mode()
Definition: ttdispersal.h:165
virtual void loadFileServices(FileServices *loader)
Definition: ttdispersal.h:157
string _init_dist
Definition: ttdispersal.h:179
bool setNonRandom()
Definition: ttdispersal.cc:120
virtual vector< unsigned int > get_locus_map_positions()
Returns the map positions of the loci in vector.
Definition: ttdispersal.h:147
virtual int get_allele_number()
Returns the number of allele per locus.
Definition: ttdispersal.h:139
string get_init_dist()
Definition: ttdispersal.h:167
sex_t _gender
The gender of the trait, will determine its type.
Definition: ttdispersal.h:184
virtual void reset()
Definition: ttdispersal.h:132
double _mut_mean
Mean mutation step.
Definition: ttdispersal.h:173
virtual TTDispersal * hatch()
Definition: ttdispersal.cc:190
bool _init_random
Definition: ttdispersal.h:181
double _init_rate_fem
Initial allele for female dispersal.
Definition: ttdispersal.h:175
virtual bool is_mapped()
Checks if the trait's loci are placed on a genetic map.
Definition: ttdispersal.h:145
TProtoDispersal(sex_t sex)
Definition: ttdispersal.cc:44
virtual bool resetParameterFromSource(std::string param, SimComponent *cmpt)
Definition: ttdispersal.h:159
virtual int get_phenotype_dimension()
Returns the dimension of the phenotype of the trait (size of the array accessed with TTrait::getValue...
Definition: ttdispersal.h:137
TMatrix _init_dist_param
Definition: ttdispersal.h:180
virtual trait_t get_type() const
Definition: ttdispersal.h:135
virtual bool setParameters()
Definition: ttdispersal.cc:78
virtual void store_data(BinaryStorageBuffer *saver)
Definition: ttdispersal.h:151
virtual TProtoDispersal * clone()
Definition: ttdispersal.h:134
bool setRandom()
Definition: ttdispersal.cc:151
virtual int get_locus_number()
Returns the number of locus.
Definition: ttdispersal.h:141
virtual bool is_mappable()
Checks if the trait is mappable, i.e., if the loci can be placed on a genetic map.
Definition: ttdispersal.h:143
virtual void loadStatServices(StatServices *loader)
Definition: ttdispersal.cc:180
virtual ~TProtoDispersal()
Definition: ttdispersal.cc:71
TMatrix * get_init_dist_params()
Definition: ttdispersal.h:166
double _mut_rate
The allelic mutation rate.
Definition: ttdispersal.h:171
virtual bool retrieve_data(BinaryStorageBuffer *reader)
Definition: ttdispersal.h:152
virtual void init()
Definition: ttdispersal.h:131
The StatHandler for the evolving dispersal traits.
Definition: ttdispersal.h:197
double getMeanMalDispRate()
Definition: stats_disp.cc:189
virtual ~TTDispersalSH()
Definition: ttdispersal.h:210
int _mdispIdx
Definition: ttdispersal.h:203
int _fdispIdx
Definition: ttdispersal.h:203
double getPatchDisp_AF(unsigned int patch)
Definition: ttdispersal.h:244
double getMeanDispRate()
Definition: stats_disp.cc:56
double getPatchDisp_OF(unsigned int patch)
Definition: ttdispersal.h:234
double _meanOffMalDisp
Definition: ttdispersal.h:201
virtual bool setStatRecorders(std::string &token)
Definition: ttdispersal.cc:358
TProtoDispersal * _trait
Definition: ttdispersal.h:199
void addDispPerPatch(sex_t SEX, age_t AGE)
Definition: ttdispersal.cc:419
double getOffsprgMeanDispRate()
Definition: stats_disp.cc:105
double getmeanOFD()
Definition: ttdispersal.h:222
double _meanMalDisp
Definition: ttdispersal.h:201
double getmeanFD()
Definition: ttdispersal.h:224
double _meanOffFemDisp
Definition: ttdispersal.h:201
double getMeanDispRateInPatch(sex_t SEX, age_idx age, unsigned int traitidx, unsigned int i)
Definition: stats_disp.cc:39
double getMeanFemDispRate()
Definition: stats_disp.cc:170
double getmeanOMD()
Definition: ttdispersal.h:223
virtual void init()
Definition: ttdispersal.h:211
double getPatchDisp_AM(unsigned int patch)
Definition: ttdispersal.h:249
double getPatchDisp_OM(unsigned int patch)
Definition: ttdispersal.h:239
double getmeanMD()
Definition: ttdispersal.h:225
TTDispersalSH(TProtoDispersal *TT)
Definition: ttdispersal.h:207
double _meanFemDisp
Definition: ttdispersal.h:201
Evolving dispersal trait, codes for female (_type = FDISP) or male (_type = MDISP) sex-specific dispe...
Definition: ttdispersal.h:44
void set_mut_mean(double val)
Definition: ttdispersal.h:77
virtual double get_allele_value(int loc, int all) const
Definition: ttdispersal.h:98
void set_init_rate_fem(double val)
Definition: ttdispersal.h:78
void set_proto(TProtoDispersal *P)
Definition: ttdispersal.h:82
double _mut_mean
The mean mutation step.
Definition: ttdispersal.h:49
virtual ~TTDispersal()
Definition: ttdispersal.h:72
double _phenotype
Definition: ttdispersal.h:63
virtual TTDispersal * clone()
Definition: ttdispersal.h:104
void set_mut_rate(double val)
Definition: ttdispersal.h:76
virtual bool retrieve_data(BinaryStorageBuffer *reader)
Definition: ttdispersal.h:111
virtual void * getValue() const
Definition: ttdispersal.h:94
TTDispersal(sex_t sex)
Definition: ttdispersal.cc:211
virtual void ** get_sequence() const
Definition: ttdispersal.h:96
virtual void init_sequence()
Definition: ttdispersal.cc:262
virtual void reset()
Definition: ttdispersal.h:88
virtual void inherit(const TTrait *mother, const TTrait *father)
Definition: ttdispersal.cc:306
double _mut_rate
The allelic mutation rate.
Definition: ttdispersal.h:47
double _init_rate_fem
Initial allele for female dispersal.
Definition: ttdispersal.h:51
virtual void mutate()
Definition: ttdispersal.cc:317
virtual TTDispersal & operator=(const TTrait &TP)
Definition: ttdispersal.cc:221
double _sequence[2]
The trait's type.
Definition: ttdispersal.h:62
sex_t _gender
the gender of the trait, will determine its type.
Definition: ttdispersal.h:58
virtual bool operator==(const TTrait &TP)
Definition: ttdispersal.cc:238
TTDispersal(const TTDispersal &TP)
Definition: ttdispersal.h:68
void set_gender(sex_t val)
Definition: ttdispersal.h:80
virtual trait_t get_type() const
Definition: ttdispersal.h:91
void set_init_rate_mal(double val)
Definition: ttdispersal.h:79
virtual void set_sequence(void **seq)
Definition: ttdispersal.h:101
virtual unsigned int get_allele(int loc, int all) const
Definition: ttdispersal.h:97
virtual void set_value()
Definition: ttdispersal.h:92
virtual void * set_trait(void *value)
Definition: ttdispersal.h:102
double _init_rate_mal
Initial allele for male dispersal.
Definition: ttdispersal.h:53
virtual bool operator!=(const TTrait &TP)
Definition: ttdispersal.cc:252
virtual void store_data(BinaryStorageBuffer *saver)
Definition: ttdispersal.h:110
TProtoDispersal * _myProto
Definition: ttdispersal.h:55
virtual void init()
Definition: ttdispersal.h:86
virtual void show_up()
Definition: ttdispersal.cc:342
virtual void set_allele_value(unsigned int locus, unsigned int allele, double value)
Definition: ttdispersal.h:99
Interface for all trait types, declares all basic trait operations.
Definition: ttrait.h:46
TTrait setter.
Definition: ttrait.h:131
std::string trait_t
Trait types.
Definition: types.h:63
sex_t
Sex types, males are always 0 and females 1!!
Definition: types.h:36
@ FEM
Definition: types.h:37
@ MAL
Definition: types.h:37
#define MDISP
Definition: types.h:69
unsigned int age_t
Age class flags.
Definition: types.h:46
age_idx
Array index of the age classes in the patch sizes and containers arrays.
Definition: types.h:41
@ OFFSx
Definition: types.h:42
@ ADLTx
Definition: types.h:42
#define FDISP
Definition: types.h:68

Generated for Nemo v2.4.0b by  doxygen 1.9.1 -- Nemo is hosted on  Download Nemo

Locations of visitors to this page
Catalogued on GSR