Mercurial > repos > dereeper > sniplay
comparison egglib/egglib-2.1.5/include/egglib-cpp/Controller.hpp @ 1:420b57c3c185 draft
Uploaded
author | dereeper |
---|---|
date | Fri, 10 Jul 2015 04:39:30 -0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
0:3e19d0dfcf3e | 1:420b57c3c185 |
---|---|
1 /* | |
2 Copyright 2009-2010 Stéphane De Mita, Mathieu Siol | |
3 | |
4 This file is part of the EggLib library. | |
5 | |
6 EggLib is free software: you can redistribute it and/or modify | |
7 it under the terms of the GNU General Public License as published by | |
8 the Free Software Foundation, either version 3 of the License, or | |
9 (at your option) any later version. | |
10 | |
11 EggLib is distributed in the hope that it will be useful, | |
12 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 GNU General Public License for more details. | |
15 | |
16 You should have received a copy of the GNU General Public License | |
17 along with EggLib. If not, see <http://www.gnu.org/licenses/>. | |
18 */ | |
19 | |
20 #ifndef EGGLIB_CONTROLLER_HPP | |
21 #define EGGLIB_CONTROLLER_HPP | |
22 | |
23 #include "Current.hpp" | |
24 #include "Arg.hpp" | |
25 #include "ParamSet.hpp" | |
26 | |
27 namespace egglib { | |
28 | |
29 class Random; | |
30 | |
31 /** \brief Controls a coalescent simulation | |
32 * | |
33 * \ingroup coalesce | |
34 * | |
35 * This class generates the gene genealogy, based on the parameters | |
36 * stocked in a ParamSet object. | |
37 * | |
38 */ | |
39 class Controller { | |
40 | |
41 public: | |
42 | |
43 /** \brief Default constructor | |
44 * | |
45 * Uses a default ParamSet object that will not allow | |
46 * performing simulations. | |
47 * | |
48 */ | |
49 Controller(); | |
50 | |
51 /** \brief Destructor | |
52 * | |
53 */ | |
54 ~Controller(); | |
55 | |
56 /** \brief Standard constructor | |
57 * | |
58 * \param paramSet a ParamSet object containing run | |
59 * parameters (it is taken as a reference and stored as this | |
60 * so it must not be modified during simulations). | |
61 * | |
62 * \param random the address of the random number generator. | |
63 * | |
64 */ | |
65 Controller(const ParamSet* paramSet, Random* random); | |
66 | |
67 /** \brief Reset for a new simulation | |
68 * | |
69 * Object is reinitiliazed for a new simulation. | |
70 * | |
71 */ | |
72 void reset(); | |
73 | |
74 /** \brief Increments the coalescent model | |
75 * | |
76 * \return The number of lineages. | |
77 * | |
78 */ | |
79 unsigned int step(); | |
80 | |
81 /** \brief Gets the Ancestral Recombination Graph | |
82 * | |
83 * \return The address of the ARG contained in the object. | |
84 * | |
85 */ | |
86 Arg* getArg(); | |
87 | |
88 /** \brief Applies a bottleneck to a given population | |
89 * | |
90 * The bottleneck is applied following Galtier, Depaulis and | |
91 * Barton (Genetics, 2000): the general time counter is | |
92 * stopped, and coalescence events are performed during a | |
93 * time (of normal coalescent process) given by the parameter | |
94 * strength. All coalescent events are instantaneous. | |
95 * | |
96 * \param populationIndex index of the population concerned | |
97 * by the event. | |
98 * | |
99 * \param strength strength of the bottleneck given by a | |
100 * number of time units (2N generations times the size of | |
101 * the population). | |
102 * | |
103 */ | |
104 void bottleneck(unsigned int populationIndex, double strength); | |
105 | |
106 /** \brief Migrate a complete population | |
107 * | |
108 * Takes all the lineages currently present in the population | |
109 * source to the population dest. | |
110 * | |
111 */ | |
112 void moveAllLineages(unsigned int source, unsigned int dest); | |
113 | |
114 /** \brief Migrate a complete population | |
115 * | |
116 * Takes all the lineages currently present in the population | |
117 * source to the population dest. | |
118 * | |
119 * \param source source population. | |
120 * \param dest destination population. | |
121 * \param probability the probability that a lineage of | |
122 * source migrates to dest. | |
123 * | |
124 */ | |
125 void moveSomeLineages(unsigned int source, unsigned int dest, double probability); | |
126 | |
127 /// Adds an empty population | |
128 void addPopulation(); | |
129 | |
130 private: | |
131 | |
132 /// The copy constructor is disabled | |
133 Controller(const Controller& source) {} | |
134 | |
135 /// The assignment operator is disabled | |
136 Controller& operator=(const Controller& source) {return *this;} | |
137 | |
138 void diploids(); | |
139 double getMigrationTime(double& migrationParameterDestination); | |
140 void getCoalescenceTime(double& destTime, unsigned int& destPopIndex); | |
141 double getCoalescenceTimeForPopulation(unsigned int populationIndex); | |
142 double getRecombinationTime() const; | |
143 void migrate(double migrationParameter); | |
144 | |
145 const ParamSet* initialParamSet; | |
146 ParamSet paramSet; | |
147 Current current; | |
148 Arg arg; | |
149 | |
150 Random* random; | |
151 | |
152 }; | |
153 | |
154 } | |
155 | |
156 #endif |