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

TTQuanti_diallelic_bitstring_no_pleio_epistasis : non-pleiotropic di-allelic bitstring with epistasis. More...

#include <ttquanti_epistasis.h>

+ Inheritance diagram for TTQuanti_diallelic_bitstring_no_pleio_epistasis:
+ Collaboration diagram for TTQuanti_diallelic_bitstring_no_pleio_epistasis:

Public Member Functions

 TTQuanti_diallelic_bitstring_no_pleio_epistasis ()
 
 TTQuanti_diallelic_bitstring_no_pleio_epistasis (const TTQuanti_diallelic_bitstring_no_pleio_epistasis &TT)
 
virtual ~TTQuanti_diallelic_bitstring_no_pleio_epistasis ()
 
virtual void init_sequence ()
 
virtual TTQuanti_diallelic_bitstring_no_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_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 unsigned int get_allele (int loc, int all) 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)
 
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_diallelic_bitstring
bitstring_sequence
 
- Protected Attributes inherited from TTQuanti
double * _phenotypes
 
double * _genotypic_values
 
TProtoQuanti_myProto
 

Detailed Description

TTQuanti_diallelic_bitstring_no_pleio_epistasis : non-pleiotropic di-allelic bitstring with epistasis.

Constructor & Destructor Documentation

◆ TTQuanti_diallelic_bitstring_no_pleio_epistasis() [1/2]

TTQuanti_diallelic_bitstring_no_pleio_epistasis::TTQuanti_diallelic_bitstring_no_pleio_epistasis ( )
inline
TTQuanti_diallelic_bitstring()
Definition: ttquanti_bitstring.h:44

Referenced by clone().

+ Here is the caller graph for this function:

◆ TTQuanti_diallelic_bitstring_no_pleio_epistasis() [2/2]

TTQuanti_diallelic_bitstring_no_pleio_epistasis::TTQuanti_diallelic_bitstring_no_pleio_epistasis ( const TTQuanti_diallelic_bitstring_no_pleio_epistasis TT)
inline
163  :

◆ ~TTQuanti_diallelic_bitstring_no_pleio_epistasis()

virtual TTQuanti_diallelic_bitstring_no_pleio_epistasis::~TTQuanti_diallelic_bitstring_no_pleio_epistasis ( )
inlinevirtual
166 {}

Member Function Documentation

◆ clone()

virtual TTQuanti_diallelic_bitstring_no_pleio_epistasis* TTQuanti_diallelic_bitstring_no_pleio_epistasis::clone ( )
inlinevirtual

Implements TTrait.

TTQuanti_diallelic_bitstring_no_pleio_epistasis()
Definition: ttquanti_epistasis.h:161

References TTQuanti_diallelic_bitstring_no_pleio_epistasis().

◆ copy_sequence_1locus()

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

Implements TTQuanti.

879 {
880  const bitstring& orig = dynamic_cast<const TTQuanti_diallelic_bitstring*>(parent)->get_bit_sequence((bool)chromosome);
881 
882  _sequence[SEX][at] = orig[at];
883 }
TTQuanti_diallelic_bitstring.
Definition: ttquanti_bitstring.h:40
const bitstring & get_bit_sequence(bool chromosome) const
Definition: ttquanti_bitstring.h:55
bitstring * _sequence
Definition: ttquanti_bitstring.h:88
Non-template and faster implementation of std::bitset.
Definition: bitstring.h:56

References TTQuanti_diallelic_bitstring::_sequence, and TTQuanti_diallelic_bitstring::get_bit_sequence().

◆ copy_sequence_block()

void TTQuanti_diallelic_bitstring_no_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.

866 {
867  assert(to_locus > from_locus);
868 
869  const bitstring& orig = dynamic_cast<const TTQuanti_diallelic_bitstring*>(parent)->get_bit_sequence((bool)chromosome);
870 
871  _sequence[SEX].copy(orig, from_locus, to_locus);
872 
873 }
void copy(const bitstring &b)
Unchecked copy, assumes we have sames sizes.
Definition: bitstring.h:360

References TTQuanti_diallelic_bitstring::_sequence, bitstring::copy(), and TTQuanti_diallelic_bitstring::get_bit_sequence().

◆ get_additive_genotype()

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

Implements TTQuanti.

801 {
802  double genotype = 0;
803  unsigned int L = _myProto->get_num_locus(trait); //number of loci affecting this trait
804  unsigned int pos = _myProto->get_locus_seq_pos(0, trait); //starting position, all loci contiguous on the map
805  vector<double> genotypes(L,0);
806 
807  for(unsigned int j = 0; j < L; ++j, ++pos) {
808  genotypes[j] = _myProto->get_seq_diallele_value( pos, _sequence[0][pos] )
809  + _myProto->get_seq_diallele_value( pos, _sequence[1][pos] );
810  genotype += genotypes[j];
811  }
812 
813  return genotype + get_epistatic_genotype(genotypes);
814 }
double get_seq_diallele_value(unsigned int position, unsigned int allele)
Definition: ttquanti.h:437
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
double get_epistatic_genotype(const vector< double > &genotypes) const
Definition: ttquanti_epistasis.cc:841
TProtoQuanti * _myProto
Definition: ttquanti.h:106

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

◆ get_dominant_genotype()

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

Implements TTQuanti.

819 {
820  double genotype = 0;
821  unsigned int L = _myProto->get_num_locus(trait); //number of loci affecting this trait
822  unsigned int pos = _myProto->get_locus_seq_pos(0, trait); //starting position, all loci contiguous on the map
823  unsigned int locID;
824  vector<double> genotypes(L,0);
825 
826  for(unsigned int j = 0; j < L; ++j, ++pos) {
827  locID = _myProto->get_locus_ID(j, trait);
828  genotypes[j] = _myProto->get_genotype_with_dominance(
829  _myProto->get_seq_diallele_value( pos, _sequence[0][pos] ) ,
830  _myProto->get_seq_diallele_value( pos, _sequence[1][pos] ),
831  locID,
832  trait);
833  genotype += genotypes[j];
834  }
835 
836  return genotype + get_epistatic_genotype(genotypes);
837 }
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_diallelic_bitstring::_sequence, get_epistatic_genotype(), TProtoQuanti::get_genotype_with_dominance(), TProtoQuanti::get_locus_ID(), TProtoQuanti::get_locus_seq_pos(), TProtoQuanti::get_num_locus(), and TProtoQuanti::get_seq_diallele_value().

◆ get_epistatic_genotype()

double TTQuanti_diallelic_bitstring_no_pleio_epistasis::get_epistatic_genotype ( const vector< double > &  genotypes) const
inline
842 {
843  double genotype = 0;
844 
845  const TMatrix& epi_loc_idx = _myProto->get_epi_coef_index();
846  const TMatrix& epi_coef = _myProto->get_epi_coefs();
847  unsigned int pos0, pos1;
848 
849  // now add the epistatic effects
850  for(unsigned int i = 0; i < epi_coef.length(); ++i) {
851 
852  // Note _epistatic_coefs_indices has dimensions [_nb_epi_coefs; 2]
853  pos0 = epi_loc_idx.get(i,0);
854  pos1 = epi_loc_idx.get(i,1);
855 
856  genotype += epi_coef.get(0,i) * double(genotypes[pos0]) * double(genotypes[pos1]);
857  }
858 
859  return genotype;
860 }
A class to handle matrix in params, coerces matrix into a vector of same total size.
Definition: tmatrix.h:49
double get(unsigned int i, unsigned int j) const
Accessor to element at row i and column j.
Definition: tmatrix.h:192
unsigned int length() const
Returns the number of elements in the matrix.
Definition: tmatrix.h:217
const TMatrix & get_epi_coefs() const
Definition: ttquanti.h:567
const TMatrix & get_epi_coef_index() const
Definition: ttquanti.h:568

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().

+ Here is the caller graph for this function:

◆ init_sequence()

void TTQuanti_diallelic_bitstring_no_pleio_epistasis::init_sequence ( )
inlinevirtual

Implements TTrait.

888 {
889  //options:
890  //0: no variation, all alleles set to 0
891  //1: max variation, randomly set alleles at each locus
892  //2: no variation and initialize with opposite effect alleles at alternating loci.
893 
894  // initialize with 0 bit
895  _sequence[0].reset();
896  _sequence[1].reset();
897 
898  if (_myProto->get_doInitMutation() == 1) {
899 
900  for(unsigned int i = 0; i < _myProto->get_num_locus(); ++i) {
901 
902  // randomly set the allelic values
903  _sequence[0][ i ] = RAND::RandBool();
904  _sequence[1][ i ] = RAND::RandBool();
905 
906  }
907 
908  } else if (_myProto->get_doInitMutation() == 2) {
909  //option 2; polarized di-allelic values; even locus set to +a, odd locus set to -a
910 
911  for(unsigned int i = 0; i < _myProto->get_num_locus(); i++) { // process trait-wise
912  // no need to set alleles to 0 since it was initialized that way
913 
914  if(i%2) { // odd locus
915  _sequence[1][ i ].flip(); //set with the alternate/negative allele value
916  _sequence[0][ i ].flip();
917  }
918  }
919  }
920 
921 }
static bool RandBool()
Returns a random boolean.
Definition: Uniform.h:164
unsigned int get_doInitMutation()
Definition: ttquanti.h:448
void flip(size_t n)
Flip the bit at n.
Definition: bitstring.h:346
void reset(size_t length)
Definition: bitstring.h:139

References TTQuanti::_myProto, TTQuanti_diallelic_bitstring::_sequence, bitstring::flip(), TProtoQuanti::get_doInitMutation(), TProtoQuanti::get_num_locus(), RAND::RandBool(), and bitstring::reset().

◆ show_up()

void TTQuanti_diallelic_bitstring_no_pleio_epistasis::show_up ( )
virtual

Implements TTrait.

926 {
927  message("\
928  Trait's type: QUANTI (diallelic bitstring, no pleiotropy with epistasis)\n\
929  traits: %i\n\
930  loci: %i\n\
931  seq length: %i\n",_myProto->get_num_traits(),_myProto->get_num_locus()
933 
934  for(unsigned int i = 0; i < _myProto->get_num_traits(); i++)
935  message("phenotype %i: %f\n",i+1,_phenotypes[i]);
936 
937  message("genotype:");
938 
939  for(unsigned int i = 0; i < _myProto->get_num_traits(); ++i) {
940 
941  message("\ntrait %i (%i loci):\nloci: ",i+1, _myProto->get_num_locus(i));
942 
943  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
944  message("%i, ", _myProto->get_locus_ID(j, i));
945  }
946 
947  message("\n[0]: ");
948 
949  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
950  message("%.3f,", (double)_sequence[0][ _myProto->get_locus_seq_pos(j, i) ]);
951  }
952 
953  message("\n[1]: ");
954 
955  for(unsigned int j = 0; j < _myProto->get_num_locus(i); ++j) {
956  message("%.3f,", (double)_sequence[1][ _myProto->get_locus_seq_pos(j, i) ]);
957  }
958  }
959 
960  message("\n");
961 
962 }
unsigned int get_seq_length()
Definition: ttquanti.h:426
unsigned int get_num_traits()
Definition: ttquanti.h:422
double * _phenotypes
Definition: ttquanti.h:104
void message(const char *message,...)
Definition: output.cc:39

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