45 #include <gsl/gsl_vector.h>
46 #include <gsl/gsl_matrix.h>
47 #include <gsl/gsl_eigen.h>
77 virtual void*
set_trait (
void* value) {
return value;}
86 unsigned int to_pos,
const TTQuanti *parent) = 0;
89 virtual void mutate_add (
unsigned int position,
unsigned int allele,
double value) = 0;
90 virtual void mutate_inplace (
unsigned int position,
unsigned int allele,
double value) = 0;
93 virtual bool get_allele_bit (
unsigned int position,
unsigned int allele)
const = 0;
94 virtual void set_allele_bit (
unsigned int position,
unsigned int allele,
bool value) = 0;
134 virtual void reset ();
135 virtual void init ();
138 virtual unsigned int get_allele (
int loc,
int all)
const ;
140 virtual void set_allele_value (
unsigned int locus,
unsigned int allele,
double value);
153 virtual void mutate_add (
unsigned int position,
unsigned int allele,
double value)
155 virtual void mutate_inplace (
unsigned int position,
unsigned int allele,
double value)
157 virtual bool get_allele_bit (
unsigned int position,
unsigned int allele)
const {
return false;}
158 virtual void set_allele_bit (
unsigned int position,
unsigned int allele,
bool value) {}
189 unsigned int to_locus,
const TTQuanti *parent);
218 unsigned int to_locus,
const TTQuanti *parent);
245 unsigned int to_locus,
const TTQuanti *parent);
272 unsigned int to_locus,
const TTQuanti *parent);
291 virtual bool get_allele_bit (
unsigned int position,
unsigned int allele)
const;
292 virtual void set_allele_bit (
unsigned int position,
unsigned int allele,
bool value);
296 virtual void reset ();
297 virtual void init ();
300 virtual unsigned int get_allele (
int loc,
int all)
const ;
302 virtual void set_allele_value (
unsigned int locus,
unsigned int allele,
double value);
315 virtual void mutate_add (
unsigned int position,
unsigned int allele,
double value)
316 {
_sequence[allele][position] = bool(value);}
317 virtual void mutate_inplace (
unsigned int position,
unsigned int allele,
double value)
347 unsigned int to_locus,
const TTQuanti *parent);
374 unsigned int to_locus,
const TTQuanti *parent);
403 unsigned int to_locus,
const TTQuanti *parent);
474 double get_allele_value (
const TTQuanti* ind,
const unsigned int allele,
const unsigned int locus,
const unsigned int trait);
744 gsl_eigen_symmv_workspace *
_ws;
763 virtual void init ( );
824 void print(ofstream& FH,
Patch* patch,
sex_t SEX,
age_idx Ax,
unsigned int print_gene,
bool print_genotype,
bool print_additive_genotype);
829 virtual void FHread (
string& filename);
847 virtual void FHread (
string& filename) {}
864 virtual void FHread (
string& filename) {}
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
Second class in the metapopulation design structure, between the Metapop and Individual classes.
Definition: metapop.h:432
static double Binomial(double p, unsigned int n)
Definition: Uniform.h:492
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
double get(unsigned int i, unsigned int j) const
Accessor to element at row i and column j.
Definition: tmatrix.h:193
TProtoQuanti.
Definition: ttquanti.h:415
bool setMutationSigmaFromQuantiMutationVariance()
Definition: ttquanti.cc:1922
bool _equal_effects
Definition: ttquanti.h:624
vector< double > _eVariance
Definition: ttquanti.h:657
double * getMutationEffectMultivariateGaussian(unsigned int loc)
Definition: ttquanti.cc:2390
unsigned int setAlleleModel()
Definition: ttquanti.cc:805
double set_genotype_value_dominance(const TTQuanti *ind, const unsigned int trait)
Definition: ttquanti.cc:2532
bool do_epistasis()
Definition: ttquanti.h:567
unsigned int _allele_model
Definition: ttquanti.h:610
TMatrix _dominance_effects
Definition: ttquanti.h:648
bool _epistasis
Definition: ttquanti.h:680
size_t _sizeofLocusType
Definition: ttquanti.h:654
void set_mutation_matrix_decomposition(unsigned int loc, unsigned int pleio_deg)
Definition: ttquanti.cc:2259
unsigned int _doInitMutation
Definition: ttquanti.h:642
unsigned int get_locus_PD(unsigned int locus)
Definition: ttquanti.h:457
void mutate_inplace_var_pleio(TTQuanti *ind)
Definition: ttquanti.cc:2788
double set_genotype_value_additive(const TTQuanti *ind, const unsigned int trait)
Definition: ttquanti.cc:2525
void setTraitAndLocusTables_full_pleio()
Definition: ttquanti.cc:1273
virtual ~TProtoQuanti()
Definition: ttquanti.cc:224
double set_trait_value_VE(const TTQuanti *ind, const unsigned int trait)
Definition: ttquanti.cc:2511
virtual int get_phenotype_dimension()
Returns the dimension of the phenotype of the trait (size of the array accessed with TTrait::getValue...
Definition: ttquanti.h:578
void mutate_diallelic_var_pleio(TTQuanti *ind)
Definition: ttquanti.cc:2847
void mutate_var_pleio(TTQuanti *ind)
Definition: ttquanti.cc:2717
bool setContinuousMutationModel_var_pleio()
Definition: ttquanti.cc:1669
unsigned int _dominance_model
Definition: ttquanti.h:647
bool _equal_dom_coeff
Definition: ttquanti.h:649
double get_equal_val_diff()
Definition: ttquanti.h:444
TMatrix _mutation_correlation
Definition: ttquanti.h:634
double * getMutationEffectUnivariateGaussian(unsigned int loc)
Definition: ttquanti.cc:2433
gsl_matrix * set_gsl_mutation_matrix_from_sigma(unsigned int loc, unsigned int pleio_deg)
Definition: ttquanti.cc:2223
bool setMutationModel_var_pleio()
Definition: ttquanti.cc:948
double get_allele_value(const TTQuanti *ind, const unsigned int allele, const unsigned int locus, const unsigned int trait)
Definition: ttquanti.cc:2487
void(TProtoQuanti::* _inherit_fun_ptr)(sex_t, TTQuanti *, const TTQuanti *)
Pointer to inheritance functions: either inherit_free() (r=0.5), or inherit_low() (r<0....
Definition: ttquanti.h:689
bool setMutationModel_no_pleio()
Definition: ttquanti.cc:1144
bool _h2_isBroad
Definition: ttquanti.h:660
const TMatrix & get_diallele_values()
Definition: ttquanti.h:435
const TMatrix & get_pleio_matrix()
Definition: ttquanti.h:452
TTQuantiFH * _reader
Definition: ttquanti.h:724
bool setDominanceParameters()
Definition: ttquanti.cc:2311
unsigned int _h2_setTime
Definition: ttquanti.h:659
unsigned int _seq_length
Total number of allelic values stored in individual sequences, no trait x no locus.
Definition: ttquanti.h:609
double _mutation_rate
Definition: ttquanti.h:614
gsl_matrix ** _evect
Definition: ttquanti.h:637
void mutate_nill(TTQuanti *ind)
Definition: ttquanti.cc:2663
bool setContinuousMutationModel_no_pleio()
Definition: ttquanti.cc:1826
gsl_vector ** _ws
Definition: ttquanti.h:640
TMatrix _mutation_sigma
Definition: ttquanti.h:635
double get_dominance(unsigned int locus, unsigned int trait)
Definition: ttquanti.h:479
bool setInitialValuesParams()
Definition: ttquanti.cc:594
bool _mutationVarianceIsLocusSpecific
Definition: ttquanti.h:643
const TMatrix & get_epi_coefs() const
Definition: ttquanti.h:568
bool readMatrixFromQuantiMutationMatrix(vector< vector< double >> &varmat)
Definition: ttquanti.cc:2058
TMatrix _allele_value
Definition: ttquanti.h:622
bool setGeneticMapParams()
Definition: ttquanti.cc:649
double * getMutationEffects(unsigned int loc)
Definition: ttquanti.h:533
double * getMutationEffectBivariateGaussian(unsigned int loc)
Definition: ttquanti.cc:2414
void set_trait_value_func_ptr(bool withVe)
Definition: ttquanti.cc:679
TTQuantiSH * get_stater()
Definition: ttquanti.h:450
vector< double > _h2
Definition: ttquanti.h:658
unsigned int _num_epi_coefs
Definition: ttquanti.h:681
size_t get_locus_byte_size()
Definition: ttquanti.h:429
void mutate_diallelic_no_pleio(TTQuanti *ind)
Definition: ttquanti.cc:2878
double get_genotypic_value(const TTQuanti *ind, const unsigned int trait)
Definition: ttquanti.h:485
unsigned int _num_traits
Number of traits.
Definition: ttquanti.h:607
double * _sequence_diallele_values[2]
Definition: ttquanti.h:623
double get_init_value(unsigned int i)
Definition: ttquanti.h:447
void mutate_inplace_full_pleio(TTQuanti *ind)
Definition: ttquanti.cc:2763
size_t get_size_locus_type()
Definition: ttquanti.h:428
unsigned int get_locus_ID(unsigned int locus, unsigned int trait)
Definition: ttquanti.h:455
TTQuantiSH * _stats
Definition: ttquanti.h:722
virtual TTQuanti * hatch()
Definition: ttquanti.cc:2898
void set_init_values(const double *values, unsigned int nval)
Definition: ttquanti.cc:2501
void(TProtoQuanti::* _mutation_func_ptr)(TTQuanti *)
Pointer to mutation function, which depends on allele on model (HC, noHC, diallelic)
Definition: ttquanti.h:692
gsl_vector ** _effects_multivar
Definition: ttquanti.h:639
double(TProtoQuanti::* _set_genotype_func_ptr)(const TTQuanti *, const unsigned int)
Pointer to functions get_genotype_value_additive() or get_genotype_value_dominance() computing the ge...
Definition: ttquanti.h:713
void inherit(sex_t SEX, TTQuanti *ind, const TTQuanti *parent)
Definition: ttquanti.cc:2594
TMatrix _pleio_matx
Pleiotropy matrix provided in input (num locu X num trait).
Definition: ttquanti.h:665
unsigned int get_num_epi_coefs()
Definition: ttquanti.h:566
string _diallele_datatype
Definition: ttquanti.h:611
const bitstring & get_trait_mask(unsigned int trait) const
Definition: ttquanti.h:445
double get_seq_diallele_value(unsigned int position, unsigned int allele)
Definition: ttquanti.h:438
double _genomic_mutation_rate
Definition: ttquanti.h:615
gsl_matrix ** _gsl_mutation_matrix
Definition: ttquanti.h:636
bool has_equal_effects()
Definition: ttquanti.h:441
double * getMutationEffectBivariateDiallelic(unsigned int loc)
Definition: ttquanti.cc:2457
virtual bool retrieve_data(BinaryStorageBuffer *reader)
Definition: ttquanti.h:589
double get_diallele_value(unsigned int locus, unsigned int allele)
Definition: ttquanti.h:436
vector< vector< unsigned int > > _trait_locus_table
Table storing the locus id of each locus affecting each trait (num trait X (variable length/trait)).
Definition: ttquanti.h:671
unsigned int get_allele_model()
Definition: ttquanti.h:434
double get_init_variance(unsigned int i)
Definition: ttquanti.h:448
bool * _all_chooser
Definition: ttquanti.h:652
bool setMutationSigmaFromQuantiMutationVariance_no_pleio()
Definition: ttquanti.cc:1992
double(TProtoQuanti::* _getGenotypeWithDominance)(double, double, double)
Pointer to either dominance_h() or dominance_k() function computing the genotypic value with dominanc...
Definition: ttquanti.h:701
double _equal_val_diff
Definition: ttquanti.h:627
void allocate_gsl_mutation_matrix_space(unsigned int num_locus)
Definition: ttquanti.cc:2117
TMatrix _epistatic_coefs_matrix
Definition: ttquanti.h:682
vector< bitstring > _trait_masks
Definition: ttquanti.h:628
double _equal_val_0
Definition: ttquanti.h:625
TMatrix _init_variance
Definition: ttquanti.h:630
void inherit_low(sex_t SEX, TTQuanti *ind, const TTQuanti *parent)
Definition: ttquanti.cc:2601
virtual int get_locus_number()
Returns the number of locus.
Definition: ttquanti.h:582
void mutate(TTQuanti *ind)
Definition: ttquanti.cc:2656
unsigned int get_h2_setTime()
Definition: ttquanti.h:432
const TMatrix & get_dominance_effects()
Definition: ttquanti.h:481
virtual TProtoQuanti * clone()
Definition: ttquanti.h:575
void mutate_inplace_no_pleio(TTQuanti *ind)
Definition: ttquanti.cc:2743
double * getMutationEffectUnivariateGaussianLocSpec(unsigned int loc)
Definition: ttquanti.cc:2441
unsigned int get_locus_seq_pos(unsigned int loc, unsigned int trait)
Definition: ttquanti.h:453
void mutate_diallelic_pleio(TTQuanti *ind)
Definition: ttquanti.cc:2812
vector< vector< unsigned int > > _trait_table
Trait table, (num trait X (variable length/trait)), holds, for each trait, the array position of caus...
Definition: ttquanti.h:668
void setTraitAndLocusTables_no_pleio(TMatrix &mat)
Definition: ttquanti.cc:1305
gsl_matrix * set_gsl_mutation_matrix(unsigned int pleio_deg, const vector< double > &varcov)
Definition: ttquanti.cc:2186
double * getMutationEffectBivariateGaussianLocSpec(unsigned int loc)
Definition: ttquanti.cc:2424
vector< vector< unsigned int > > _locus_table
Locus table, num_locus x 2, first column holds the start position of the alleles of each locus in the...
Definition: ttquanti.h:676
unsigned int get_num_mutations()
Definition: ttquanti.h:543
vector< double > get_heritability()
Definition: ttquanti.h:431
const TMatrix & get_epi_coef_index() const
Definition: ttquanti.h:569
size_t _locusByteSize
Definition: ttquanti.h:653
TMatrix _init_value
Definition: ttquanti.h:629
double get_equal_val_0()
Definition: ttquanti.h:442
double set_trait_value_noVE(const TTQuanti *ind, const unsigned int trait)
Definition: ttquanti.cc:2518
unsigned int get_sequence_block_size(unsigned int from, unsigned int to)
Definition: ttquanti.h:459
unsigned int get_num_locus()
Definition: ttquanti.h:424
virtual void loadStatServices(StatServices *loader)
Definition: ttquanti.cc:3091
unsigned int get_seq_length()
Definition: ttquanti.h:427
bool setEpistasisParameters()
Definition: ttquanti.cc:689
double(TProtoQuanti::* _set_trait_value_func_ptr)(const TTQuanti *, const unsigned int)
Pointer to either set_trait_value_VE() or set_trait_value_noVE() to compute phenotypic values.
Definition: ttquanti.h:707
double get_phenotypic_value(const TTQuanti *ind, const unsigned int trait)
Definition: ttquanti.h:489
unsigned int get_pleiotropy_type()
Definition: ttquanti.h:426
bool setHeritabilityParams()
Definition: ttquanti.cc:438
virtual trait_t get_type() const
Definition: ttquanti.h:576
double *(TProtoQuanti::* _getMutationValues)(unsigned int)
Pointer to mutation allele value function, which depends on allele model and number of traits affecte...
Definition: ttquanti.h:695
double get_genotype_dominance_k(double a1, double a2, double k)
Definition: ttquanti.cc:2573
virtual bool resetParameterFromSource(std::string param, SimComponent *cmpt)
Definition: ttquanti.h:597
double get_genotype_dominance_h(double a1, double a2, double h)
Definition: ttquanti.cc:2557
double _effects_bivar[2]
Definition: ttquanti.h:641
virtual void reset()
Definition: ttquanti.h:573
double * getMutationEffectMultivariateGaussianLocSpec(unsigned int loc)
Definition: ttquanti.cc:2402
bool setDiallelicMutationModel()
Definition: ttquanti.cc:1348
unsigned int get_num_traits()
Definition: ttquanti.h:423
double get_equal_val_1()
Definition: ttquanti.h:443
gsl_vector ** _eval
Definition: ttquanti.h:638
unsigned int get_doInitMutation()
Definition: ttquanti.h:449
TMatrix _epistatic_coefs_indices
Definition: ttquanti.h:683
TTQuantiFH * _writer
Definition: ttquanti.h:723
virtual bool setParameters()
Definition: ttquanti.cc:249
bool has_equal_domCoeff()
Definition: ttquanti.h:440
bool setMutationCorrelation()
Definition: ttquanti.cc:1864
bool get_h2_isBroad()
Definition: ttquanti.h:433
virtual void loadFileServices(FileServices *loader)
Definition: ttquanti.cc:2977
void mutate_full_pleio(TTQuanti *ind)
Definition: ttquanti.cc:2691
virtual void store_data(BinaryStorageBuffer *saver)
Definition: ttquanti.h:586
bool _mutationEffectIsFixedDiAllele
Definition: ttquanti.h:644
TTQOhtaStats * _ohtaStats
Definition: ttquanti.h:726
double get_trait_mutation_variance(unsigned int trait)
Definition: ttquanti.cc:2580
virtual int get_allele_number()
Returns the number of allele per locus.
Definition: ttquanti.h:580
unsigned int _2L
Diploid locus size, to save on useless operations during mutation.
Definition: ttquanti.h:605
unsigned int get_dominance_model()
Definition: ttquanti.h:478
bool setContinuousMutationModel_full_pleio()
Definition: ttquanti.cc:1502
double * getMutationEffectsVarPleio(unsigned int loc)
Definition: ttquanti.h:536
TProtoQuanti()
Definition: ttquanti.cc:64
bool setMutationModel_full_pleio()
Definition: ttquanti.cc:869
unsigned int _num_locus
Total number of loci, for all traits.
Definition: ttquanti.h:603
unsigned int get_num_locus(unsigned int trait)
Definition: ttquanti.h:425
unsigned int get_locus_start_pos(unsigned int locus)
Definition: ttquanti.h:458
double _equal_val_1
Definition: ttquanti.h:626
void set_eVarianceSD(unsigned int trait, double SD)
Definition: ttquanti.cc:2380
double get_genotype_with_dominance(const double a1, const double a2, const unsigned int locus, const unsigned int trait)
Definition: ttquanti.cc:2539
int get_allele_position(const unsigned int locus, const unsigned int trait)
Definition: ttquanti.cc:2468
void inherit_free(sex_t SEX, TTQuanti *ind, const TTQuanti *parent)
Definition: ttquanti.cc:2639
vector< double > get_env_var()
Definition: ttquanti.h:430
unsigned int _pleio_type
Definition: ttquanti.h:618
void mutate_no_pleio(TTQuanti *ind)
Definition: ttquanti.cc:2670
void deallocate_gsl_mutation_matrix_space()
Definition: ttquanti.cc:2137
TTQFreqExtractor * _freqExtractor
Definition: ttquanti.h:725
vector< double *(TProtoQuanti::*)(unsigned int) > _getMutationValuesVarPleio
Collection of pointers to mutation functions, which generate allele values in dependence of pleiotrop...
Definition: ttquanti.h:698
TTProtoWithMap.
Definition: ttrait_with_map.h:184
virtual void reset()
Definition: ttrait_with_map.cc:638
TTQOhtaStats.
Definition: ttquanti.h:855
TMatrix _pairwiseCombs
Definition: ttquanti.h:857
virtual void FHread(string &filename)
Definition: ttquanti.h:864
TTQOhtaStats(TProtoQuanti *T)
Definition: ttquanti.h:860
virtual ~TTQOhtaStats()
Definition: ttquanti.h:862
virtual void FHwrite()
Definition: ttquanti.cc:6466
TTQuantiFH.
Definition: ttquanti.h:810
void write_PLINK()
Definition: ttquanti.cc:5885
void print_PLINK_FAM(ofstream &FH, age_idx Ax, Patch *patch)
Definition: ttquanti.cc:6117
TTQuantiFH(TProtoQuanti *T)
Definition: ttquanti.h:816
virtual void FHread(string &filename)
Definition: ttquanti.cc:6192
void print_PLINK_PED(ofstream &FH, age_idx Ax, Patch *patch)
Definition: ttquanti.cc:6020
void write_TABLE()
Definition: ttquanti.cc:5721
virtual void FHwrite()
Definition: ttquanti.cc:5699
virtual ~TTQuantiFH()
Definition: ttquanti.h:818
string _output_option
Definition: ttquanti.h:812
bool _has_genetic_map
Definition: ttquanti.h:813
void setOutputOption(string opt)
Definition: ttquanti.cc:5677
void print(ofstream &FH, Patch *patch, sex_t SEX, age_idx Ax, unsigned int print_gene, bool print_genotype, bool print_additive_genotype)
Definition: ttquanti.cc:5816
TTQuantiSH.
Definition: ttquanti.h:734
double * _Vp
Definition: ttquanti.h:736
double getMeanGenotPerPatch(unsigned int i, unsigned int p)
Definition: ttquanti.h:791
void addQuanti(age_t AGE)
Definition: ttquanti.cc:4738
void addAvgPerPatch(age_t AGE)
Definition: ttquanti.cc:4823
double ** _pVa
Definition: ttquanti.h:737
double getEigenVectorEltPerPatch(unsigned int p, unsigned int v)
Definition: ttquanti.h:797
vector< double > getVaNoDominance(Patch *curPop, const age_idx AGE)
Definition: ttquanti.cc:5390
double * _Vb
Definition: ttquanti.h:736
unsigned int _num_locus
Definition: ttquanti.h:740
void addCovarPerPatch(age_t AGE)
Definition: ttquanti.cc:4946
double * _meanP
Definition: ttquanti.h:736
void addEigenVect1PerPatch(age_t AGE)
Definition: ttquanti.cc:5065
void addVarPerPatch(age_t AGE)
Definition: ttquanti.cc:4893
TTQuantiSH(TProtoQuanti *TP)
Definition: ttquanti.h:751
virtual ~TTQuantiSH()
Definition: ttquanti.h:759
double ** _pVp
Definition: ttquanti.h:737
double getVa(unsigned int i)
Definition: ttquanti.h:784
bool _eVar
Definition: ttquanti.h:738
gsl_matrix * _evec
Definition: ttquanti.h:742
double getEigenValuePerPatch(unsigned int i, unsigned int p)
Definition: ttquanti.h:795
void addGenotPerPatch(age_t AGE)
Definition: ttquanti.cc:4858
unsigned int _table_set_age
Definition: ttquanti.h:747
void addEigenValuesPerPatch(age_t AGE)
Definition: ttquanti.cc:5031
double getVb(unsigned int i)
Definition: ttquanti.h:786
double getSkewPerPatch(unsigned int i, unsigned int p)
Definition: ttquanti.cc:5140
double ** _pmeanP
Definition: ttquanti.h:737
double * _meanG
Definition: ttquanti.h:736
double getMeanPhenotPerPatch(unsigned int i, unsigned int p)
Definition: ttquanti.h:792
void setStats(age_t AGE)
Definition: ttquanti.cc:5226
void setAdultStats()
Definition: ttquanti.h:779
double getVg(unsigned int i)
Definition: ttquanti.h:785
gsl_vector * _eval
Definition: ttquanti.h:743
double getMeanPhenot(unsigned int i)
Definition: ttquanti.h:783
double * _covar
Definition: ttquanti.h:736
DataTable< double > _phenoTable
Definition: ttquanti.h:746
double getCovarPerPatch(unsigned int p, unsigned int i)
Definition: ttquanti.h:796
double getQst(unsigned int i)
Definition: ttquanti.h:788
void addEigenPerPatch(age_t AGE)
Definition: ttquanti.cc:4987
vector< double > getVaWithDominance(Patch *curPop, const age_idx AGE)
computation of the additive genetic variance from the average excess of each allele exact under rando...
Definition: ttquanti.cc:5489
double getVp(unsigned int i)
Definition: ttquanti.h:787
gsl_matrix * _G
Definition: ttquanti.h:742
double getMeanGenot(unsigned int i)
Definition: ttquanti.h:782
double ** _peigvect
Definition: ttquanti.h:737
unsigned int _table_set_repl
Definition: ttquanti.h:747
double getVpPerPatch(unsigned int i, unsigned int p)
Definition: ttquanti.h:794
gsl_eigen_symmv_workspace * _ws
Definition: ttquanti.h:744
unsigned int _table_set_gen
Definition: ttquanti.h:747
double getCovar(unsigned int i)
Definition: ttquanti.h:789
vector< double > getSNPalleleFreqInPatch(Patch *patch, const age_idx AGE)
Definition: ttquanti.cc:5347
virtual bool setStatRecorders(std::string &token)
Definition: ttquanti.cc:4676
DataTable< double > _genoTable
Definition: ttquanti.h:746
unsigned int _num_trait
Definition: ttquanti.h:740
double * _Va
Definition: ttquanti.h:736
void resetPtrs()
Definition: ttquanti.cc:4545
double * _Vg
Definition: ttquanti.h:736
void setDataTables(age_t AGE)
Definition: ttquanti.cc:5155
void addQuantiPerPatch(age_t AGE)
Definition: ttquanti.cc:4807
double ** _peigval
Definition: ttquanti.h:737
unsigned int _patchNbr
Definition: ttquanti.h:740
double ** _pcovar
Definition: ttquanti.h:737
double ** _pmeanG
Definition: ttquanti.h:737
double getVaPerPatch(unsigned int i, unsigned int p)
Definition: ttquanti.h:793
void addSkewPerPatch(age_t AGE)
Definition: ttquanti.cc:5104
void setOffsprgStats()
Definition: ttquanti.h:780
virtual void init()
Definition: ttquanti.cc:4603
TTQuanti_continuous_full_pleio : universal pleiotropy.
Definition: ttquanti.h:171
TTQuanti_continuous_full_pleio(const TTQuanti_continuous_full_pleio &TT)
Definition: ttquanti.h:176
virtual void show_up()
Definition: ttquanti.cc:3452
virtual void copy_sequence_1locus(sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)
Definition: ttquanti.cc:3363
virtual void copy_sequence_block(sex_t SEX, unsigned int strand, unsigned int from_locus, unsigned int to_locus, const TTQuanti *parent)
Definition: ttquanti.cc:3346
virtual ~TTQuanti_continuous_full_pleio()
Definition: ttquanti.h:178
virtual TTQuanti_continuous_full_pleio * clone()
Definition: ttquanti.h:182
TTQuanti_continuous_full_pleio()
Definition: ttquanti.h:174
virtual double get_dominant_genotype(const unsigned int trait) const
Definition: ttquanti.cc:3331
virtual double get_additive_genotype(const unsigned int trait) const
Definition: ttquanti.cc:3314
virtual void init_sequence()
Definition: ttquanti.cc:3375
TTQuanti_continuous_no_pleio : multiple non-pleiotropic traits.
Definition: ttquanti.h:227
virtual double get_dominant_genotype(const unsigned int trait) const
Definition: ttquanti.cc:3686
virtual ~TTQuanti_continuous_no_pleio()
Definition: ttquanti.h:234
TTQuanti_continuous_no_pleio()
Definition: ttquanti.h:230
virtual TTQuanti_continuous_no_pleio * clone()
Definition: ttquanti.h:238
TTQuanti_continuous_no_pleio(const TTQuanti_continuous_no_pleio &TT)
Definition: ttquanti.h:232
virtual void init_sequence()
Definition: ttquanti.cc:3755
virtual void copy_sequence_1locus(sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)
Definition: ttquanti.cc:3745
virtual void copy_sequence_block(sex_t SEX, unsigned int strand, unsigned int from_locus, unsigned int to_locus, const TTQuanti *parent)
Definition: ttquanti.cc:3729
virtual double get_additive_genotype(const unsigned int trait) const
Definition: ttquanti.cc:3665
virtual void show_up()
Definition: ttquanti.cc:3809
TTQuanti_continuous_single : simple implementation for a single quantitative trait with continuous al...
Definition: ttquanti.h:254
virtual void copy_sequence_block(sex_t SEX, unsigned int strand, unsigned int from_locus, unsigned int to_locus, const TTQuanti *parent)
virtual TTQuanti_continuous_single * clone()
Definition: ttquanti.h:265
virtual void copy_sequence_1locus(sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)
virtual ~TTQuanti_continuous_single()
Definition: ttquanti.h:261
virtual double get_dominant_genotype(const unsigned int trait) const
Definition: ttquanti.cc:3867
virtual void init_sequence()
virtual double get_additive_genotype(const unsigned int trait) const
Definition: ttquanti.cc:3854
TTQuanti_continuous_single(const TTQuanti_continuous_single &TT)
Definition: ttquanti.h:259
TTQuanti_continuous_single()
Definition: ttquanti.h:257
TTQuanti_continuous_var_pleio : variable pleiotropy.
Definition: ttquanti.h:198
unsigned int get_sequence_block_size(unsigned int from, unsigned int to)
Definition: ttquanti.cc:3525
virtual double get_additive_genotype(const unsigned int trait) const
Definition: ttquanti.cc:3491
virtual void copy_sequence_1locus(sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)
Definition: ttquanti.cc:3548
TTQuanti_continuous_var_pleio()
Definition: ttquanti.h:201
virtual TTQuanti_continuous_var_pleio * clone()
Definition: ttquanti.h:211
virtual void show_up()
Definition: ttquanti.cc:3620
virtual double get_dominant_genotype(const unsigned int trait) const
Definition: ttquanti.cc:3508
TTQuanti_continuous_var_pleio(const TTQuanti_continuous_var_pleio &TT)
Definition: ttquanti.h:203
virtual ~TTQuanti_continuous_var_pleio()
Definition: ttquanti.h:205
virtual void init_sequence()
Definition: ttquanti.cc:3561
virtual void copy_sequence_block(sex_t SEX, unsigned int strand, unsigned int from_locus, unsigned int to_locus, const TTQuanti *parent)
Definition: ttquanti.cc:3533
TTQuanti_continuous.
Definition: ttquanti.h:114
virtual bool retrieve_data(BinaryStorageBuffer *reader)
Definition: ttquanti.cc:3291
virtual void set_allele_value(unsigned int locus, unsigned int allele, double value)
Definition: ttquanti.cc:3231
TTQuanti_continuous(const TTQuanti &T)
Definition: ttquanti.h:123
TTQuanti_continuous()
Definition: ttquanti.h:118
virtual void set_allele(int locus, int allele, double value)
Definition: ttquanti.h:152
virtual void store_data(BinaryStorageBuffer *saver)
Definition: ttquanti.cc:3283
virtual bool operator!=(const TTrait &T)
Definition: ttquanti.cc:3205
virtual unsigned int get_allele(int loc, int all) const
Definition: ttquanti.cc:3215
virtual void ** get_sequence() const
Definition: ttquanti.h:137
virtual void set_allele_bit(unsigned int position, unsigned int allele, bool value)
Definition: ttquanti.h:158
virtual ~TTQuanti_continuous()
Definition: ttquanti.h:128
virtual void set_sequence(void **seq)
Definition: ttquanti.cc:3300
virtual void mutate_add(unsigned int position, unsigned int allele, double value)
Definition: ttquanti.h:153
virtual void init()
Definition: ttquanti.cc:3239
virtual void mutate_inplace(unsigned int position, unsigned int allele, double value)
Definition: ttquanti.h:155
virtual TTQuanti_continuous & operator=(const TTrait &T)
Definition: ttquanti.cc:3167
virtual double get_full_genotype(unsigned int trait)
Definition: ttquanti.cc:3276
virtual double get_allele_value(int loc, int all) const
Definition: ttquanti.cc:3223
virtual bool operator==(const TTrait &T)
Definition: ttquanti.cc:3188
virtual void reset()
Definition: ttquanti.cc:3259
double ** _sequence
Definition: ttquanti.h:163
virtual bool get_allele_bit(unsigned int position, unsigned int allele) const
Definition: ttquanti.h:157
TTQuanti_diallelic_full_pleio : pleiotropic di-allelic loci, max PD = 2.
Definition: ttquanti.h:356
virtual TTQuanti_diallelic_full_pleio * clone()
Definition: ttquanti.h:367
virtual double get_dominant_genotype(const unsigned int trait) const
Definition: ttquanti.cc:4244
virtual void show_up()
Definition: ttquanti.cc:4338
TTQuanti_diallelic_full_pleio()
Definition: ttquanti.h:359
virtual ~TTQuanti_diallelic_full_pleio()
Definition: ttquanti.h:363
virtual void copy_sequence_block(sex_t SEX, unsigned int strand, unsigned int from_locus, unsigned int to_locus, const TTQuanti *parent)
Definition: ttquanti.cc:4265
virtual void copy_sequence_1locus(sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)
Definition: ttquanti.cc:4281
virtual double get_additive_genotype(const unsigned int trait) const
Definition: ttquanti.cc:4226
virtual void init_sequence()
Definition: ttquanti.cc:4293
TTQuanti_diallelic_full_pleio(const TTQuanti_diallelic_full_pleio &TT)
Definition: ttquanti.h:361
TTQuanti_diallelic_no_pleio : single or multiple non-pleiotropic traits, di-allelic.
Definition: ttquanti.h:329
TTQuanti_diallelic_no_pleio()
Definition: ttquanti.h:332
virtual ~TTQuanti_diallelic_no_pleio()
Definition: ttquanti.h:336
virtual void copy_sequence_block(sex_t SEX, unsigned int strand, unsigned int from_locus, unsigned int to_locus, const TTQuanti *parent)
Definition: ttquanti.cc:4112
virtual TTQuanti_diallelic_no_pleio * clone()
Definition: ttquanti.h:340
virtual double get_dominant_genotype(const unsigned int trait) const
Definition: ttquanti.cc:4091
virtual double get_additive_genotype(const unsigned int trait) const
Definition: ttquanti.cc:4063
virtual void copy_sequence_1locus(sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)
Definition: ttquanti.cc:4128
virtual void init_sequence()
Definition: ttquanti.cc:4138
TTQuanti_diallelic_no_pleio(const TTQuanti_diallelic_no_pleio &TT)
Definition: ttquanti.h:334
virtual void show_up()
Definition: ttquanti.cc:4183
TTQuanti_diallelic_var_pleio : variable pleiotropic di-allelic loci, max PD = 2.
Definition: ttquanti.h:383
virtual void copy_sequence_block(sex_t SEX, unsigned int strand, unsigned int from_locus, unsigned int to_locus, const TTQuanti *parent)
Definition: ttquanti.cc:4423
TTQuanti_diallelic_var_pleio(const TTQuanti_diallelic_var_pleio &TT)
Definition: ttquanti.h:388
virtual void copy_sequence_1locus(sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)
Definition: ttquanti.cc:4440
TTQuanti_diallelic_var_pleio()
Definition: ttquanti.h:386
virtual TTQuanti_diallelic_var_pleio * clone()
Definition: ttquanti.h:396
virtual ~TTQuanti_diallelic_var_pleio()
Definition: ttquanti.h:390
virtual double get_additive_genotype(const unsigned int trait) const
Definition: ttquanti.cc:4376
virtual void show_up()
Definition: ttquanti.cc:4498
unsigned int get_sequence_block_size(unsigned int from, unsigned int to)
Definition: ttquanti.cc:4415
virtual double get_dominant_genotype(const unsigned int trait) const
Definition: ttquanti.cc:4394
virtual void init_sequence()
Definition: ttquanti.cc:4454
TTQuanti_diallelic.
Definition: ttquanti.h:281
virtual void ** get_sequence() const
Definition: ttquanti.h:299
virtual void mutate_inplace(unsigned int position, unsigned int allele, double value)
Definition: ttquanti.h:317
virtual unsigned int get_allele(int loc, int all) const
Definition: ttquanti.cc:3989
TTQuanti_diallelic()
Definition: ttquanti.h:285
TTQuanti_diallelic(const TTQuanti &T)
Definition: ttquanti.h:287
virtual TTQuanti_diallelic & operator=(const TTrait &T)
Definition: ttquanti.cc:3922
virtual void init()
Definition: ttquanti.cc:3884
virtual bool operator==(const TTrait &T)
Definition: ttquanti.cc:3943
virtual void mutate_add(unsigned int position, unsigned int allele, double value)
Definition: ttquanti.h:315
virtual void reset()
Definition: ttquanti.cc:3904
unsigned char ** _sequence
Definition: ttquanti.h:322
virtual double get_full_genotype(unsigned int trait)
Definition: ttquanti.cc:4026
virtual ~TTQuanti_diallelic()
Definition: ttquanti.h:289
virtual void store_data(BinaryStorageBuffer *saver)
Definition: ttquanti.cc:4033
virtual bool retrieve_data(BinaryStorageBuffer *reader)
Definition: ttquanti.cc:4041
virtual void set_allele(int locus, int allele, double value)
Definition: ttquanti.h:314
virtual double get_allele_value(int locus, int allele) const
Definition: ttquanti.cc:3998
virtual void set_allele_value(unsigned int locus, unsigned int allele, double value)
Definition: ttquanti.cc:4009
virtual bool get_allele_bit(unsigned int position, unsigned int allele) const
Definition: ttquanti.cc:3970
virtual void set_allele_bit(unsigned int position, unsigned int allele, bool value)
Definition: ttquanti.cc:3979
virtual void set_sequence(void **seq)
Definition: ttquanti.cc:4051
void inherit_free(const TTrait *mother, const TTrait *father)
virtual bool operator!=(const TTrait &T)
Definition: ttquanti.cc:3960
TTQuanti.
Definition: ttquanti.h:61
virtual void mutate_add(unsigned int position, unsigned int allele, double value)=0
TProtoQuanti * _myProto
Definition: ttquanti.h:107
virtual void copy_sequence_1locus(sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)=0
virtual ~TTQuanti()
Definition: ttquanti.h:72
virtual void set_value()
Definition: ttquanti.cc:3125
virtual void set_allele_bit(unsigned int position, unsigned int allele, bool value)=0
TProtoQuanti * get_proto()
Definition: ttquanti.h:98
virtual bool get_allele_bit(unsigned int position, unsigned int allele) const =0
virtual double get_dominant_genotype(const unsigned int trait) const =0
void set_phenotype(unsigned int trait, double value)
Definition: ttquanti.cc:3154
virtual double get_additive_genotype(const unsigned int trait) const =0
TTQuanti()
Definition: ttquanti.h:64
virtual void * getValue() const
Definition: ttquanti.h:79
virtual void * set_trait(void *value)
Definition: ttquanti.h:77
TTQuanti(const TTQuanti &T)
Definition: ttquanti.h:69
void set_proto(TProtoQuanti *proto)
Definition: ttquanti.h:97
virtual void mutate_inplace(unsigned int position, unsigned int allele, double value)=0
virtual void inherit(const TTrait *mother, const TTrait *father)
Definition: ttquanti.cc:3116
double get_phenotype(unsigned int trai)
Definition: ttquanti.cc:3145
double * _phenotypes
Definition: ttquanti.h:105
virtual double get_full_genotype(unsigned int trait)=0
void reset_phenotype_to_genotypic_value()
Definition: ttquanti.cc:3137
virtual void mutate()
Definition: ttquanti.cc:3109
double * _genotypic_values
Definition: ttquanti.h:106
virtual void copy_sequence_block(sex_t SEX, unsigned int strand, unsigned int from_pos, unsigned int to_pos, const TTQuanti *parent)=0
virtual trait_t get_type() const
Definition: ttquanti.h:74
Interface for all trait types, declares all basic trait operations.
Definition: ttrait.h:46
Template class for the trait's FileHandler.
Definition: filehandler.h:221
Template class for the trait's StatHandler.
Definition: stathandler.h:168
Non-template and faster implementation of std::bitset.
Definition: bitstring.h:57
#define QUANT
Definition: types.h:72
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
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
age_idx
Array index of the age classes in the patch sizes and containers arrays.
Definition: types.h:41