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

Trait used to study the dynamics of spread of Wolbachia, an endosymbiotic parasite causing cytoplasmic incompatibility. More...

#include <ttwolbachia.h>

+ Inheritance diagram for TTWolbachia:
+ Collaboration diagram for TTWolbachia:

Public Member Functions

 TTWolbachia ()
 
 TTWolbachia (const TTWolbachia &T)
 
virtual ~TTWolbachia ()
 
void set_transmit_rate (double val)
 
virtual void init ()
 
virtual void init_sequence ()
 
virtual void reset ()
 
virtual void inherit (const TTrait *mother, const TTrait *father)
 
virtual void mutate ()
 
virtual void * set_trait (void *value)
 
virtual void set_sequence (void **seq)
 
virtual void set_value ()
 
virtual void * getValue () const
 
virtual trait_t get_type () const
 
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 void show_up ()
 
virtual TTWolbachiaclone ()
 
virtual TTWolbachiaoperator= (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)
 
- Public Member Functions inherited from TTrait
virtual ~TTrait ()
 
- Public Member Functions inherited from StorableComponent
virtual ~StorableComponent ()
 

Private Attributes

double _transmit_rate
 
bool _is_infected
 

Detailed Description

Trait used to study the dynamics of spread of Wolbachia, an endosymbiotic parasite causing cytoplasmic incompatibility.

The trait state is given by a unique haploid "gene" with two alleles, 0 = uninfected and 1 = infected.

Constructor & Destructor Documentation

◆ TTWolbachia() [1/2]

TTWolbachia::TTWolbachia ( )
inline
61  : _transmit_rate(0), _is_infected(0) { }
bool _is_infected
Definition: ttwolbachia.h:56
double _transmit_rate
Definition: ttwolbachia.h:55

Referenced by clone().

+ Here is the caller graph for this function:

◆ TTWolbachia() [2/2]

TTWolbachia::TTWolbachia ( const TTWolbachia T)
inline

◆ ~TTWolbachia()

virtual TTWolbachia::~TTWolbachia ( )
inlinevirtual
67 {}

Member Function Documentation

◆ clone()

virtual TTWolbachia* TTWolbachia::clone ( )
inlinevirtual

Implements TTrait.

89 {return new TTWolbachia(*this);}
TTWolbachia()
Definition: ttwolbachia.h:60

References TTWolbachia().

◆ get_allele()

virtual unsigned int TTWolbachia::get_allele ( int  loc,
int  all 
) const
inlinevirtual

Implements TTrait.

85 {return _is_infected;}

References _is_infected.

◆ get_allele_value()

virtual double TTWolbachia::get_allele_value ( int  loc,
int  all 
) const
inlinevirtual

Implements TTrait.

86 {return _is_infected;}

References _is_infected.

◆ get_sequence()

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

Implements TTrait.

84 {return NULL;}

◆ get_type()

virtual trait_t TTWolbachia::get_type ( ) const
inlinevirtual

Implements TTrait.

83 {return WOLB;}
#define WOLB
Definition: types.h:72

References WOLB.

Referenced by operator==().

+ Here is the caller graph for this function:

◆ getValue()

virtual void* TTWolbachia::getValue ( ) const
inlinevirtual

Implements TTrait.

82 {return (void*)&_is_infected;}

References _is_infected.

◆ inherit()

virtual void TTWolbachia::inherit ( const TTrait mother,
const TTrait father 
)
inlinevirtual

Implements TTrait.

75  { _is_infected = *(bool*)mother->getValue(); }
virtual void * getValue() const =0
Genotype to phenotype mapper.

References _is_infected, and TTrait::getValue().

◆ init()

virtual void TTWolbachia::init ( )
inlinevirtual

Implements TTrait.

71 {_is_infected = 0;}

References _is_infected.

◆ init_sequence()

virtual void TTWolbachia::init_sequence ( )
inlinevirtual

Implements TTrait.

72 {_is_infected = 0;}

References _is_infected.

◆ mutate()

virtual void TTWolbachia::mutate ( )
inlinevirtual

Implements TTrait.

static double Uniform()
Generates a random number from [0.0, 1.0[ uniformly distributed.
Definition: Uniform.h:126

References _is_infected, _transmit_rate, and RAND::Uniform().

◆ operator!=()

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

Implements TTrait.

99 {
100  if(!((*this) == T))
101  return true;
102  else
103  return false;
104 }

◆ operator=()

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

Implements TTrait.

75 {
76  const TTWolbachia& TD = dynamic_cast<const TTWolbachia&> (T);
77  if(this != &TD) {
79 // _transmit_rate = TD._transmit_rate;
80  }
81  return *this;
82 }
Trait used to study the dynamics of spread of Wolbachia, an endosymbiotic parasite causing cytoplasmi...
Definition: ttwolbachia.h:53

References _is_infected.

◆ operator==()

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

Implements TTrait.

87 {
88  if(this->get_type().compare(T.get_type()) != 0) return false;
89 // const TTWolbachia& TD = dynamic_cast<const TTWolbachia&> (T);
90 // if(this != &TD) {
91 // if(_transmit_rate != TD._transmit_rate) return false;
92 // }
93  return true;
94 }
virtual trait_t get_type() const
Definition: ttwolbachia.h:83
virtual trait_t get_type() const =0
type accessor.

References get_type(), and TTrait::get_type().

◆ reset()

virtual void TTWolbachia::reset ( )
inlinevirtual

Implements TTrait.

73 {_is_infected = 0;}

References _is_infected.

◆ retrieve_data()

virtual bool TTWolbachia::retrieve_data ( BinaryStorageBuffer reader)
inlinevirtual

Implements StorableComponent.

100  {
101  unsigned char dummy;
102  reader->read(&dummy, 1);
103  _is_infected = dummy;
104  return true;
105  }
void read(void *out, unsigned int nb_bytes)
Definition: binarystoragebuffer.h:220

References _is_infected, and BinaryStorageBuffer::read().

◆ set_allele_value()

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

Implements TTrait.

87 {_is_infected=(bool)value;}

References _is_infected.

◆ set_sequence()

virtual void TTWolbachia::set_sequence ( void **  seq)
inlinevirtual

Implements TTrait.

80 { }

◆ set_trait()

virtual void* TTWolbachia::set_trait ( void *  value)
inlinevirtual

Implements TTrait.

79  { _is_infected = *(bool*)value; return &_is_infected; }

References _is_infected.

◆ set_transmit_rate()

void TTWolbachia::set_transmit_rate ( double  val)
inline
69 {_transmit_rate = val;}

References _transmit_rate.

Referenced by TProtoWolbachia::hatch().

+ Here is the caller graph for this function:

◆ set_value()

virtual void TTWolbachia::set_value ( )
inlinevirtual

Implements TTrait.

81 { }

◆ show_up()

virtual void TTWolbachia::show_up ( )
inlinevirtual

Implements TTrait.

88 {}

◆ store_data()

virtual void TTWolbachia::store_data ( BinaryStorageBuffer saver)
inlinevirtual

Implements StorableComponent.

95  {
96  unsigned char dummy = static_cast<unsigned char>(_is_infected);
97  saver->store(&dummy, 1);
98  }
void store(void *stream, unsigned int nb_bytes)
Definition: binarystoragebuffer.cc:37

References _is_infected, and BinaryStorageBuffer::store().

Member Data Documentation

◆ _is_infected

◆ _transmit_rate

double TTWolbachia::_transmit_rate
private

Referenced by mutate(), and set_transmit_rate().


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