diff egglib/egglib-2.1.5/include/egglib-cpp/Controller.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/Controller.hpp	Wed Feb 07 22:08:47 2018 -0500
@@ -0,0 +1,156 @@
+/*
+    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_CONTROLLER_HPP
+#define EGGLIB_CONTROLLER_HPP
+
+#include "Current.hpp"
+#include "Arg.hpp"
+#include "ParamSet.hpp"
+
+namespace egglib {
+    
+    class Random;
+
+   /** \brief Controls a coalescent simulation
+    *
+    * \ingroup coalesce
+    * 
+    * This class generates the gene genealogy, based on the parameters
+    * stocked in a ParamSet object.
+    *
+    */
+    class Controller {
+
+        public:
+    
+           /** \brief Default constructor
+            *
+            * Uses a default ParamSet object that will not allow
+            * performing simulations.
+            *
+            */
+            Controller();
+
+           /** \brief Destructor
+            * 
+            */
+            ~Controller();
+            
+           /** \brief Standard constructor
+            * 
+            * \param paramSet a ParamSet object containing run
+            * parameters (it is taken as a reference and stored as this
+            * so it must not be modified during simulations).
+            * 
+            * \param random the address of the random number generator.
+            *
+            */
+            Controller(const ParamSet* paramSet, Random* random);
+            
+          /** \brief Reset for a new simulation
+           * 
+           * Object is reinitiliazed for a new simulation.
+           * 
+           */
+           void reset();
+            
+           /** \brief Increments the coalescent model
+            * 
+            * \return The number of lineages.
+            *
+            */
+            unsigned int step();
+            
+           /** \brief Gets the Ancestral Recombination Graph
+            * 
+            * \return The address of the ARG contained in the object.
+            * 
+            */
+            Arg* getArg();
+
+           /** \brief Applies a bottleneck to a given population
+            * 
+            * The bottleneck is applied following Galtier, Depaulis and
+            * Barton (Genetics, 2000): the general time counter is
+            * stopped, and coalescence events are performed during a
+            * time (of normal coalescent process) given by the parameter
+            * strength. All coalescent events are instantaneous.
+            * 
+            * \param populationIndex index of the population concerned
+            * by the event.
+            * 
+            * \param strength strength of the bottleneck given by a
+            * number of time units (2N generations times the size of
+            * the population).
+            * 
+            */
+            void bottleneck(unsigned int populationIndex, double strength);
+
+           /** \brief Migrate a complete population
+            * 
+            * Takes all the lineages currently present in the population
+            * source to the population dest.
+            * 
+            */
+            void moveAllLineages(unsigned int source, unsigned int dest);
+            
+           /** \brief Migrate a complete population
+            * 
+            * Takes all the lineages currently present in the population
+            * source to the population dest.
+            * 
+            * \param source source population.
+            * \param dest destination population.
+            * \param probability the probability that a lineage of
+            * source migrates to dest.
+            * 
+            */
+            void moveSomeLineages(unsigned int source, unsigned int dest, double probability);
+
+            /// Adds an empty population
+            void addPopulation();
+
+        private:
+        
+            /// The copy constructor is disabled
+            Controller(const Controller& source) {}
+            
+            /// The assignment operator is disabled
+            Controller& operator=(const Controller& source) {return *this;}
+
+            void diploids();
+            double getMigrationTime(double& migrationParameterDestination);
+            void getCoalescenceTime(double& destTime, unsigned int& destPopIndex);
+            double getCoalescenceTimeForPopulation(unsigned int populationIndex);
+            double getRecombinationTime() const;
+            void migrate(double migrationParameter);
+
+            const ParamSet* initialParamSet;
+            ParamSet paramSet;
+            Current current;
+            Arg arg;
+            
+            Random* random;
+
+    };
+
+}
+
+#endif