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

TTQuanti_diallelic_full_pleio : pleiotropic di-allelic loci, max PD = 2. More...

#include <ttquanti_epistasis.h>

+ Inheritance diagram for TTQuanti_diallelic_full_pleio_epistasis:
+ Collaboration diagram for TTQuanti_diallelic_full_pleio_epistasis:

Public Member Functions

 TTQuanti_diallelic_full_pleio_epistasis ()
 
 TTQuanti_diallelic_full_pleio_epistasis (const TTQuanti_diallelic_full_pleio_epistasis &TT)
 
virtual ~TTQuanti_diallelic_full_pleio_epistasis ()
 
virtual void init_sequence ()
 
virtual TTQuanti_diallelic_full_pleio_epistasisclone ()
 
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 chromosome, unsigned int from_locus, unsigned int to_locus, const TTQuanti *parent)
 
virtual void copy_sequence_1locus (sex_t SEX, unsigned int chromosome, unsigned int at, const TTQuanti *parent)
 
double get_epistatic_genotype (const vector< double > &genotypes) const
 
- Public Member Functions inherited from TTQuanti_diallelic
 TTQuanti_diallelic ()
 
 TTQuanti_diallelic (const TTQuanti &T)
 
virtual ~TTQuanti_diallelic ()
 
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)
 
void inherit_free (const TTrait *mother, const TTrait *father)
 
virtual void reset ()
 
virtual void init ()
 
virtual void set_sequence (void **seq)
 
virtual void ** get_sequence () const
 
virtual double get_allele_value (int locus, int allele) const
 
virtual void set_allele_value (unsigned int locus, unsigned int allele, double value)
 
virtual TTQuanti_diallelicoperator= (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)
 
- 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)
 
- Public Member Functions inherited from TTrait
virtual ~TTrait ()
 
- Public Member Functions inherited from StorableComponent
virtual ~StorableComponent ()
 

Additional Inherited Members

- Protected Attributes inherited from TTQuanti_diallelic
unsigned char ** _sequence
 
- Protected Attributes inherited from TTQuanti
double * _phenotypes
 
TProtoQuanti_myProto
 

Detailed Description

TTQuanti_diallelic_full_pleio : pleiotropic di-allelic loci, max PD = 2.

Constructor & Destructor Documentation

◆ TTQuanti_diallelic_full_pleio_epistasis() [1/2]

TTQuanti_diallelic_full_pleio_epistasis::TTQuanti_diallelic_full_pleio_epistasis ( )
inline
73 : TTQuanti_diallelic() {}
TTQuanti_diallelic()
Definition: ttquanti.h:280

Referenced by clone().

◆ TTQuanti_diallelic_full_pleio_epistasis() [2/2]

TTQuanti_diallelic_full_pleio_epistasis::TTQuanti_diallelic_full_pleio_epistasis ( const TTQuanti_diallelic_full_pleio_epistasis TT)
inline
75  :
76  TTQuanti_diallelic(TT) {}

◆ ~TTQuanti_diallelic_full_pleio_epistasis()

virtual TTQuanti_diallelic_full_pleio_epistasis::~TTQuanti_diallelic_full_pleio_epistasis ( )
inlinevirtual
78 {}

Member Function Documentation

◆ clone()

virtual TTQuanti_diallelic_full_pleio_epistasis* TTQuanti_diallelic_full_pleio_epistasis::clone ( )
inlinevirtual

Implements TTrait.

82 {return new TTQuanti_diallelic_full_pleio_epistasis(*this);}
TTQuanti_diallelic_full_pleio_epistasis()
Definition: ttquanti_epistasis.h:73

References TTQuanti_diallelic_full_pleio_epistasis().

◆ copy_sequence_1locus()

void TTQuanti_diallelic_full_pleio_epistasis::copy_sequence_1locus ( sex_t  SEX,
unsigned int  chromosome,
unsigned int  at,
const TTQuanti parent 
)
inlinevirtual

Implements TTQuanti.

341 {
342  const unsigned char *orig = (const unsigned char*)parent->get_sequence()[chromosome];
343  unsigned char *seq = _sequence[SEX];
344  unsigned int from_pos = at * _myProto->get_num_traits();
345 
346  memcpy(&seq[from_pos], &orig[from_pos], _myProto->get_locus_byte_size());
347 }
size_t get_locus_byte_size()
Definition: ttquanti.h:423
unsigned int get_num_traits()
Definition: ttquanti.h:417
unsigned char ** _sequence
Definition: ttquanti.h:316
TProtoQuanti * _myProto
Definition: ttquanti.h:103
virtual void ** get_sequence() const =0
sequence accessor.

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

◆ copy_sequence_block()

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

Implements TTQuanti.

325 {
326  assert(to_locus >= from_locus);
327 
328  const unsigned char* orig = (const unsigned char*)parent->get_sequence()[chromosome];
329  unsigned char* seq = _sequence[SEX];
330  unsigned int from_pos = from_locus * _myProto->get_num_traits();
331 
332  size_t block_size = (to_locus - from_locus) * _myProto->get_locus_byte_size();
333 
334  memcpy(&seq[from_pos], &orig[from_pos], block_size);
335 }

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

◆ get_additive_genotype()

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

Implements TTQuanti.

254 {
255  double genotype = 0;
256  unsigned int L = _myProto->get_num_locus(); //number of loci
257  unsigned int pos = _myProto->get_locus_seq_pos(0, trait); //starting position, all loci contiguous on the map
258  vector<double> genotypes(L,0);
259 
260  for(unsigned int j = 0; j < L; ++j) {
261  genotypes[j] = _myProto->get_seq_diallele_value( pos, _sequence[0][pos] ) + _myProto->get_seq_diallele_value( pos, _sequence[1][pos] );
262  pos += _myProto->get_num_traits(); // stride size on the genome (all loci affect each trait)
263  genotype += genotypes[j];
264  }
265 
266  return genotype + get_epistatic_genotype(genotypes);
267 }
double get_seq_diallele_value(unsigned int position, unsigned int allele)
Definition: ttquanti.h:432
unsigned int get_locus_seq_pos(unsigned int loc, unsigned int trait)
Definition: ttquanti.h:440
unsigned int get_num_locus()
Definition: ttquanti.h:418
double get_epistatic_genotype(const vector< double > &genotypes) const
Definition: ttquanti_epistasis.cc:295

References TTQuanti::_myProto, TTQuanti_diallelic::_sequence, get_epistatic_genotype(), TProtoQuanti::get_locus_seq_pos(), TProtoQuanti::get_num_locus(), TProtoQuanti::get_num_traits(), and TProtoQuanti::get_seq_diallele_value().

◆ get_dominant_genotype()

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

Implements TTQuanti.

273 {
274  double genotype = 0;
275  unsigned int L = _myProto->get_num_locus(); //number of loci
276  unsigned int pos = _myProto->get_locus_seq_pos(0, trait); //starting position
277  vector<double> genotypes(L,0);
278 
279 
280  for(unsigned int j = 0; j < L; ++j) {
281  genotypes[j] = _myProto->get_genotype_with_dominance(
282  _myProto->get_seq_diallele_value( pos, _sequence[0][pos] ),
283  _myProto->get_seq_diallele_value( pos, _sequence[1][pos] ),
284  j,
285  trait);
286  pos += _myProto->get_num_traits(); // stride size on the genome (all loci affect each trait)
287  genotype += genotypes[j];
288  }
289 
290  return genotype + get_epistatic_genotype(genotypes);
291 }
double get_genotype_with_dominance(const double a1, const double a2, const unsigned int locus, const unsigned int trait)
Definition: ttquanti.cc:2504

References TTQuanti::_myProto, TTQuanti_diallelic::_sequence, get_epistatic_genotype(), TProtoQuanti::get_genotype_with_dominance(), TProtoQuanti::get_locus_seq_pos(), TProtoQuanti::get_num_locus(), TProtoQuanti::get_num_traits(), and TProtoQuanti::get_seq_diallele_value().

◆ get_epistatic_genotype()

double TTQuanti_diallelic_full_pleio_epistasis::get_epistatic_genotype ( const vector< double > &  genotypes) const
inline
296 {
297  double genotype = 0;
298 
299  const TMatrix& epi_loc_idx = _myProto->get_epi_coef_index();
300  const TMatrix& epi_coef = _myProto->get_epi_coefs();
301  unsigned int pos0, pos1;
302 
303  // now add the epistatic effects
304  for(unsigned int i = 0; i < epi_coef.length() ; ++i) {
305 
306  // Note _epistatic_coefs_indices has dimensions [_nb_epi_coefs; 2]
307  pos0 = epi_loc_idx.get(i,0);
308  pos1 = epi_loc_idx.get(i,1);
309 
310 // genotype += epi_coef.get(0,i)
311 // * (_sequence[0][pos0] + _sequence[1][pos0])
312 // * (_sequence[0][pos1] + _sequence[1][pos1]);
313 
314  genotype += epi_coef.get(0,i) * double(genotypes[pos0]) * double(genotypes[pos1]);
315 
316  }
317 
318  return genotype;
319 }
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
unsigned int length() const
Returns the number of elements in the matrix.
Definition: tmatrix.h:218
const TMatrix & get_epi_coefs() const
Definition: ttquanti.h:548
const TMatrix & get_epi_coef_index() const
Definition: ttquanti.h:549

References TTQuanti::_myProto, TMatrix::get(), TProtoQuanti::get_epi_coef_index(), TProtoQuanti::get_epi_coefs(), and TMatrix::length().

Referenced by get_additive_genotype(), and get_dominant_genotype().

◆ init_sequence()

void TTQuanti_diallelic_full_pleio_epistasis::init_sequence ( )
inlinevirtual

Implements TTrait.

352 {
353  //options:
354  //0: no variation, init value = one of each allele, mean value is average genotype
355  //1: max variation, randomly set alleles at each locus
356  //2: no variation and initialize with opposite effect alleles at alternating loci.
357 
358 
359  if (_myProto->get_doInitMutation() == 0){
360 
361  memset(_sequence[0], 0, _myProto->get_seq_length());
362  memset(_sequence[1], 0, _myProto->get_seq_length());
363 
364  } else if (_myProto->get_doInitMutation() == 1) {
365 
366  for(unsigned int i = 0; i < _myProto->get_seq_length(); ++i) {
367 
368  // randomly set the allelic values
369  _sequence[0][ i ] = RAND::RandBool();
370  _sequence[1][ i ] = RAND::RandBool();
371 
372  }
373 
374  } else {
375  //option 2; polarized di-allelic values; even locus set to +a, odd locus set to -a
376 
377  for(unsigned int t = 0; t < _myProto->get_num_traits(); ++t) {
378  for(unsigned int i = 0; i < _myProto->get_num_locus(t); i++) { // process trait-wise
379  // even locus
380  if (i % 2 == 0){
381  _sequence[0][ _myProto->get_locus_seq_pos(i, t) ] = 0; //_myProto->get_allele_value(i, 0); //set with the positive allele value
382  _sequence[1][ _myProto->get_locus_seq_pos(i, t) ] = 0; //_myProto->get_allele_value(i, 0);
383  }
384  else { // odd locus
385  _sequence[1][ _myProto->get_locus_seq_pos(i, t) ] = 1; // = _myProto->get_allele_value(i, 1); //set with the alternate/negative allele value
386  _sequence[0][ _myProto->get_locus_seq_pos(i, t) ] = 1; // = _myProto->get_allele_value(i, 1);
387  }
388  }
389 
390  }
391  }
392 }
static bool RandBool()
Returns a random boolean.
Definition: Uniform.h:162
unsigned int get_seq_length()
Definition: ttquanti.h:421
unsigned int get_doInitMutation()
Definition: ttquanti.h:436

References TTQuanti::_myProto, TTQuanti_diallelic::_sequence, TProtoQuanti::get_doInitMutation(), TProtoQuanti::get_locus_seq_pos(), TProtoQuanti::get_num_locus(), TProtoQuanti::get_num_traits(), TProtoQuanti::get_seq_length(), and RAND::RandBool().

◆ show_up()

void TTQuanti_diallelic_full_pleio_epistasis::show_up ( )
virtual

Implements TTrait.

397 {
398  message("\
399  Trait's type: QUANTI (diallelic, full pleiotropy with epistasis)\n\
400  traits: %i\n\
401  loci: %i\n\
402  seq length: %i\n",_myProto->get_num_traits(),_myProto->get_num_locus()
404 
405  for(unsigned int i = 0; i < _myProto->get_num_traits(); i++)
406  message("phenotype %i: %f\n",i+1,_phenotypes[i]);
407 
408  message("_sequence:");
409 
410  for(unsigned int i = 0; i < _myProto->get_num_traits(); ++i) {
411 
412  message("\nt%i (%i loci):\n[0]: ",i+1, _myProto->get_num_locus(i));
413 
414  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
415  message("%.3f,",(double)_sequence[0][ _myProto->get_locus_seq_pos(j, i) ]);
416  }
417 
418  message("\n[1]: ");
419 
420  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
421  message("%.3f,",(double)_sequence[1][ _myProto->get_locus_seq_pos(j, i) ]);
422  }
423  }
424 
425  message("\n");
426 
427 }
double * _phenotypes
Definition: ttquanti.h:102
void message(const char *message,...)
Definition: output.cc:40

References TTQuanti::_myProto, TTQuanti::_phenotypes, TTQuanti_diallelic::_sequence, 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.0b by  doxygen 1.9.1 -- Nemo is hosted on  Download Nemo

Locations of visitors to this page
Catalogued on GSR