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

TTQuanti_diallelic_bitstring. More...

#include <ttquanti_bitstring.h>

+ Inheritance diagram for TTQuanti_diallelic_bitstring:
+ Collaboration diagram for TTQuanti_diallelic_bitstring:

Public Member Functions

 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
 
virtual double get_additive_genotype (const unsigned int trait) const =0
 
virtual double get_dominant_genotype (const unsigned int trait) const =0
 
virtual void copy_sequence_block (sex_t SEX, unsigned int strand, unsigned int from_pos, unsigned int to_pos, const TTQuanti *parent)=0
 
virtual void copy_sequence_1locus (sex_t SEX, unsigned int strand, unsigned int at, const TTQuanti *parent)=0
 
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 void init_sequence ()=0
 Called at the start of each replicate, sets the initial genotypes. More...
 
virtual void show_up ()=0
 Writes some info to stdout. More...
 
virtual TTraitclone ()=0
 Returns a copy of itself. More...
 
virtual ~TTrait ()
 
- Public Member Functions inherited from StorableComponent
virtual ~StorableComponent ()
 

Protected Attributes

bitstring_sequence
 
- Protected Attributes inherited from TTQuanti
double * _phenotypes
 
TProtoQuanti_myProto
 

Detailed Description

Constructor & Destructor Documentation

◆ TTQuanti_diallelic_bitstring() [1/2]

TTQuanti_diallelic_bitstring::TTQuanti_diallelic_bitstring ( )
inline
45  : TTQuanti(), _sequence(0)
46  {
47 // message("CONSTRUCTOR::TTQuanti_continuous::CONSTRUCTOR\n");
48  }
bitstring * _sequence
Definition: ttquanti_bitstring.h:91
TTQuanti()
Definition: ttquanti.h:62

◆ TTQuanti_diallelic_bitstring() [2/2]

TTQuanti_diallelic_bitstring::TTQuanti_diallelic_bitstring ( const TTQuanti T)
inline
50 : TTQuanti(T), _sequence(0) {}

◆ ~TTQuanti_diallelic_bitstring()

virtual TTQuanti_diallelic_bitstring::~TTQuanti_diallelic_bitstring ( )
inlinevirtual
53 {reset();}
virtual void reset()
Definition: ttquanti_bitstring.cc:148

References reset().

Member Function Documentation

◆ get_allele_bit()

bool TTQuanti_diallelic_bitstring::get_allele_bit ( unsigned int  position,
unsigned int  allele 
) const
virtual

Implements TTQuanti.

88 {
89  assert(position < (int)_myProto->get_seq_length() && allele < 2);
90 
91  return _sequence[allele][position];
92 }
unsigned int get_seq_length()
Definition: ttquanti.h:421
TProtoQuanti * _myProto
Definition: ttquanti.h:103

References TTQuanti::_myProto, _sequence, and TProtoQuanti::get_seq_length().

◆ get_allele_value()

double TTQuanti_diallelic_bitstring::get_allele_value ( int  locus,
int  allele 
) const
inlinevirtual

Implements TTrait.

107 {
108  // beware that get_diallele_value() expects a locus ID, not a sequence position!!!
109 
110  assert(position < (int)_myProto->get_seq_length() && all < 2);
111 
112  return _myProto->get_seq_diallele_value( position, (unsigned int)_sequence[all][position] );
113 }
double get_seq_diallele_value(unsigned int position, unsigned int allele)
Definition: ttquanti.h:432

References TTQuanti::_myProto, _sequence, TProtoQuanti::get_seq_diallele_value(), and TProtoQuanti::get_seq_length().

◆ get_bit_sequence()

◆ get_full_genotype()

double TTQuanti_diallelic_bitstring::get_full_genotype ( unsigned int  trait)
virtual

Implements TTQuanti.

163 { //returns genotypic value that includes dominance effects if any
164  return _myProto->get_genotypic_value(this, trait);
165 }
double get_genotypic_value(const TTQuanti *ind, const unsigned int trait)
Definition: ttquanti.h:468

References TTQuanti::_myProto, and TProtoQuanti::get_genotypic_value().

◆ get_sequence()

virtual void** TTQuanti_diallelic_bitstring::get_sequence ( ) const
inlinevirtual

Implements TTrait.

66  {
67  error("calling TTQuanti_diallelic_bitstring::get_sequence()\n");
68  return (void**)NULL;
69  }
int error(const char *str,...)
Definition: output.cc:77

References error().

◆ inherit_free()

void TTQuanti_diallelic_bitstring::inherit_free ( const TTrait mother,
const TTrait father 
)

◆ init()

void TTQuanti_diallelic_bitstring::init ( )
inlinevirtual

Implements TTrait.

135 {
136  reset();
137 
138  _sequence = new bitstring [2];
141 
142  _phenotypes = new double [_myProto->get_num_traits()];
143 
144 }
unsigned int get_num_traits()
Definition: ttquanti.h:417
double * _phenotypes
Definition: ttquanti.h:102
Non-template and faster implementation of std::bitset.
Definition: bitstring.h:57
void reset(size_t length)
Definition: bitstring.h:140

References TTQuanti::_myProto, TTQuanti::_phenotypes, _sequence, TProtoQuanti::get_num_traits(), TProtoQuanti::get_seq_length(), reset(), and bitstring::reset().

Referenced by operator=(), and set_bit_sequence().

◆ mutate_add()

virtual void TTQuanti_diallelic_bitstring::mutate_add ( unsigned int  position,
unsigned int  allele,
double  value 
)
inlinevirtual

Implements TTQuanti.

85  {_sequence[allele].set(position, bool(value));}
void set(size_t n)
Set a bit to 1.
Definition: bitstring.h:256

References _sequence, and bitstring::set().

◆ mutate_inplace()

virtual void TTQuanti_diallelic_bitstring::mutate_inplace ( unsigned int  position,
unsigned int  allele,
double  value 
)
inlinevirtual

Implements TTQuanti.

87  {_sequence[allele].flip(position);}
void flip(size_t n)
Flip the bit at n.
Definition: bitstring.h:267

References _sequence, and bitstring::flip().

◆ operator!=()

bool TTQuanti_diallelic_bitstring::operator!= ( const TTrait T)
virtual

Implements TTrait.

78 {
79  if(!((*this) == T) )
80  return true;
81  else
82  return false;
83 }

◆ operator=()

TTQuanti_diallelic_bitstring & TTQuanti_diallelic_bitstring::operator= ( const TTrait T)
virtual

Implements TTrait.

40 {
41  const TTQuanti_diallelic_bitstring& TQ = dynamic_cast<const TTQuanti_diallelic_bitstring&>(T);
42 
43  assert(*this == TQ); // to make sure that the sequences are of same length
44 
45  if(this != &TQ) {
46 
47  init();
48 
49  _sequence[0].copy(TQ._sequence[0]);
50  _sequence[1].copy(TQ._sequence[1]);
51 
52  set_value();
53  }
54 
55  return *this;
56 }
TTQuanti_diallelic_bitstring.
Definition: ttquanti_bitstring.h:41
virtual void init()
Definition: ttquanti_bitstring.cc:134
virtual void set_value()
Definition: ttquanti.cc:3091
void copy(const bitstring &b)
Unchecked copy, assumes we have sames sizes.
Definition: bitstring.h:284

References _sequence, bitstring::copy(), init(), and TTQuanti::set_value().

◆ operator==()

bool TTQuanti_diallelic_bitstring::operator== ( const TTrait T)
virtual

Implements TTrait.

61  {
62  if(this->get_type().compare(T.get_type()) != 0) return false;
63 
64  const TTQuanti_diallelic_bitstring& TQ = dynamic_cast<const TTQuanti_diallelic_bitstring&>(T);
65 
66  if(this != &TQ) {
67  if(_myProto->get_num_locus() != TQ._myProto->get_num_locus()) return false;
68  if(_myProto->get_num_traits() != TQ._myProto->get_num_traits()) return false;
69  if(_myProto->get_seq_length() != TQ._myProto->get_seq_length()) return false;
70  if(_myProto->get_pleiotropy_type() != TQ._myProto->get_pleiotropy_type()) return false;
71  }
72  return true;
73  }
unsigned int get_num_locus()
Definition: ttquanti.h:418
unsigned int get_pleiotropy_type()
Definition: ttquanti.h:420
virtual trait_t get_type() const
Definition: ttquanti.h:72
virtual trait_t get_type() const =0
type accessor.

References TTQuanti::_myProto, TProtoQuanti::get_num_locus(), TProtoQuanti::get_num_traits(), TProtoQuanti::get_pleiotropy_type(), TProtoQuanti::get_seq_length(), TTQuanti::get_type(), and TTrait::get_type().

◆ reset()

void TTQuanti_diallelic_bitstring::reset ( )
inlinevirtual

Implements TTrait.

149 {
150  if(_sequence) {
151  delete [] _sequence;
152  _sequence = NULL;
153  }
154 
155  if(_phenotypes) delete [] _phenotypes;
156  _phenotypes = NULL;
157 
158 }

References TTQuanti::_phenotypes, and _sequence.

Referenced by init(), and ~TTQuanti_diallelic_bitstring().

◆ retrieve_data()

bool TTQuanti_diallelic_bitstring::retrieve_data ( BinaryStorageBuffer reader)
inlinevirtual

Implements StorableComponent.

184 {
185  size_t wnb = _sequence[0].nb_words();
186  size_t bytes = wnb * sizeof(bitstring::_ul);
187  bitstring::_ul *srce = new bitstring::_ul [wnb];
188 
189  reader->read(srce, bytes);
190  _sequence[0].set_data(srce,wnb);
191 
192  reader->read(srce, bytes);
193  _sequence[1].set_data(srce,wnb);
194 
195  delete [] srce;
196 
197  return true;
198 }
void read(void *out, unsigned int nb_bytes)
Definition: binarystoragebuffer.h:162
unsigned long _ul
Definition: bitstring.h:61
void set_data(_ul *srce, size_t nbwrd)
Copy bits from an array of unsigned long words.
Definition: bitstring.h:270
size_t nb_words() const
Definition: bitstring.h:160

References _sequence, bitstring::nb_words(), BinaryStorageBuffer::read(), and bitstring::set_data().

◆ set_allele_bit()

void TTQuanti_diallelic_bitstring::set_allele_bit ( unsigned int  position,
unsigned int  allele,
bool  value 
)
virtual

Implements TTQuanti.

97 {
98  assert(position < (int)_myProto->get_seq_length() && allele < 2);
99 
100  _sequence[allele].set(position, value); // avoiding reference
101 }

References TTQuanti::_myProto, _sequence, TProtoQuanti::get_seq_length(), and bitstring::set().

◆ set_allele_value()

void TTQuanti_diallelic_bitstring::set_allele_value ( unsigned int  locus,
unsigned int  allele,
double  value 
)
inlinevirtual

Implements TTrait.

118 {
119 // assert(position);
120  bool a = _sequence[allele][position];
121  double refval1 = _myProto->get_seq_diallele_value( position, a );
122  double refval2 = _myProto->get_seq_diallele_value( position, !a );
123 
124  if( refval1 != value && refval2 != value )
125  fatal("trait quant::trying to set allele %i at position %i to value %f, which is not as set in the input allele table (%f, %f)\n",
126  allele, position, value, refval1, refval2);
127 
128  if( refval1 != value )
129  _sequence[allele].flip(position);
130 }
void fatal(const char *str,...)
Definition: output.cc:96

References TTQuanti::_myProto, _sequence, fatal(), bitstring::flip(), and TProtoQuanti::get_seq_diallele_value().

◆ set_bit_sequence()

void TTQuanti_diallelic_bitstring::set_bit_sequence ( const bitstring inseq)
210 {
211  init();
212  _sequence[0].copy(inseq[0]);
213  _sequence[1].copy(inseq[1]);
214 }

References _sequence, bitstring::copy(), and init().

◆ set_sequence()

void TTQuanti_diallelic_bitstring::set_sequence ( void **  seq)
virtual

Implements TTrait.

203 {
204  error("Calling TTQuanti_diallelic_bitstring::set_sequence(), should be calling TTQuanti_diallelic_bitstring::set_bit_sequence()\n");
205 }

References error().

◆ store_data()

void TTQuanti_diallelic_bitstring::store_data ( BinaryStorageBuffer saver)
inlinevirtual

Implements StorableComponent.

170 {
171  size_t wnb = _sequence[0].nb_words();
172  size_t bytes = sizeof(bitstring::_ul);
173 
174  for(size_t i = 0; i < wnb; i++)
175  saver->store(_sequence[0].getword_atIdx(i), bytes);
176 
177  for(size_t i = 0; i < wnb; i++)
178  saver->store(_sequence[1].getword_atIdx(i), bytes);
179 }
void store(void *stream, unsigned int nb_bytes)
Definition: binarystoragebuffer.cc:16
_ul * getword_atIdx(size_t index) const
Definition: bitstring.h:155

References _sequence, bitstring::getword_atIdx(), bitstring::nb_words(), and BinaryStorageBuffer::store().

Member Data Documentation

◆ _sequence


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