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

TTQuanti_continuous_no_pleio : multiple non-pleiotropic traits. More...

#include <ttquanti.h>

+ Inheritance diagram for TTQuanti_continuous_no_pleio:
+ Collaboration diagram for TTQuanti_continuous_no_pleio:

Public Member Functions

 TTQuanti_continuous_no_pleio ()
 
 TTQuanti_continuous_no_pleio (const TTQuanti_continuous_no_pleio &TT)
 
virtual ~TTQuanti_continuous_no_pleio ()
 
virtual void init_sequence ()
 
virtual TTQuanti_continuous_no_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_no_pleio : multiple non-pleiotropic traits.

Constructor & Destructor Documentation

◆ TTQuanti_continuous_no_pleio() [1/2]

TTQuanti_continuous_no_pleio::TTQuanti_continuous_no_pleio ( )
inline
229 : TTQuanti_continuous() {}
TTQuanti_continuous()
Definition: ttquanti.h:117

Referenced by clone().

+ Here is the caller graph for this function:

◆ TTQuanti_continuous_no_pleio() [2/2]

TTQuanti_continuous_no_pleio::TTQuanti_continuous_no_pleio ( const TTQuanti_continuous_no_pleio TT)
inline
231 : TTQuanti_continuous(TT) {}

◆ ~TTQuanti_continuous_no_pleio()

virtual TTQuanti_continuous_no_pleio::~TTQuanti_continuous_no_pleio ( )
inlinevirtual
233 {}

Member Function Documentation

◆ clone()

virtual TTQuanti_continuous_no_pleio* TTQuanti_continuous_no_pleio::clone ( )
inlinevirtual

Implements TTrait.

237 {return new TTQuanti_continuous_no_pleio(*this);}
TTQuanti_continuous_no_pleio()
Definition: ttquanti.h:229

References TTQuanti_continuous_no_pleio().

◆ copy_sequence_1locus()

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

Implements TTQuanti.

3746 {
3747  const double *orig = (const double*)parent->get_sequence()[strand];
3748 
3749  _sequence[SEX][at] = orig[at];
3750 }
double ** _sequence
Definition: ttquanti.h:162
virtual void ** get_sequence() const =0
sequence accessor.

References TTQuanti_continuous::_sequence, and TTrait::get_sequence().

◆ copy_sequence_block()

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

Implements TTQuanti.

3730 {
3731  assert(to_locus >= from_locus);
3732 
3733  const double *orig = (const double*)parent->get_sequence()[strand];
3734  double *seq = _sequence[SEX];
3735 
3736  size_t block_size = (to_locus - from_locus) * _myProto->get_locus_byte_size();
3737 
3738  memcpy(&seq[from_locus], &orig[from_locus], block_size);
3739 
3740 }
size_t get_locus_byte_size()
Definition: ttquanti.h:428
TProtoQuanti * _myProto
Definition: ttquanti.h:106

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

◆ get_additive_genotype()

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

Implements TTQuanti.

3665 {
3666  double genotype = 0;
3667  unsigned int L = _myProto->get_num_locus(trait); //number of loci affecting this trait
3668  unsigned int pos = _myProto->get_locus_seq_pos(0, trait); //starting position, all loci contiguous on the map
3669 
3670  // to help with vectorization:
3671  const double* __restrict__ s0 = _sequence[0] + pos;
3672  const double* __restrict__ s1 = _sequence[1] + pos;
3673 
3674  for (unsigned int j = 0; j < L; ++j) genotype += s0[j] + s1[j];
3675 
3676 // for(unsigned int j = 0; j < L; ++j, ++pos) {
3677 // genotype += _sequence[0][pos] + _sequence[1][pos];
3678 // }
3679 
3680  return genotype;
3681 }
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_no_pleio::get_dominant_genotype ( const unsigned int  trait) const
inlinevirtual

Implements TTQuanti.

3686 {
3687  double genotype = 0, k, a1, a2;
3688  unsigned int L = _myProto->get_num_locus(trait); //number of loci affecting this trait
3689  unsigned int pos = _myProto->get_locus_seq_pos(0, trait); //starting position, all loci contiguous on the map
3690  unsigned int locID;
3691 
3692  const double* __restrict__ s0 = _sequence[0] + pos;
3693  const double* __restrict__ s1 = _sequence[1] + pos;
3694  const TMatrix& __restrict__ dom_coef = _myProto->get_dominance_effects();
3695 
3696 // if(_myProto->has_equal_domCoeff()){
3697 // k = dom_coef.get(trait, _myProto->get_locus_ID(0, trait));
3698 // for (unsigned int j = 0; j < L; ++j) {
3699 // double a1 = s0[j], a2 = s1[j];
3700 // genotype += a1 + a2 + k * fabs(a2 - a1);
3701 // }
3702 // return genotype;
3703 // }
3704 //
3705  // double a1 = s0[j], a2 = s1[j];
3706  for (unsigned int j = 0; j < L; ++j) {
3707  locID = _myProto->get_locus_ID(j, trait);
3708 // genotype += _myProto->get_genotype_dominance_k(s0[j], s1[j],
3709 // _myProto->get_dominance(locID, trait));
3710  a1 = s0[j]; a2 = s1[j];
3711  k = dom_coef.get(trait, locID);
3712  genotype += a1 + a2 + k * fabs(a2 - a1);
3713  }
3714 
3715 // for(unsigned int j = 0; j < L; ++j, ++pos) {
3716 // locID = _myProto->get_locus_ID(j, trait);
3717 // genotype += _myProto->get_genotype_dominance_k(_sequence[0][pos], _sequence[1][pos],
3718 // _myProto->get_dominance(locID, trait));
3721 // }
3722 
3723  return genotype;
3724 }
A class to handle matrix in params, coerces matrix into a vector of same total size.
Definition: tmatrix.h:49
unsigned int get_locus_ID(unsigned int locus, unsigned int trait)
Definition: ttquanti.h:454
const TMatrix & get_dominance_effects()
Definition: ttquanti.h:480

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

◆ init_sequence()

void TTQuanti_continuous_no_pleio::init_sequence ( )
inlinevirtual

Implements TTrait.

3755 {
3756  // cout << "\nStart of TTQuanti_var_pleio::init_sequence!\t\n";
3757 
3758  //options:
3759  //0: no variation, init value = (trait value)/(2*_num_locus)
3760  //1: init value = (trait value)/(2*_num_locus) + 1 mutation/locus
3761  //2: init value = (trait value)/(2*_num_locus) + random deviate ~N(0, _init_variance/2*_num_locus)
3762 
3763  //Note: the initial values may have been set individually by LCE_quanti
3764  // it wouldn't make sense then to store the init values in the prototype
3765  // because init values are set patch-specific by LCE_quanti
3766  // Problem: without LCE_quanti, the original init values must not change from one replicate
3767  // to the other, so we use a local variable
3768 
3769 
3770  //set the allele values from the trait values
3771  double myinit, initSD;
3772  for(unsigned int i = 0; i < _myProto->get_num_traits(); ++i){ // process trait-wise
3773 
3774  myinit = _myProto->get_init_value(i) / (2 * _myProto->get_num_locus(i)); //divide by num loci affecting that trait
3775  initSD = sqrt(_myProto->get_init_variance(i)/(2*_myProto->get_num_locus(i)));
3776 
3777  for(unsigned int j = 0, pos = _myProto->get_locus_seq_pos(0, i); j < _myProto->get_num_locus(i); ++j, ++pos){
3778  _sequence[0][ pos ] = myinit;
3779  _sequence[1][ pos ] = myinit;
3780  }
3781 
3782  if(_myProto->get_doInitMutation() == 2) {
3783  // add a random deviate from a Normal distribution
3784  for(unsigned int j = 0, pos = _myProto->get_locus_seq_pos(0, i); j < _myProto->get_num_locus(i); ++j, ++pos){
3785  _sequence[0][ pos ] += RAND::Gaussian(initSD);
3786  _sequence[1][ pos ] += RAND::Gaussian(initSD);
3787  }
3788  }
3789 
3790  }
3791 
3792  //add random mutations to allele values
3793  if(_myProto->get_doInitMutation() == 1) {
3794 
3795  for(unsigned int i = 0; i < _myProto->get_num_locus(); i++) {
3796 
3798 
3799  }
3800  }
3801 
3802 
3803 
3804 }
static double Gaussian(double sigma)
Definition: Uniform.h:261
static bool RandBool()
Returns a random boolean.
Definition: Uniform.h:164
double * getMutationEffects(unsigned int loc)
Definition: ttquanti.h:532
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

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

◆ show_up()

void TTQuanti_continuous_no_pleio::show_up ( )
virtual

Implements TTrait.

3809 {
3810  message("\
3811  Trait's type: QUANTI (continuous, no pleiotropy)\n\
3812  traits: %i\n\
3813  loci: %i\n\
3814  seq length: %i\n",_myProto->get_num_traits(),_myProto->get_num_locus()
3815  ,_myProto->get_seq_length());
3816 
3817  for(unsigned int i = 0; i < _myProto->get_num_traits(); i++)
3818  message("phenotype %i: %f\n",i+1,_phenotypes[i]);
3819 
3820  message("genotype:");
3821 
3822  for(unsigned int i = 0; i < _myProto->get_num_traits(); ++i) {
3823 
3824  message("\ntrait %i (%i loci):\nloci: ",i+1, _myProto->get_num_locus(i));
3825 
3826  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
3827  message("%i, ", _myProto->get_locus_ID(j, i));
3828  }
3829 
3830  message("\n[0]: ");
3831 
3832  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
3833  message("%.3f,",_sequence[0][ _myProto->get_locus_seq_pos(j, i) ]);
3834  }
3835 
3836  message("\n[1]: ");
3837 
3838  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
3839  message("%.3f,",_sequence[1][ _myProto->get_locus_seq_pos(j, i) ]);
3840  }
3841  }
3842 
3843  message("\n");
3844 
3845 }
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