Mercurial > repos > dereeper > sniplay
diff egglib/egglib-2.1.5/include/egglib-cpp/Population.hpp @ 9:98c37a5d67f4 draft
Uploaded
author | dereeper |
---|---|
date | Wed, 07 Feb 2018 22:08:47 -0500 |
parents | 420b57c3c185 |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/egglib/egglib-2.1.5/include/egglib-cpp/Population.hpp Wed Feb 07 22:08:47 2018 -0500 @@ -0,0 +1,143 @@ +/* + Copyright 2009-2010 Stéphane De Mita, Mathieu Siol + + This file is part of the EggLib library. + + EggLib is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + EggLib is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with EggLib. If not, see <http://www.gnu.org/licenses/>. +*/ + +#ifndef EGGLIB_POPULATION_HPP +#define EGGLIB_POPULATION_HPP + + +#include "Edge.hpp" + +namespace egglib { + + class Random; + + /** \brief Handles a single population + * + * \ingroup coalesce + * + */ + class Population { + + public: + + /** \brief Default constructor + * + * Generates an empty population. + * + */ + Population(); + + /** \brief Copy constructor + * + */ + Population(const Population& source); + + /** \brief Assignment operator + * + */ + Population& operator=(const Population& source); + + /** \brief Destructor + * + * The object only cleans Edge objects currently stored in it. + * + */ + ~Population(); + + /** \brief Standard constructor + * + * The Edge instances will be handled by address and they + * MUST be passed using the method set(). + * + * \param numberOfSegments number of recombining segments. + * + * \param numberOfLineages the number of lineages contained + * in this population. + * + * \param firstIndex the absolute index (or ID) of the first + * lineage (the other will have consecutive incremented + * ID's). + * + */ + Population(unsigned int numberOfSegments, + unsigned int numberOfLineages, unsigned firstIndex); + + /** \brief Gets the number of lineages + * + */ + unsigned int numberOfLineages() const; + + /** \brief Gets the efficient number of lineages + * + * The number of lineages is multiplied by the number of + * covered segments of each lineages. + * + */ + unsigned int efficientNumberOfLineages() const; + + /** \brief Sets the Edge of a lineage + * + * \param index the index of the lineage within the + * population. + * \param edge the address of the Edge instance representing + * the lineage. + * + */ + void set(unsigned int index, Edge* edge); + + /** \brief Removes and returns a random lineage. + * + * \param random pointer to simulator's random generator + * instance. + * + */ + Edge* extractRandomly(Random* random); + + /** \brief Removes and returns a given lineage. + * + * \param index the relative index of the lineage. + * + */ + Edge* extractByIndex(unsigned int index); + + /** \brief Appends a lineage to the object + * + */ + void push(Edge* edge); + + /** \brief Gets coverage + * + */ + unsigned int coverage(unsigned int edgeIndex) const; + + + private: + + void copy(const Population& source); + void clear(); + Edge* pick(unsigned int index); + void init(); + unsigned int _numberOfLineages; + unsigned int _efficientNumberOfLineages; + Edge** lineages; + }; + +} + +#endif