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

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

#include <ttquanti_bitstring.h>

+ Inheritance diagram for TTQuanti_diallelic_bitstring_full_pleio:
+ Collaboration diagram for TTQuanti_diallelic_bitstring_full_pleio:

Public Member Functions

 TTQuanti_diallelic_bitstring_full_pleio ()
 
 TTQuanti_diallelic_bitstring_full_pleio (const TTQuanti_diallelic_bitstring_full_pleio &TT)
 
virtual ~TTQuanti_diallelic_bitstring_full_pleio ()
 
virtual void init_sequence ()
 
virtual TTQuanti_diallelic_bitstring_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 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)
 
- Public Member Functions inherited from TTQuanti_diallelic_bitstring
 TTQuanti_diallelic_bitstring ()
 
 TTQuanti_diallelic_bitstring (const TTQuanti &T)
 
virtual ~TTQuanti_diallelic_bitstring ()
 
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 set_bit_sequence (const bitstring *inseq)
 
const bitstringget_bit_sequence (bool chromosome) const
 
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_diallelic_bitstringoperator= (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 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_bitstring
bitstring_sequence
 
- Protected Attributes inherited from TTQuanti
double * _phenotypes
 
TProtoQuanti_myProto
 

Detailed Description

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

Constructor & Destructor Documentation

◆ TTQuanti_diallelic_bitstring_full_pleio() [1/2]

TTQuanti_diallelic_bitstring_full_pleio::TTQuanti_diallelic_bitstring_full_pleio ( )
inline
TTQuanti_diallelic_bitstring()
Definition: ttquanti_bitstring.h:45

Referenced by clone().

◆ TTQuanti_diallelic_bitstring_full_pleio() [2/2]

TTQuanti_diallelic_bitstring_full_pleio::TTQuanti_diallelic_bitstring_full_pleio ( const TTQuanti_diallelic_bitstring_full_pleio TT)
inline

◆ ~TTQuanti_diallelic_bitstring_full_pleio()

virtual TTQuanti_diallelic_bitstring_full_pleio::~TTQuanti_diallelic_bitstring_full_pleio ( )
inlinevirtual
135 {}

Member Function Documentation

◆ clone()

virtual TTQuanti_diallelic_bitstring_full_pleio* TTQuanti_diallelic_bitstring_full_pleio::clone ( )
inlinevirtual

Implements TTrait.

139 {return new TTQuanti_diallelic_bitstring_full_pleio(*this);}
TTQuanti_diallelic_bitstring_full_pleio()
Definition: ttquanti_bitstring.h:131

References TTQuanti_diallelic_bitstring_full_pleio().

◆ copy_sequence_1locus()

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

Implements TTQuanti.

417 {
418  const bitstring& orig = dynamic_cast<const TTQuanti_diallelic_bitstring*>(parent)->get_bit_sequence((bool)chromosome);
419 
420  size_t pos = _myProto->get_locus_start_pos(at);
421 
422  for(unsigned int i = 0; i < _myProto->get_num_traits(); ++i) {
423  _sequence[SEX][pos] = orig[pos];
424  pos++;
425  }
426 
427 // _sequence[SEX].copy(orig, start_pos, start_pos + _myProto->get_num_traits());
428 }
unsigned int get_num_traits()
Definition: ttquanti.h:417
unsigned int get_locus_start_pos(unsigned int locus)
Definition: ttquanti.h:445
TTQuanti_diallelic_bitstring.
Definition: ttquanti_bitstring.h:41
const bitstring & get_bit_sequence(bool chromosome) const
Definition: ttquanti_bitstring.h:58
bitstring * _sequence
Definition: ttquanti_bitstring.h:91
TProtoQuanti * _myProto
Definition: ttquanti.h:103
Non-template and faster implementation of std::bitset.
Definition: bitstring.h:57

References TTQuanti::_myProto, TTQuanti_diallelic_bitstring::_sequence, TTQuanti_diallelic_bitstring::get_bit_sequence(), TProtoQuanti::get_locus_start_pos(), and TProtoQuanti::get_num_traits().

◆ copy_sequence_block()

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

Implements TTQuanti.

400 {
401  assert(to_locus > from_locus);
402 
403  const bitstring& orig = dynamic_cast<const TTQuanti_diallelic_bitstring*>(parent)->get_bit_sequence((bool)chromosome);
404 
405  size_t block_size = (to_locus - from_locus)*_myProto->get_num_traits();
406 
407  size_t start_pos = _myProto->get_locus_start_pos(from_locus);
408 
409  _sequence[SEX].copy(orig, start_pos, start_pos + block_size);
410 
411 }
void copy(const bitstring &b)
Unchecked copy, assumes we have sames sizes.
Definition: bitstring.h:284

References TTQuanti::_myProto, TTQuanti_diallelic_bitstring::_sequence, bitstring::copy(), TTQuanti_diallelic_bitstring::get_bit_sequence(), TProtoQuanti::get_locus_start_pos(), and TProtoQuanti::get_num_traits().

◆ get_additive_genotype()

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

Implements TTQuanti.

360 {
361  double genotype = 0;
362  unsigned int L = _myProto->get_num_locus(); //number of loci
363  unsigned int pos = _myProto->get_locus_seq_pos(0, trait); //starting position, all loci contiguous on the map
364 
365  for(unsigned int j = 0; j < L; ++j) {
366  genotype += _myProto->get_seq_diallele_value( pos, _sequence[0][pos] );
367  genotype += _myProto->get_seq_diallele_value( pos, _sequence[1][pos] );
368  pos += _myProto->get_num_traits(); // stride size on the genome (all loci affect each trait)
369  }
370 
371  return genotype;
372 }
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

References TTQuanti::_myProto, TTQuanti_diallelic_bitstring::_sequence, 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_bitstring_full_pleio::get_dominant_genotype ( const unsigned int  trait) const
inlinevirtual

Implements TTQuanti.

378 {
379  double genotype = 0;
380  unsigned int L = _myProto->get_num_locus(); //number of loci
381  unsigned int pos = _myProto->get_locus_seq_pos(0, trait); //starting position,
382 
383 
384  for(unsigned int j = 0; j < L; ++j) {
386  _myProto->get_seq_diallele_value( pos, _sequence[0][pos] ),
387  _myProto->get_seq_diallele_value( pos, _sequence[1][pos] ),
388  j,
389  trait);
390  pos += _myProto->get_num_traits(); // stride size on the genome (all loci affect each trait)
391  }
392 
393  return genotype;
394 }
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_bitstring::_sequence, TProtoQuanti::get_genotype_with_dominance(), TProtoQuanti::get_locus_seq_pos(), TProtoQuanti::get_num_locus(), TProtoQuanti::get_num_traits(), and TProtoQuanti::get_seq_diallele_value().

◆ init_sequence()

void TTQuanti_diallelic_bitstring_full_pleio::init_sequence ( )
inlinevirtual

Implements TTrait.

433 {
434  //options:
435  //0: no variation, all alleles set to 0
436  //1: max variation, randomly set alleles at each locus
437  //2: no variation and initialize with opposite effect alleles at alternating loci.
438 
439 
440  if (_myProto->get_doInitMutation() == 1) {
441 
442  for(unsigned int i = 0; i < _myProto->get_seq_length(); ++i) {
443 
444  // randomly set the allelic values
445  _sequence[0][ i ] = RAND::RandBool();
446  _sequence[1][ i ] = RAND::RandBool();
447 
448  }
449 
450  } else if (_myProto->get_doInitMutation() == 2) {
451  //option 2; polarized di-allelic values; even locus set to +a, odd locus set to -a
452 
453  for(unsigned int t = 0; t < _myProto->get_num_traits(); ++t) {
454  for(unsigned int i = 0; i < _myProto->get_num_locus(t); i++) { // process trait-wise
455  // no need to set to 0 since it was initialized that way
456  if(i%2) { // odd locus
457  _sequence[1][ _myProto->get_locus_seq_pos(i, t) ].flip(); // = _myProto->get_allele_value(i, 1); //set with the alternate/negative allele value
458  _sequence[0][ _myProto->get_locus_seq_pos(i, t) ].flip(); // = _myProto->get_allele_value(i, 1);
459  }
460  }
461 
462  }
463  }
464 }
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
void flip(size_t n)
Flip the bit at n.
Definition: bitstring.h:267

References TTQuanti::_myProto, TTQuanti_diallelic_bitstring::_sequence, bitstring::flip(), 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_bitstring_full_pleio::show_up ( )
virtual

Implements TTrait.

469 {
470  message("\
471  Trait's type: QUANTI (diallelic, full pleiotropy)\n\
472  traits: %i\n\
473  loci: %i\n\
474  seq length: %i\n",_myProto->get_num_traits(),_myProto->get_num_locus()
476 
477  for(unsigned int i = 0; i < _myProto->get_num_traits(); i++)
478  message("phenotype %i: %f\n",i+1,_phenotypes[i]);
479 
480  message("_sequence:");
481 
482  for(unsigned int i = 0; i < _myProto->get_num_traits(); ++i) {
483 
484  message("\nt%i (%i loci):\n[0]: ",i+1, _myProto->get_num_locus(i));
485 
486  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
487  message("%.3f,", (double)_sequence[0][ _myProto->get_locus_seq_pos(j, i) ]);
488  }
489 
490  message("\n[1]: ");
491 
492  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
493  message("%.3f,", (double)_sequence[1][ _myProto->get_locus_seq_pos(j, i) ]);
494  }
495  }
496 
497  message("\n");
498 
499 }
double * _phenotypes
Definition: ttquanti.h:102
void message(const char *message,...)
Definition: output.cc:40

References TTQuanti::_myProto, TTQuanti::_phenotypes, TTQuanti_diallelic_bitstring::_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