Mercurial > repos > dereeper > sniplay
diff egglib/egglib-2.1.5/include/egglib-cpp/Current.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/Current.hpp Wed Feb 07 22:08:47 2018 -0500 @@ -0,0 +1,128 @@ +/* + 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_CURRENT_HPP +#define EGGLIB_CURRENT_HPP + + +namespace egglib { + + class Population; + class ParamSet; + + /** \brief Represents the current set of populations + * + * \ingroup coalesce + * + */ + class Current { + + public: + + /** \brief Default constructor + * + */ + Current(); + + /** \brief Standard constructor + * + * \param paramSet allows to initiate the correct structure + * of populations. + * + */ + Current(ParamSet* paramSet); + + /** \brief Rebuilds the object + * + * \param paramSet allows to initiate the correct structure + * of populations. + * + */ + void reset(ParamSet* paramSet); + + /** \brief Destructor + * + */ + virtual ~Current(); + + /** \brief Copy constructor + * + */ + Current(const Current&); + + /** \brief Assignment operator + * + */ + Current& operator=(const Current&); + + /** \brief Gets the current number of populations + * + */ + unsigned int numberOfPopulations() const; + + + /** \brief Adds an empty population to the system + * + */ + void addPopulation(); + + + /** \brief Gets the number of lineages contained by a given + * population + * + */ + unsigned int populationNumberOfLineages(unsigned int populationIndex) const; + + + /** \brief Provides access to a given population + * + * The returned pointer can be used to modify the object. + * + */ + Population* population(unsigned int populationIndex); + + + /** \brief Total number of lineages + * + */ + unsigned int totalNumberOfLineages() const; + + + /** \brief Efficient number of lineages + * + * This sums the number of covered segments of each lineage. + * + */ + unsigned int efficientNumberOfLineages() const; + + + private: + + void setPopulationArray(); + void copy(const Current&); + void clear(); + + unsigned int _numberOfPopulations; + unsigned int _numberOfSegments; + Population** populations; + }; + +} + +#endif