bpp-phyl3  3.0.0
bpp::ComprehensiveSubstitutionRegister Class Reference

Distinguishes all types of substitutions. More...

#include <Bpp/Phyl/Mapping/CategorySubstitutionRegister.h>

+ Inheritance diagram for bpp::ComprehensiveSubstitutionRegister:
+ Collaboration diagram for bpp::ComprehensiveSubstitutionRegister:

Public Member Functions

 ComprehensiveSubstitutionRegister (std::shared_ptr< const StateMapInterface > stateMap, bool within=false)
 
ComprehensiveSubstitutionRegisterclone () const
 
virtual size_t getCategory (size_t state) const
 
virtual size_t getCategoryFrom (size_t type) const
 
virtual size_t getCategoryTo (size_t type) const
 
virtual std::string getCategoryName (size_t category) const
 
virtual bool allowWithin () const
 
bool isStationary () const
 
void setStationarity (bool stat)
 
size_t getNumberOfCategories () const
 
size_t getNumberOfSubstitutionTypes () const
 
virtual size_t getType (size_t fromState, size_t toState) const
 Get the substitution type far a given pair of model states. More...
 
std::string getTypeName (size_t type) const
 Get the name of a given substitution type. More...
 
const StateMapInterfacestateMap () const override
 
std::shared_ptr< const StateMapInterfacegetStateMap () const override
 
const Alphabetalphabet () const override
 
std::shared_ptr< const AlphabetgetAlphabet () const override
 
const std::string & getName () const override
 Get the name of the register. More...
 

Protected Member Functions

template<class T >
void setAlphabetCategories (const std::map< int, T > &categories)
 
template<class T >
void setModelCategories (const std::map< size_t, T > &categories)
 

Protected Attributes

bool within_
 
size_t nbCategories_
 
std::map< size_t, size_t > categories_
 
std::vector< std::string > categoryNames_
 
std::vector< std::vector< size_t > > index_
 
std::vector< std::vector< size_t > > revIndex_
 
bool stationarity_
 
std::shared_ptr< const StateMapInterfacestateMap_
 
std::string name_
 

Detailed Description

Distinguishes all types of substitutions.

This register has all n * (n-1) substitution type, where n is the size of the alphabet, mapped as:

  • 0 not a substitution
  • x in [1, n(n-1)] a substitution

Definition at line 217 of file CategorySubstitutionRegister.h.

Constructor & Destructor Documentation

◆ ComprehensiveSubstitutionRegister()

bpp::ComprehensiveSubstitutionRegister::ComprehensiveSubstitutionRegister ( std::shared_ptr< const StateMapInterface stateMap,
bool  within = false 
)
inline

Member Function Documentation

◆ allowWithin()

virtual bool bpp::CategorySubstitutionRegister::allowWithin ( ) const
inlinevirtualinherited

◆ alphabet()

const Alphabet& bpp::AbstractSubstitutionRegister::alphabet ( ) const
inlineoverridevirtualinherited
Returns
The alphabet associated to this instance.

Implements bpp::SubstitutionRegisterInterface.

Definition at line 133 of file SubstitutionRegister.h.

References bpp::AbstractSubstitutionRegister::stateMap_.

◆ clone()

ComprehensiveSubstitutionRegister* bpp::ComprehensiveSubstitutionRegister::clone ( ) const
inlinevirtual

◆ getAlphabet()

std::shared_ptr<const Alphabet> bpp::AbstractSubstitutionRegister::getAlphabet ( ) const
inlineoverridevirtualinherited
Returns
A shared_ptr toward the alphabet associated to this instance.

Implements bpp::SubstitutionRegisterInterface.

Definition at line 135 of file SubstitutionRegister.h.

References bpp::AbstractSubstitutionRegister::stateMap_.

◆ getCategory()

virtual size_t bpp::CategorySubstitutionRegister::getCategory ( size_t  state) const
inlinevirtualinherited

◆ getCategoryFrom()

virtual size_t bpp::CategorySubstitutionRegister::getCategoryFrom ( size_t  type) const
inlinevirtualinherited

◆ getCategoryName()

virtual std::string bpp::CategorySubstitutionRegister::getCategoryName ( size_t  category) const
inlinevirtualinherited

◆ getCategoryTo()

virtual size_t bpp::CategorySubstitutionRegister::getCategoryTo ( size_t  type) const
inlinevirtualinherited

◆ getName()

const std::string& bpp::AbstractSubstitutionRegister::getName ( ) const
inlineoverridevirtualinherited

Get the name of the register.

Returns
A string describing the register.

Implements bpp::SubstitutionRegisterInterface.

Definition at line 137 of file SubstitutionRegister.h.

References bpp::AbstractSubstitutionRegister::name_.

◆ getNumberOfCategories()

size_t bpp::CategorySubstitutionRegister::getNumberOfCategories ( ) const
inlineinherited

◆ getNumberOfSubstitutionTypes()

size_t bpp::CategorySubstitutionRegister::getNumberOfSubstitutionTypes ( ) const
inlinevirtualinherited
Returns
The number of substitution types supported by this class.

Implements bpp::SubstitutionRegisterInterface.

Definition at line 191 of file CategorySubstitutionRegister.h.

References bpp::CategorySubstitutionRegister::nbCategories_, and bpp::CategorySubstitutionRegister::within_.

◆ getStateMap()

std::shared_ptr<const StateMapInterface> bpp::AbstractSubstitutionRegister::getStateMap ( ) const
inlineoverridevirtualinherited
Returns
A shared_ptr toward the state map associated to this instance.

Implements bpp::SubstitutionRegisterInterface.

Definition at line 131 of file SubstitutionRegister.h.

References bpp::AbstractSubstitutionRegister::stateMap_.

◆ getType()

virtual size_t bpp::CategorySubstitutionRegister::getType ( size_t  fromState,
size_t  toState 
) const
inlinevirtualinherited

Get the substitution type far a given pair of model states.

Parameters
fromStateInitial state (should be a state supported by the specified alphabet).
toStateFinal state (should be a state supported by the specified alphabet).
Returns
The index of the corresponding substitution type, ranging from 0 to 'getNumberOfSubstitutionTypes' + 1, as non-substitution (that is when fromState == toState) will always return 0.

Implements bpp::SubstitutionRegisterInterface.

Reimplemented in bpp::GCPositionSubstitutionRegister, and bpp::GCSynonymousSubstitutionRegister.

Definition at line 193 of file CategorySubstitutionRegister.h.

References bpp::CategorySubstitutionRegister::categories_, and bpp::CategorySubstitutionRegister::index_.

◆ getTypeName()

std::string bpp::CategorySubstitutionRegister::getTypeName ( size_t  type) const
inlinevirtualinherited

Get the name of a given substitution type.

This method is only used for user-friendlyness purposes, not computational goal. I can therefore be left unimplemented in some cases.

Parameters
typeIndex of the substitution (should be an size_t contained in the register).
Returns
A string describing the substitution type.

Implements bpp::SubstitutionRegisterInterface.

Reimplemented in bpp::GCPositionSubstitutionRegister, and bpp::GCSynonymousSubstitutionRegister.

Definition at line 203 of file CategorySubstitutionRegister.h.

References bpp::CategorySubstitutionRegister::getCategoryFrom(), bpp::CategorySubstitutionRegister::getCategoryName(), and bpp::CategorySubstitutionRegister::getCategoryTo().

◆ isStationary()

bool bpp::CategorySubstitutionRegister::isStationary ( ) const
inlineinherited

◆ setAlphabetCategories()

template<class T >
void bpp::CategorySubstitutionRegister::setAlphabetCategories ( const std::map< int, T > &  categories)
inlineprotectedinherited

◆ setModelCategories()

◆ setStationarity()

void bpp::CategorySubstitutionRegister::setStationarity ( bool  stat)
inlineinherited

◆ stateMap()

Member Data Documentation

◆ categories_

◆ categoryNames_

std::vector<std::string> bpp::CategorySubstitutionRegister::categoryNames_
protectedinherited

◆ index_

std::vector< std::vector<size_t> > bpp::CategorySubstitutionRegister::index_
protectedinherited

◆ name_

std::string bpp::AbstractSubstitutionRegister::name_
protectedinherited

◆ nbCategories_

◆ revIndex_

std::vector< std::vector<size_t> > bpp::CategorySubstitutionRegister::revIndex_
protectedinherited

◆ stateMap_

◆ stationarity_

bool bpp::CategorySubstitutionRegister::stationarity_
protectedinherited

◆ within_


The documentation for this class was generated from the following file: