Nemo  2.4.0
Simulate forward-in-time genetic evolution in a spatially explicit, individual-based stochastic simulator
TTQuanti_continuous_var_pleio Class Reference

TTQuanti_continuous_var_pleio : variable pleiotropy. More...

#include <ttquanti.h>

+ Inheritance diagram for TTQuanti_continuous_var_pleio:
+ Collaboration diagram for TTQuanti_continuous_var_pleio:

Public Member Functions

 TTQuanti_continuous_var_pleio ()
 
 TTQuanti_continuous_var_pleio (const TTQuanti_continuous_var_pleio &TT)
 
virtual ~TTQuanti_continuous_var_pleio ()
 
unsigned int get_sequence_block_size (unsigned int from, unsigned int to)
 
virtual void init_sequence ()
 
virtual TTQuanti_continuous_var_pleioclone ()
 
virtual void show_up ()
 
virtual double get_additive_genotype (const unsigned int trait) const
 
virtual double get_dominant_genotype (const unsigned int trait) const
 
virtual void copy_sequence_block (sex_t SEX, unsigned int strand, unsigned int from_locus, unsigned int to_locus, const TTQuanti *parent)
 
virtual void copy_sequence_1locus (sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)
 
- Public Member Functions inherited from TTQuanti_continuous
 TTQuanti_continuous ()
 
 TTQuanti_continuous (const TTQuanti &T)
 
virtual ~TTQuanti_continuous ()
 
virtual void reset ()
 
virtual void init ()
 
virtual void set_sequence (void **seq)
 
virtual void ** get_sequence () const
 
virtual unsigned int get_allele (int loc, int all) const
 
virtual double get_allele_value (int loc, int all) const
 
virtual void set_allele_value (unsigned int locus, unsigned int allele, double value)
 
virtual TTQuanti_continuousoperator= (const TTrait &T)
 
virtual bool operator== (const TTrait &T)
 
virtual bool operator!= (const TTrait &T)
 
virtual void store_data (BinaryStorageBuffer *saver)
 
virtual bool retrieve_data (BinaryStorageBuffer *reader)
 
virtual double get_full_genotype (unsigned int trait)
 
virtual void set_allele (int locus, int allele, double value)
 
virtual void mutate_add (unsigned int position, unsigned int allele, double value)
 
virtual void mutate_inplace (unsigned int position, unsigned int allele, double value)
 
virtual bool get_allele_bit (unsigned int position, unsigned int allele) const
 
virtual void set_allele_bit (unsigned int position, unsigned int allele, bool value)
 
- Public Member Functions inherited from TTQuanti
 TTQuanti ()
 
 TTQuanti (const TTQuanti &T)
 
virtual ~TTQuanti ()
 
virtual trait_t get_type () const
 
virtual void mutate ()
 
virtual void inherit (const TTrait *mother, const TTrait *father)
 
virtual void * set_trait (void *value)
 
virtual void set_value ()
 
virtual void * getValue () const
 
void set_proto (TProtoQuanti *proto)
 
TProtoQuantiget_proto ()
 
double get_phenotype (unsigned int trai)
 
void set_phenotype (unsigned int trait, double value)
 
void reset_phenotype_to_genotypic_value ()
 
- Public Member Functions inherited from TTrait
virtual ~TTrait ()
 
- Public Member Functions inherited from StorableComponent
virtual ~StorableComponent ()
 

Additional Inherited Members

- Protected Attributes inherited from TTQuanti_continuous
double ** _sequence
 
- Protected Attributes inherited from TTQuanti
double * _phenotypes
 
double * _genotypic_values
 
TProtoQuanti_myProto
 

Detailed Description

TTQuanti_continuous_var_pleio : variable pleiotropy.

Constructor & Destructor Documentation

◆ TTQuanti_continuous_var_pleio() [1/2]

TTQuanti_continuous_var_pleio::TTQuanti_continuous_var_pleio ( )
inline
200 : TTQuanti_continuous() {}
TTQuanti_continuous()
Definition: ttquanti.h:117

Referenced by clone().

+ Here is the caller graph for this function:

◆ TTQuanti_continuous_var_pleio() [2/2]

TTQuanti_continuous_var_pleio::TTQuanti_continuous_var_pleio ( const TTQuanti_continuous_var_pleio TT)
inline
202 : TTQuanti_continuous(TT) {}

◆ ~TTQuanti_continuous_var_pleio()

virtual TTQuanti_continuous_var_pleio::~TTQuanti_continuous_var_pleio ( )
inlinevirtual
204 {}

Member Function Documentation

◆ clone()

virtual TTQuanti_continuous_var_pleio* TTQuanti_continuous_var_pleio::clone ( )
inlinevirtual

Implements TTrait.

210 {return new TTQuanti_continuous_var_pleio(*this);}
TTQuanti_continuous_var_pleio()
Definition: ttquanti.h:200

References TTQuanti_continuous_var_pleio().

◆ copy_sequence_1locus()

void TTQuanti_continuous_var_pleio::copy_sequence_1locus ( sex_t  SEX,
unsigned int  strand,
unsigned int  at,
const TTQuanti parent 
)
inlinevirtual

Implements TTQuanti.

3549 {
3550  const double *orig = (const double*)parent->get_sequence()[strand];
3551  double *seq = _sequence[SEX];
3552  unsigned int from_pos = _myProto->get_locus_start_pos(at);
3553  size_t size = _myProto->get_locus_PD(at) * _myProto->get_size_locus_type();
3554 
3555  memcpy(&seq[from_pos], &orig[from_pos], size);
3556 }
unsigned int get_locus_PD(unsigned int locus)
Definition: ttquanti.h:456
size_t get_size_locus_type()
Definition: ttquanti.h:427
unsigned int get_locus_start_pos(unsigned int locus)
Definition: ttquanti.h:457
double ** _sequence
Definition: ttquanti.h:162
TProtoQuanti * _myProto
Definition: ttquanti.h:106
virtual void ** get_sequence() const =0
sequence accessor.

References TTQuanti::_myProto, TTQuanti_continuous::_sequence, TProtoQuanti::get_locus_PD(), TProtoQuanti::get_locus_start_pos(), TTrait::get_sequence(), and TProtoQuanti::get_size_locus_type().

◆ copy_sequence_block()

void TTQuanti_continuous_var_pleio::copy_sequence_block ( sex_t  SEX,
unsigned int  strand,
unsigned int  from_locus,
unsigned int  to_locus,
const TTQuanti parent 
)
inlinevirtual

Implements TTQuanti.

3534 {
3535  const double *orig = (const double*)parent->get_sequence()[strand];
3536  double *seq = _sequence[SEX];
3537  unsigned int from_pos = _myProto->get_locus_start_pos(from_locus);
3538 
3539  size_t block_size = _myProto->get_sequence_block_size(from_locus, to_locus) * _myProto->get_size_locus_type();
3540 
3541  memcpy(&seq[from_pos], &orig[from_pos], block_size);
3542 
3543 }
unsigned int get_sequence_block_size(unsigned int from, unsigned int to)
Definition: ttquanti.h:458

References TTQuanti::_myProto, TTQuanti_continuous::_sequence, TProtoQuanti::get_locus_start_pos(), TTrait::get_sequence(), TProtoQuanti::get_sequence_block_size(), and TProtoQuanti::get_size_locus_type().

◆ get_additive_genotype()

double TTQuanti_continuous_var_pleio::get_additive_genotype ( const unsigned int  trait) const
inlinevirtual

Implements TTQuanti.

3491 {
3492  double genotype = 0;
3493  unsigned int L = _myProto->get_num_locus(trait), pos;
3494 
3495  for(unsigned int j = 0; j < L; ++j) { // each trait can be affected by a different number of loci
3496  // alleles are ordered locus-trait: seq[0]:l0t0,l0t1,l0t2, ..., l1t0,l1t1,l1t2, ...
3497  pos = _myProto->get_locus_seq_pos(j, trait);
3498  genotype += _sequence[0][pos] + _sequence[1][pos];
3499  }
3500 
3501  return genotype;
3502 }
unsigned int get_locus_seq_pos(unsigned int loc, unsigned int trait)
Definition: ttquanti.h:452
unsigned int get_num_locus()
Definition: ttquanti.h:423

References TTQuanti::_myProto, TTQuanti_continuous::_sequence, TProtoQuanti::get_locus_seq_pos(), and TProtoQuanti::get_num_locus().

◆ get_dominant_genotype()

double TTQuanti_continuous_var_pleio::get_dominant_genotype ( const unsigned int  trait) const
inlinevirtual

Implements TTQuanti.

3508 {
3509  double genotype = 0;
3510  unsigned int L = _myProto->get_num_locus(trait), pos, locID;
3511 
3512  for(unsigned int j = 0; j < L; ++j) {
3513  pos = _myProto->get_locus_seq_pos(j, trait);
3514  locID = _myProto->get_locus_ID(j, trait);
3515  genotype += _myProto->get_genotype_with_dominance(_sequence[0][pos] ,
3516  _sequence[1][pos], locID, trait);
3517  }
3518 
3519  return genotype;
3520 }
unsigned int get_locus_ID(unsigned int locus, unsigned int trait)
Definition: ttquanti.h:454
double get_genotype_with_dominance(const double a1, const double a2, const unsigned int locus, const unsigned int trait)
Definition: ttquanti.cc:2538

References TTQuanti::_myProto, TTQuanti_continuous::_sequence, TProtoQuanti::get_genotype_with_dominance(), TProtoQuanti::get_locus_ID(), TProtoQuanti::get_locus_seq_pos(), and TProtoQuanti::get_num_locus().

◆ get_sequence_block_size()

unsigned int TTQuanti_continuous_var_pleio::get_sequence_block_size ( unsigned int  from,
unsigned int  to 
)
inline

◆ init_sequence()

void TTQuanti_continuous_var_pleio::init_sequence ( )
inlinevirtual

Implements TTrait.

3561 {
3562 // cout << "TTQuanti_var_pleio::init_sequence\n";
3563 
3564  //options:
3565  //0: no variation, init value = (trait value)/(2*_num_locus)
3566  //1: init value = (trait value)/(2*_num_locus) + 1 mutation/locus
3567  //2: init value = (trait value)/(2*_num_locus) + random deviate ~N(0, _init_variance/2*_num_locus)
3568 
3569  //Note: the initial values may have been set individually by LCE_quanti
3570  // it wouldn't make sense then to store the init values in the prototype
3571  // because init values are set patch-specific by LCE_quanti
3572  // Problem: without LCE_quanti, the original init values must not change from one replicate
3573  // to the other, so we use a local variable
3574 
3575 
3576  //set the allele values from the trait value and the pleiotropic degree of each locus
3577  double myinit, initSD;
3578 
3579  for(unsigned int t = 0; t < _myProto->get_num_traits(); ++t){ // process trait-wise
3580 
3581  myinit = _myProto->get_init_value(t) / (2*_myProto->get_num_locus(t)); //divide by num loci affecting that trait
3582 
3583  initSD = sqrt(_myProto->get_init_variance(t)/(2*_myProto->get_num_locus(t)));
3584 
3585  for(unsigned int i = 0; i < _myProto->get_num_locus(t); ++i){
3586  _sequence[0][ _myProto->get_locus_seq_pos(i, t) ] = myinit;
3587  _sequence[1][ _myProto->get_locus_seq_pos(i, t) ] = myinit;
3588  }
3589  //add a random deviate to initial additive effect
3590  if(_myProto->get_doInitMutation() == 2) {
3591  for(unsigned int i = 0; i < _myProto->get_num_locus(t); i++) {
3592  _sequence[0][ _myProto->get_locus_seq_pos(i, t) ] += RAND::Gaussian(initSD);
3593  _sequence[1][ _myProto->get_locus_seq_pos(i, t) ] += RAND::Gaussian(initSD);
3594  } // end for_num_locus
3595  } // end if_doInit == 2
3596 
3597  }
3598  //add random effects to allele values
3599  if(_myProto->get_doInitMutation() == 1) {
3600 
3601  double *mut;
3602 
3603  for(unsigned int i = 0; i < _myProto->get_num_locus(); i++) {
3604 
3605  mut = _myProto->getMutationEffectsVarPleio(i); // returns as many values as the locus' PD
3606 
3607  for(unsigned int j = 0; j < _myProto->get_locus_PD(i); j++){
3608  //mutate only one of the alleles, randomly
3609  _sequence[RAND::RandBool()][ _myProto->get_locus_start_pos(i) + j ] += mut[j];
3610  }
3611  }
3612  } // end init model 1
3613 
3614 }
static double Gaussian(double sigma)
Definition: Uniform.h:261
static bool RandBool()
Returns a random boolean.
Definition: Uniform.h:164
double get_init_value(unsigned int i)
Definition: ttquanti.h:446
double get_init_variance(unsigned int i)
Definition: ttquanti.h:447
unsigned int get_num_traits()
Definition: ttquanti.h:422
unsigned int get_doInitMutation()
Definition: ttquanti.h:448
double * getMutationEffectsVarPleio(unsigned int loc)
Definition: ttquanti.h:535

References TTQuanti::_myProto, TTQuanti_continuous::_sequence, RAND::Gaussian(), TProtoQuanti::get_doInitMutation(), TProtoQuanti::get_init_value(), TProtoQuanti::get_init_variance(), TProtoQuanti::get_locus_PD(), TProtoQuanti::get_locus_seq_pos(), TProtoQuanti::get_locus_start_pos(), TProtoQuanti::get_num_locus(), TProtoQuanti::get_num_traits(), TProtoQuanti::getMutationEffectsVarPleio(), and RAND::RandBool().

◆ show_up()

void TTQuanti_continuous_var_pleio::show_up ( )
virtual

Implements TTrait.

3620 {
3621  message("\
3622  Trait's type: QUANTI (continuous, variable pleiotropy)\n\
3623  traits: %i\n\
3624  loci: %i\n\
3625  seq length: %i\n",_myProto->get_num_traits(),_myProto->get_num_locus()
3626  ,_myProto->get_seq_length());
3627 
3628  for(unsigned int i = 0; i < _myProto->get_num_traits(); i++)
3629  message("phenotype %i: %f\n",i+1,_phenotypes[i]);
3630 
3631  message("genotype:");
3632 
3633  for(unsigned int i = 0; i < _myProto->get_num_traits(); ++i) {
3634 
3635  message("\ntrait %i (%i loci):\nloci: ",i+1, _myProto->get_num_locus(i));
3636 
3637  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
3638  message("%i, ", _myProto->get_locus_ID(j, i));
3639  }
3640 
3641  message("\n[0]: ");
3642 
3643  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
3644  message("%.3f,",_sequence[0][ _myProto->get_locus_seq_pos(j, i) ]);
3645  }
3646 
3647  message("\n[1]: ");
3648 
3649  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
3650  message("%.3f,",_sequence[1][ _myProto->get_locus_seq_pos(j, i) ]);
3651  }
3652  }
3653 
3654  message("\n");
3655 
3656 }
unsigned int get_seq_length()
Definition: ttquanti.h:426
double * _phenotypes
Definition: ttquanti.h:104
void message(const char *message,...)
Definition: output.cc:39

References TTQuanti::_myProto, TTQuanti::_phenotypes, TTQuanti_continuous::_sequence, TProtoQuanti::get_locus_ID(), TProtoQuanti::get_locus_seq_pos(), TProtoQuanti::get_num_locus(), TProtoQuanti::get_num_traits(), TProtoQuanti::get_seq_length(), and message().


The documentation for this class was generated from the following files:

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

Locations of visitors to this page
Catalogued on GSR