30 #ifndef LCE_COMPOSITE_H
31 #define LCE_COMPOSITE_H
40 #include <gsl/gsl_rng.h>
41 #include <gsl/gsl_randist.h>
69 gsl_ran_discrete_t* rate_fem, gsl_ran_discrete_t* rate_mal);
140 return patch->
get_K(SEX);
145 double K = (double)patch->
get_K(SEX);
151 return (
unsigned int)ceil(N + r*N*((K-N)/K));
197 gsl_ran_discrete_t* rate_fem, gsl_ran_discrete_t* rate_mal);
200 gsl_ran_discrete_t* rate_fem, gsl_ran_discrete_t* rate_mal);
203 gsl_ran_discrete_t* rate_fem, gsl_ran_discrete_t* rate_mal);
206 gsl_ran_discrete_t* rate_fem, gsl_ran_discrete_t* rate_mal);
209 gsl_ran_discrete_t* rate_fem, gsl_ran_discrete_t* rate_mal);
214 gsl_ran_discrete_t* rates);
308 void do_breed (
sex_t SEX,
unsigned int size,
int* counter,
Patch* patch,
unsigned int patchID);
A class to manage the files associated with each components of the simulation.
Definition: fileservices.h:52
This class contains traits along with other individual information (sex, pedigree,...
Definition: individual.h:49
Performs breeding and migration in one, migration rates are backward rates.
Definition: LCEcomposite.h:50
unsigned int stochasticFecundityGrowth(Patch *patch, sex_t SEX)
The number of offspring produced is a random number drawn from a Poisson distribution with mean equal...
Definition: LCEcomposite.h:186
unsigned int(LCE_Breed_Disperse::* _get_numMalOffspring)(Patch *patch)
Definition: LCEcomposite.h:71
void do_breed_disperse()
Definition: LCEcomposite.cc:251
Individual * mate_cloning(sex_t SEX, Patch *patch, unsigned int LocalPatch, gsl_ran_discrete_t *rate_fem, gsl_ran_discrete_t *rate_mal)
Definition: LCEcomposite.cc:525
unsigned int conditionalLogisticGrowth(Patch *patch, sex_t SEX)
The number of offspring produced depends on the adult density.
Definition: LCEcomposite.h:160
unsigned int numMalOffspring_random_colonizers(Patch *patch)
Definition: LCEcomposite.h:123
void do_breed_disperse_in_empty_patch(sex_t SEX, Patch *patch, unsigned int ID, unsigned int num_offsprg)
Definition: LCEcomposite.cc:326
virtual bool resetParameterFromSource(std::string param, SimComponent *cmpt)
Definition: LCEcomposite.h:225
virtual age_t removeAgeClass()
Definition: LCEcomposite.h:226
Individual * get_parent(sex_t SEX, sex_t DispSex, Patch *LocalPatch, unsigned int patchID, gsl_ran_discrete_t *rates)
Definition: LCEcomposite.cc:537
virtual void loadStatServices(StatServices *loader)
Definition: LCEcomposite.h:224
LCE_Breed_Disperse()
Definition: LCEcomposite.cc:45
Individual * mate_full_selfing(sex_t SEX, Patch *patch, unsigned int LocalPatch, gsl_ran_discrete_t *rate_fem, gsl_ran_discrete_t *rate_mal)
Definition: LCEcomposite.cc:513
TMatrix _NatT0
Recorder of original patch sizes used to compute future sizes depending on growth rate model.
Definition: LCEcomposite.h:58
unsigned int exponentialGrowth(Patch *patch, sex_t SEX)
Exponential growth using current patch size as basis to calculate future sizes, set once the function...
Definition: LCEcomposite.cc:428
sex_t _dispersing_sex
Which part of the population is dispersing its gametes.
Definition: LCEcomposite.h:66
unsigned int numMalOffspring_notrandom(Patch *patch)
The number of males produced is always zero when the mating system is not random mating.
Definition: LCEcomposite.h:108
Individual * mate_selfing(sex_t SEX, Patch *patch, unsigned int LocalPatch, gsl_ran_discrete_t *rate_fem, gsl_ran_discrete_t *rate_mal)
Definition: LCEcomposite.cc:486
unsigned int(LCE_Breed_Disperse::* _get_patchFecundity)(Patch *patch, sex_t SEX)
Definition: LCEcomposite.h:72
unsigned int conditionalStochasticLogisticGrowth(Patch *patch, sex_t SEX)
The number of offspring produced depends on the adult density, similar to 'conditionalLogisticGrowth'...
Definition: LCEcomposite.h:170
Individual * makeOffspring(Individual *ind)
Individual * mate_random_hermaphrodite(sex_t SEX, Patch *patch, unsigned int LocalPatch, gsl_ran_discrete_t *rate_fem, gsl_ran_discrete_t *rate_mal)
Definition: LCEcomposite.cc:472
unsigned int stochasticLogisticGrowth(Patch *patch, sex_t SEX)
The number of offspring produced is drawn from a Poisson with mean equal to the logistic growth predi...
Definition: LCEcomposite.h:154
virtual age_t addAgeClass()
Definition: LCEcomposite.h:227
double * _growthRates
Patch-specific growth rates.
Definition: LCEcomposite.h:55
unsigned int numFemOffspring(Patch *patch)
Definition: LCEcomposite.h:86
void(LCE_Breed_Disperse::* _breed_disperse)()
Definition: LCEcomposite.h:51
virtual ~LCE_Breed_Disperse()
Definition: LCEcomposite.h:78
virtual age_t requiredAgeClass()
Definition: LCEcomposite.h:228
unsigned int numFemOffspring_colonizers(Patch *patch)
The number of females produced in case a max number of colonizers was specified.
Definition: LCEcomposite.h:95
unsigned int fixedFecundityGrowth(Patch *patch, sex_t SEX)
The number of offspring produced is equal to the current number of breeders multiplied by the mean fe...
Definition: LCEcomposite.h:180
Individual *(LCE_Breed_Disperse::* _make_offspring)(sex_t SEX, Patch *patch, unsigned int LocalPatch, gsl_ran_discrete_t *rate_fem, gsl_ran_discrete_t *rate_mal)
Definition: LCEcomposite.h:68
void do_breed_disperse_in_patch(sex_t SEX, Patch *patch, unsigned int ID, unsigned int num_offsprg)
Definition: LCEcomposite.cc:287
unsigned int numMalOffspring_random(Patch *patch)
Definition: LCEcomposite.h:113
int _num_colonizers
Maximum size of a patch after colonisation.
Definition: LCEcomposite.h:63
unsigned int logisticGrowth(Patch *patch, sex_t SEX)
The number of offspring produced is given by the logistic growth function.
Definition: LCEcomposite.h:143
Individual * mate_random(sex_t SEX, Patch *patch, unsigned int LocalPatch, gsl_ran_discrete_t *rate_fem, gsl_ran_discrete_t *rate_mal)
Definition: LCEcomposite.cc:459
virtual bool setParameters()
Definition: LCEcomposite.cc:61
virtual void loadFileServices(FileServices *loader)
Definition: LCEcomposite.h:223
unsigned int(LCE_Breed_Disperse::* _get_numFemOffspring)(Patch *patch)
Definition: LCEcomposite.h:70
virtual void execute()
Definition: LCEcomposite.cc:222
unsigned int instantGrowth(Patch *patch, sex_t SEX)
The number of offspring produced corresponds to the carrying capacity of the patch.
Definition: LCEcomposite.h:138
virtual LifeCycleEvent * clone()
Definition: LCEcomposite.h:222
void do_breed_disperse_propagule()
Definition: LCEcomposite.cc:420
Composite LCE performing breeding, migration and viability selection all in one.
Definition: LCEcomposite.h:294
virtual void execute()
Definition: LCEcomposite.cc:641
virtual void loadStatServices(StatServices *loader)
Definition: LCEcomposite.cc:634
virtual LifeCycleEvent * clone()
Definition: LCEcomposite.h:315
void breed_selection_disperse_propagule(int *counter)
Definition: LCEcomposite.cc:743
LCE_Breed_Selection_Disperse()
Definition: LCEcomposite.cc:588
virtual void loadFileServices(FileServices *loader)
Definition: LCEcomposite.h:316
void do_breed(sex_t SEX, unsigned int size, int *counter, Patch *patch, unsigned int patchID)
Definition: LCEcomposite.cc:751
virtual ~LCE_Breed_Selection_Disperse()
Definition: LCEcomposite.h:303
virtual age_t removeAgeClass()
Definition: LCEcomposite.h:319
virtual bool setParameters()
Definition: LCEcomposite.cc:597
virtual bool resetParameterFromSource(std::string param, SimComponent *cmpt)
Definition: LCEcomposite.h:318
void(LCE_Breed_Selection_Disperse::* _breed_selection_disperse)(int *counter)
Definition: LCEcomposite.h:297
virtual age_t addAgeClass()
Definition: LCEcomposite.h:320
virtual age_t requiredAgeClass()
Definition: LCEcomposite.h:321
void breed_selection_disperse(int *counter)
Definition: LCEcomposite.cc:681
Composite LCE implementing breeding and viability selection on a given trait type.
Definition: LCEcomposite.h:238
void do_breed_selection_WrightFisher_1sex(Patch *patch, unsigned int patchID, unsigned int *cntr)
Definition: LCEcomposite.cc:1136
virtual bool setParameters()
Definition: LCEcomposite.cc:883
void do_breed_selection_FecFitness(Patch *patch, unsigned int patchID, unsigned int *cntr)
Definition: LCEcomposite.cc:1041
void do_breed_selection_WrightFisher_2sex(Patch *patch, unsigned int patchID, unsigned int *cntr)
Definition: LCEcomposite.cc:1087
virtual age_t addAgeClass()
Definition: LCEcomposite.h:280
Individual * makeOffspringWithSelection(Individual *ind, unsigned int natalpatch)
Performs viability selection and breeding at the same time.
Definition: LCEcomposite.cc:1213
vector< unsigned int > _nonSelectedTraitIndices
Definition: LCEcomposite.h:244
virtual void loadStatServices(StatServices *loader)
Definition: LCEcomposite.cc:954
void do_breed_selection_OffSurvival(Patch *patch, unsigned int patchID, unsigned int *cntr)
Definition: LCEcomposite.cc:1005
virtual bool resetParameterFromSource(std::string param, SimComponent *cmpt)
Definition: LCEcomposite.h:278
virtual LifeCycleEvent * clone()
Definition: LCEcomposite.h:275
virtual age_t requiredAgeClass()
Definition: LCEcomposite.h:281
void setReproScaledFitness_sum(sex_t SEX, valarray< double > &survival, unsigned int numReproFem, Patch *patch)
Definition: LCEcomposite.cc:1181
virtual ~LCE_Breed_Selection()
Definition: LCEcomposite.h:249
LCE_Breed_Selection()
Definition: LCEcomposite.cc:874
virtual age_t removeAgeClass()
Definition: LCEcomposite.h:279
virtual void loadFileServices(FileServices *loader)
Definition: LCEcomposite.h:276
void(LCE_Breed_Selection::* _breed_selection)(Patch *patch, unsigned int patchID, unsigned int *cntr)
Definition: LCEcomposite.h:240
bool setNonSelectedTraitTable()
Builds the vector of traits not under selection.
Definition: LCEcomposite.cc:925
gsl_ran_discrete_t * setReproScaledFitness_gsl(sex_t SEX, unsigned int numReproInd, Patch *patch)
Definition: LCEcomposite.cc:1196
unsigned int _nb_trait
Definition: LCEcomposite.h:242
virtual void execute()
Definition: LCEcomposite.cc:961
Base class for the breeding (and mating) life cycle events.
Definition: LCEbreed.h:46
double getMeanFecundity(unsigned int patch)
Definition: LCEbreed.h:101
The base class of the dispersal LCEs, all events move offspring to the post-dispersal patch container...
Definition: LCEdisperse.h:44
Base class performing (viability) selection on an arbitrary trait.
Definition: LCEselection.h:51
Base class of the Life Cycle Events, declares the LCE interface.
Definition: lifecycleevent.h:73
Second class in the metapopulation design structure, between the Metapop and Individual classes.
Definition: metapop.h:432
unsigned int get_K()
Definition: metapop.h:482
unsigned int size(age_t AGE)
Returns the size of the container of the appropriate age class(es) for both sexes.
Definition: metapop.h:498
unsigned int getID()
Definition: metapop.h:481
bool get_isExtinct()
Definition: metapop.h:486
static double Poisson(double mean)
From the Numerical Recieps.
Definition: Uniform.h:219
static double Uniform()
Generates a random number from [0.0, 1.0[ uniformly distributed.
Definition: Uniform.h:124
Interface to all basic components of a simulation (traits, life cycle events, pop,...
Definition: simcomponent.h:45
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
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 NONE
No age flag.
Definition: types.h:48
unsigned int age_t
Age class flags.
Definition: types.h:46
#define ADULTS
Adults age class flag (breeders).
Definition: types.h:54
#define OFFSPRG
Offspring age class flag.
Definition: types.h:50
@ ADLTx
Definition: types.h:42