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

TTQuanti_continuous_full_pleio : universal pleiotropy. More...

#include <ttquanti.h>

+ Inheritance diagram for TTQuanti_continuous_full_pleio:
+ Collaboration diagram for TTQuanti_continuous_full_pleio:

Public Member Functions

 TTQuanti_continuous_full_pleio ()
 
 TTQuanti_continuous_full_pleio (const TTQuanti_continuous_full_pleio &TT)
 
virtual ~TTQuanti_continuous_full_pleio ()
 
virtual void init_sequence ()
 
virtual TTQuanti_continuous_full_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_full_pleio : universal pleiotropy.

Constructor & Destructor Documentation

◆ TTQuanti_continuous_full_pleio() [1/2]

TTQuanti_continuous_full_pleio::TTQuanti_continuous_full_pleio ( )
inline
173 : TTQuanti_continuous() {}
TTQuanti_continuous()
Definition: ttquanti.h:117

Referenced by clone().

+ Here is the caller graph for this function:

◆ TTQuanti_continuous_full_pleio() [2/2]

TTQuanti_continuous_full_pleio::TTQuanti_continuous_full_pleio ( const TTQuanti_continuous_full_pleio TT)
inline
175 : TTQuanti_continuous(TT) {}

◆ ~TTQuanti_continuous_full_pleio()

virtual TTQuanti_continuous_full_pleio::~TTQuanti_continuous_full_pleio ( )
inlinevirtual
177 {}

Member Function Documentation

◆ clone()

virtual TTQuanti_continuous_full_pleio* TTQuanti_continuous_full_pleio::clone ( )
inlinevirtual

Implements TTrait.

181 {return new TTQuanti_continuous_full_pleio(*this);}
TTQuanti_continuous_full_pleio()
Definition: ttquanti.h:173

References TTQuanti_continuous_full_pleio().

◆ copy_sequence_1locus()

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

Implements TTQuanti.

3364 {
3365  const double *orig = (const double*)parent->get_sequence()[strand];
3366  double *seq = _sequence[SEX];
3367  unsigned int from_pos = at * _myProto->get_num_traits();
3368 
3369  memcpy(&seq[from_pos], &orig[from_pos], _myProto->get_locus_byte_size());
3370 }
size_t get_locus_byte_size()
Definition: ttquanti.h:428
unsigned int get_num_traits()
Definition: ttquanti.h:422
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_byte_size(), TProtoQuanti::get_num_traits(), and TTrait::get_sequence().

◆ copy_sequence_block()

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

Implements TTQuanti.

3347 {
3348  const double *orig = (const double*)parent->get_sequence()[strand];
3349  double *seq = _sequence[SEX];
3350  unsigned int from_pos = from_locus * _myProto->get_num_traits();
3351 
3352  assert(to_locus >= from_locus);
3353 
3354  size_t block_size = (to_locus - from_locus) * _myProto->get_locus_byte_size();
3355 
3356  memcpy(&seq[from_pos], &orig[from_pos], block_size);
3357 
3358 }

References TTQuanti::_myProto, TTQuanti_continuous::_sequence, TProtoQuanti::get_locus_byte_size(), TProtoQuanti::get_num_traits(), and TTrait::get_sequence().

◆ get_additive_genotype()

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

Implements TTQuanti.

3314 {
3315  unsigned int loc = trait; // initial position in the sequence, in the first locus
3316  double genotype = 0;
3317 
3318 
3319  for(unsigned int j = 0; j < _myProto->get_num_locus(); ++j) {
3320  // alleles are ordered locus-trait: seq[0]:l0t0,l0t1,l0t2, ..., l1t0,l1t1,l1t2, ...
3321  genotype += _sequence[0][loc] + _sequence[1][loc];
3322  loc += _myProto->get_num_traits(); // stride size on the genome, between loci
3323  }
3324 
3325  return genotype;
3326 }
unsigned int get_num_locus()
Definition: ttquanti.h:423

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

◆ get_dominant_genotype()

double TTQuanti_continuous_full_pleio::get_dominant_genotype ( const unsigned int  trait) const
virtual

Implements TTQuanti.

3331 {
3332  unsigned int loc = trait;
3333  double genotype = 0;
3334 
3335  for(unsigned int j = 0; j < _myProto->get_num_locus(); ++j) {
3336  genotype += _myProto->get_genotype_with_dominance( _sequence[0][loc] , _sequence[1][loc], j, trait);
3337  loc += _myProto->get_num_traits(); // stride size on the genome, between loci
3338  }
3339 
3340  return genotype;
3341 }
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_num_locus(), and TProtoQuanti::get_num_traits().

◆ init_sequence()

void TTQuanti_continuous_full_pleio::init_sequence ( )
inlinevirtual

Implements TTrait.

3375 {
3376 // cout<<" TTQuanti_continuous_full_pleio::init_sequence\n";
3377 
3378  //options:
3379  //0: no variation, init value = (trait value)/(2*_num_locus)
3380  //1: init value = (trait value)/(2*_num_locus) + 1 mutation/locus
3381  //2: init value = (trait value)/(2*_num_locus) + random deviate ~N(0, _init_variance/2*_num_locus)
3382 
3383  //Note: the initial values may have been set individually by LCE_quanti
3384  // it wouldn't make sense then to store the init values in the prototype
3385  // because init values are set patch-specific by LCE_quanti
3386  // Problem: without LCE_quanti, the original init values must not change from one replicate
3387  // to the other, so we use a local variable
3388 
3389  double my_init[_myProto->get_num_traits()];
3390 
3391  for(unsigned int j = 0; j < _myProto->get_num_traits(); j++)
3392  my_init[j] = _myProto->get_init_value(j) / (2*_myProto->get_num_locus());
3393 
3394  unsigned int pos = 0;
3395 
3396  for(unsigned int j = 0; j < _myProto->get_num_traits(); ++j) {
3397  pos = j;
3398  //set the allele values from the init value, mutations may be added later
3399  for(unsigned int i = 0; i < _myProto->get_num_locus(); ++i) {
3400  _sequence[0][pos] = my_init[j];
3401  _sequence[1][pos] = my_init[j];
3402  pos += _myProto->get_num_traits();
3403  }
3404  }
3405 
3406  //add random effects to allele values if needed
3407  if(_myProto->get_doInitMutation() == 1) {
3408 
3409  double *mut;
3410 
3411  for(unsigned int i = 0; i < _myProto->get_num_locus(); i++) {
3412 
3413  pos = i * _myProto->get_num_traits();
3414 
3415  // change only one of the two allele at the locus, randomly
3416  mut = (_myProto->*_myProto->_getMutationValues)(i);
3417 
3418  for(unsigned int j = 0; j < _myProto->get_num_traits(); j++) {
3419  _sequence[RAND::RandBool()][pos] += mut[j];
3420  pos++;
3421  }
3422  } // end for_num_locus
3423  } // end if_doInit == 1
3424 
3425  // random deviate to initial additive effect
3426  if(_myProto->get_doInitMutation() == 2) {
3427 
3428  double initSD[_myProto->get_num_traits()];
3429 
3430  for(unsigned int j = 0; j < _myProto->get_num_traits(); j++) {
3431  initSD[j] = sqrt(_myProto->get_init_variance(j) / (2*_myProto->get_num_locus()) );
3432  }
3433 
3434  for(unsigned int i = 0; i < _myProto->get_num_locus(); i++) {
3435 
3436  pos = i * _myProto->get_num_traits();
3437 
3438  for(unsigned int j = 0; j < _myProto->get_num_traits(); j++) {
3439  _sequence[0][pos] += RAND::Gaussian(initSD[j]);
3440  _sequence[1][pos] += RAND::Gaussian(initSD[j]);
3441  pos++;
3442  }
3443  } // end for_num_locus
3444  } // end if_doInit == 2
3445 
3446 // cout<<" TTQuanti_continuous_full_pleio::init_sequence::end\n";
3447 }
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
double *(TProtoQuanti::* _getMutationValues)(unsigned int)
Pointer to mutation allele value function, which depends on allele model and number of traits affecte...
Definition: ttquanti.h:694
unsigned int get_doInitMutation()
Definition: ttquanti.h:448

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

◆ show_up()

void TTQuanti_continuous_full_pleio::show_up ( )
virtual

Implements TTrait.

3452 {
3453  message("\
3454  Trait's type: QUANTI (continuous, full pleiotropy)\n\
3455  traits: %i\n\
3456  loci: %i\n\
3457  seq length: %i\n",_myProto->get_num_traits(),_myProto->get_num_locus()
3458  ,_myProto->get_seq_length());
3459 
3460  for(unsigned int i = 0; i < _myProto->get_num_traits(); i++)
3461  message("phenotype %i: %f\n",i+1,_phenotypes[i]);
3462 
3463  message("_sequence: \n0:");
3464  unsigned int loc;
3465  for(unsigned int i = 0; i < _myProto->get_num_traits(); ++i) {
3466  message("\nt%i:",i+1);
3467  for(unsigned int j = 0; (j < _myProto->get_num_locus()); ++j) {
3468  loc = j * _myProto->get_num_traits() + i;
3469  message("%.3f,",_sequence[0][loc]);
3470  }
3471  }
3472  message("\n1:");
3473  for(unsigned int i = 0; i < _myProto->get_num_traits(); ++i) {
3474  message("\nt%i:",i+1);
3475  for(unsigned int j = 0; (j < _myProto->get_num_locus()); ++j) {
3476  loc = j * _myProto->get_num_traits() + i;
3477  message("%.3f,",_sequence[1][loc]);
3478  }
3479  }
3480  message("\n");
3481 
3482 }
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_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