|
|
(36 intermediate revisions by the same user not shown) |
Line 1: |
Line 1: |
− | {{Heidelberg/header}}
| |
| | | |
− | {{#tag:html|
| |
− | <script>
| |
− | {{Heidelberg/title|Phage Titer}}
| |
− | </script>
| |
− | }}
| |
− |
| |
− | {{Heidelberg/navbar
| |
− | }}
| |
− | {{Heidelberg/main|
| |
− | Modeling|
| |
− | Phage Titer|
| |
− | https://static.igem.org/mediawiki/2017/3/38/T--Heidelberg--2017_Background_Owl.jpg|blue|
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | While developing <a href="https://2017.igem.org/Team:Heidelberg/Predcel">PREDCEL</a> in the lab, we simultaneously developed it <i>in silico</i> so that both sides could benefit from each other. One of the most important parameter of phage assisted directed evolution experiments like PREDCEL and PACE is the phage titer itself. If the phage titer drops washout can occur and the experiment has to be restarted with the disadvantage of loosing library complexity. If the phage titer increases too much, the multiplicity of infection (MOI), that means the amount of phage relative the the amount of <i>E. coli</i> rises too. If fore example the MOI is 10 and an <i>E. coli</i> can only be infected by one phage, nine out of ten phages will not infect an <i>E. coli</i> and thus will not evolve, but still make up most of the phage population.
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | {{Heidelberg/templateus/Imagebox|https://static.igem.org/mediawiki/2017/c/cd/T--Heidelberg--2017_phage_titer_fig1.png|{{#tag:html|Figure 1: Basic logarithmic phage and <i>E. coli</i> titer plot with 20 % wildtype fitness}}|{{#tag:html| The blue lines correspond to the different <i>E. coli</i> populations. Exponential growth of <i>E. coli</i> and constant fitness of 20% of the wildtype, equal in all phages was assumed. After ten minutes infected <i>E. coli</i> start producing phage, corresponding to a drop in infected <i>E. coli</i> and an increase in phage concentration.
| |
− | <br>
| |
− | <a href="#parameters">See the full list of parameters.</a>
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Imagebox|https://static.igem.org/mediawiki/2017/3/38/T--Heidelberg--2017_phage_titer_fig2.png|{{#tag:html|Figure 2: Basic logarithmic phage and <i>E. coli</i> titer plot with 100 % wildtype fitness.}}|{{#tag:html| The blue lines correspond to the different <i>E. coli</i> populations. Exponential growth of <i>E. coli</i> and constant fitness of 100% of the wildtype, equal in all phages was assumed. After ten minutes infected <i>E. coli</i> start producing phage, corresponding to a drop in infected <i>E. coli</i> and an increase in phage concentration.
| |
− | <br>
| |
− | <a href="#parameters">See the full list of parameters.</a>
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | Comparing the plots for 20 % and 100 % fitness show that a higher fitness increases the final phage titer and decreases the amount of uninfected <i>E. coli</i> earlier.
| |
− | <h1>Modeling concentrations in one Lagoon</h1>
| |
− | Here the concentrations \(c\) of uninfected <i>E. coli</i>, infected <i>E. coli</i> and phage producing <i>E. coli</i> as well as the <i>M13</i> phage are modeled. They are denoted with the subscripts \(_{u}\), \(_{i}\), \(_{p}\) and \(_{P}\). If the whole <i>E. coli</i> population is referred to, \(c_{E}\) is used. If an arbitrary <i> E. coli</i> population is meant, the subscript \(_{e}\) is used. The phage concentration \(c_{P}\) refers to the free phage only, phage that are contained in an <i>E. coli</i> they infected are not included.
| |
− | The used parameters include the time \(t\), the affinity of phage for <i>E. coli</i> \(k\), the duration between infection of an <i>E. coli</i> and the first phage leaving the <i>E. coli</i> \(t_{P}\). The three different <i>E. coli</i> populations each have a generation time \(t\) that is denoted with their subscript. The fitness of a phage population is \(f\).
| |
− |
| |
− | }}
| |
− |
| |
− | {{Heidelberg/templateus/Tablebox|
| |
− | Table 1: Variables and Parameters used in this model |
| |
− | {{#tag:html|
| |
− | <table class="table table-bordered mdl-shadow--4dp" XSSCleaned="overflow-x: scroll !important">
| |
− | <thead>
| |
− | <tr>
| |
− | <th>Symbol</th>
| |
− | <th>Name in source code</th>
| |
− | <th>Value and Unit</th>
| |
− | <th>Explanation</th>
| |
− |
| |
− | </tr>
| |
− | </thead>
| |
− | <tbody>
| |
− | <tr>
| |
− | <td>\(c \)</td>
| |
− | <td>-</td>
| |
− | <td>[cfu] or [pfu] </td>
| |
− | <td>colony forming units for <i> E. coli</i> (cfu) or plaque forming units (pfu) for M13 phage</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( _u\)</td>
| |
− | <td>-</td>
| |
− | <td> - </td>
| |
− | <td>Subscript for uninfected <i>E. coli</i></td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( _i\)</td>
| |
− | <td>-</td>
| |
− | <td> - </td>
| |
− | <td>Subscript for infected <i>E. coli</i></td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( _p\)</td>
| |
− | <td>-</td>
| |
− | <td> - </td>
| |
− | <td>Subscript for phage-producing <i>E. coli</i></td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( _e\)</td>
| |
− | <td>-</td>
| |
− | <td> - </td>
| |
− | <td>Subscript any the of <i>E. coli</i> populations on its own</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( _E\)</td>
| |
− | <td>-</td>
| |
− | <td> - </td>
| |
− | <td>Subscript for all populations of <i>E. coli</i> together</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( _P\)</td>
| |
− | <td>-</td>
| |
− | <td> - </td>
| |
− | <td>Subscript for M13 phage</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(c_{c} \)</td>
| |
− | <td><code class="python">capacity</code></td>
| |
− | <td>[cfu/ml]</td>
| |
− | <td>Maximum concentration of <i>E. coli</i> possible under given conditions, important for logistic growth</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(t\)</td>
| |
− | <td><code class="python">t</code></td>
| |
− | <td>[min]</td>
| |
− | <td>Duration since the experiment modeled was started</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(t_{u} \)</td>
| |
− | <td><code class="python">tu</code></td>
| |
− | <td>\(20\) min</td>
| |
− | <td>Duration one division of uninfected <i>E. coli</i></td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(t_{i} \)</td>
| |
− | <td><code class="python">ti</code></td>
| |
− | <td>\(30\) min</td>
| |
− | <td>Duration one division of infected <i>E. coli</i></td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(t_{p} \)</td>
| |
− | <td><code class="python">tp</code></td>
| |
− | <td>\(40\) min</td>
| |
− | <td>Duration one division of phage producing <i>E. coli</i></td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( t_{P}\)</td>
| |
− | <td><code class="python">tpp</code></td>
| |
− | <td>[min]</td>
| |
− | <td>Duration between an <i>E. coli</i> being infected by an M13 phage and releasing the first new phage</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(g_{e} \)</td>
| |
− | <td><code class="python">e_growth_rate</code></td>
| |
− | <td>[cfu/min]</td>
| |
− | <td>Growth rate of <i>E. coli</i>, depending on the type of growth (either logistic or exponential), the current concentration \(c_{e}\), the maximum concentration \(c_{c}\), and the generation time \(t_{e}\)</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( k\)</td>
| |
− | <td><code class="python">k</code></td>
| |
− | <td>\(3 \cdot 10^{-11}\frac{1}{cfu \cdot pfu \cdot ml \cdot min}\)</td>
| |
− | <td>Affinity of M13 phage for <i>E. coli</i></td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( \mu_{max}\)</td>
| |
− | <td><code class="python">mumax</code></td>
| |
− | <td>\(16.67 \frac{cfu}{min \cdot ml \cdot cfu}\)</td>
| |
− | <td>Wildtype M13 phage production rate</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\( f\)</td>
| |
− | <td><code class="python">f</code></td>
| |
− | <td>?</td>
| |
− | <td>Fitnessvalue, fraction of actual \(\mu\) and \(\mu_{max}\)</td>
| |
− | </tr>
| |
− | </tbody>
| |
− | </table>
| |
− | }}|
| |
− | List of all paramters and variables used in this model. When possible values are given.
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | Each term describing the change of an <i>E. coli</i> concentration contains its growth, \(g_{e}\). The growth rate of an <i>E. coli</i> population can be modeled by exponential growth or by logistic growth. Especially, when long durations per lagoon are modeled, the logistic growth model is more exact. [source].
| |
− | In the exponential case the growth rate \(g_{e}\) is modeled as
| |
− | $$
| |
− | g_{e} (t_{e}) = c_{e} \cdot \frac{log(2)}{t_{e} }
| |
− | $$
| |
− | Note that the growth rate in the model increases over time, while in the modeled culture, the nutrient concentration decreases.
| |
− |
| |
− | That makes the logistic model more plausible, it models \(g_{e}\) as
| |
− | $$
| |
− | g_{e} (t_{e}, \: c_{e}(t), \: c_{c}) = \frac{c_{c} - c_{e} (t)}{c_{c} } \cdot \frac{log(2)}{t_{e} }
| |
− | $$
| |
− | In this case the learning rate decreases as the current concentration \(c_{e}\) approaches the maximum capacity for <i>E. coli</i> in the given setup \(c_{c}\). With this model \(c_{e} \leq c_{c}\) is true for any point in time.
| |
− |
| |
− |
| |
− | <b>Change of concentration of uninfected <i>E. coli</i>, \(\frac{\partial c_{u} }{\partial t} \: [cfu/min]\)</b>
| |
− | $$
| |
− | \frac{\partial c_{u} }{\partial t}(t) = g_{u} (t_{u}, \: c_{u}(t), \: c_{c})
| |
− | - k \cdot c_{u}(t) \cdot c_{p}(t)
| |
− | $$
| |
− | In addition to the growth term, the concentration of uninfected <i>E. coli</i> is described by a term for infection that takes into account the concentration of uninfected <i>E. coli</i> and the concentration of free phage and reduces the conentration of uninfected <i>E. coli</i>.
| |
− |
| |
− | <b>Change of concentration of uninfected <i>E. coli</i>, \(\frac{\partial c_{i} }{\partial t} \: [cfu/min]\)</b>
| |
− | $$
| |
− | \frac{\partial c_{i} }{\partial t}(t) = \begin{cases}
| |
− | g_{i} (t_{i}, \: c_{i}(t), \:c_{c})
| |
− | + k \cdot c_{i}(t) \cdot c_{p}(t)
| |
− | - c_{i}(t - t_{P}),
| |
− | \quad \text{for} \: t > t_{P} \\
| |
− | g_{i} (t_{i}, \: c_{i}(t), \: c_{c})
| |
− | + k \cdot c_{i}(t) \cdot c_{p}(t),
| |
− | \quad \text{otherwise}
| |
− | \end{cases}
| |
− | $$
| |
− | Until \(t > t_{P}\) the concentration of infected <i>E. coli</i> increases by growth and infection of previouly uninfected <i>E. coli</i>. When \(t > t_{P}\), a third term describing that infected <i>E. coli</i> turn into phage-producing <i>E. coli</i> is subtracted.
| |
− |
| |
− | <b>Change of concentration of phage producing <i>E. coli</i>, \(\frac{\partial c_{p} }{\partial t} \: [cfu/min]\)</b>
| |
− |
| |
− | $$
| |
− | \frac{\partial c_{p} }{\partial t}(t) = \begin{cases}
| |
− | g_{p} (t_{p}, \: c_{p}(t), \: c_{c}) -
| |
− | c_{i}(t - t_{P}),
| |
− | \quad \text{for} \: t > t_{P} \\
| |
− | g_{p} (t_{p}, \: c_{p}(t), \: c_{c}),
| |
− | \quad \text{otherwise}
| |
− | \end{cases}
| |
− | $$
| |
− | The population of phage producing E. coli only increases by growth until \(t > t_{P}\). When infected <i>E. coli</i> drop their first phage they turn into producing <i>E. coli</i> as described by the second term.
| |
− |
| |
− | <b>Change of concentration of <i>M13</i> phage, \(\frac{\partial c_{P} }{\partial t} \: [cpu/min]\)</b>
| |
− |
| |
− | $$
| |
− | \frac{\partial c_{P} }{\partial t}(t) = c_{P}(t) \cdot \mu_{max} \cdot f - k \cdot c_{u}(t)\cdot c_{P}(t)
| |
− | $$
| |
− | The phage concentration is only increased by phage that leave phage-producing <i>E. coli</i>, which happens at a rate of \(f \cdot \mu_{max}\) per time unit, with f being the fitness, a value between 0 and 1, equal to the share of the wildtype <i>M13</i> phages fitness and \(\mu_{max}\) being the wildtype phages production rate. We assume that the only negative influence on the free phage titer is phage infecting <i>E. coli</i>, which depends on both the phage titer \(c_{P}\) and the titer of uninfected <i>E. coli</i>, \(c_{i}\).
| |
− |
| |
− | When the fitness is assumed to be the same for all phages, it is modeled to be constant during the time in one lagoon.
| |
− | <br>
| |
− |
| |
− | If a fitness distribution is assumed, the fitness does not necessarily stay constant in one lagoon. The distribution is initialised with 100 % of the phages having the starting fitness. First changes in the fitness distribution occur after the first <i>E. coli</i> start to release phages.
| |
− | <br>
| |
− | The fitness distribution is modeled to change by mutation and selection. The <b>selection</b> is implemented in the following equation:
| |
− |
| |
− | $$
| |
− | s_{i}(t_{n + 1}) = f_{i}(t_{n}) \cdot s_{i}(t_{n})
| |
− | $$
| |
− |
| |
− |
| |
− | \(f_{i}\) is one of \(N\) fitness values, \(s_{i}\) is the share of phages with that fitness value relative to the total phage population. Since the fitness is interpreted as a percentage of the wildtype fitness in this model, the new shares can be calculated als the product of the fitness value \(f_{i}\) and its old share \(s_{i}(t_{n})\). The resulting values are then normalized by divsion with
| |
− |
| |
− | $$
| |
− | \sum_{i = 0}^{N} f_{i}(t_{n + 1})
| |
− | $$
| |
− |
| |
− | in order to always have shares that sum up to 1.
| |
− | <br>
| |
− | The <b>mutation</b> is implemented as a function that manipulates the fitness shares and applied to the fitness shares after selection.
| |
− | Here, \(r_{M}\) is the mutation rate, that means the amount of the fitness share \(i\) that changed during the mutation. \(w\) is the width of a fitness bin:
| |
− |
| |
− | $$
| |
− | w = \frac{1}{N - 1}
| |
− | $$
| |
− |
| |
− | The new shares are calculated as
| |
− |
| |
− | $$
| |
− | s_{i}(t_{n + 1}) = \big(1 - r_{M}\big) \cdot s_{i}(t_{n}) + r_{M} \sum_{i = 0}^{N} \int_{f_{i} - \frac{1}{2} \cdot w}^{f_{i} + \frac{1}{2} \cdot w} \mathcal{N}_{\mu=f_{i}, \: \sigma}(x) \: dx
| |
− | $$
| |
− |
| |
− | <b>Special cases:</b><br>
| |
− | For \(f_{0}\) the integral is changed to
| |
− |
| |
− | $$
| |
− | \int_{- \infty }^{f_{0} + \frac{1}{2} \cdot w} \mathcal{N}_{\mu=f_{i}, \: \sigma}(x) \: dx
| |
− | $$
| |
− |
| |
− | For \(f_{0}\) the integral is changed to
| |
− |
| |
− | $$
| |
− | \int_{f_{N} - \frac{1}{2} \cdot w}^{\infty} \mathcal{N}_{\mu=f_{i}, \: \sigma}(x) \: dx
| |
− | $$
| |
− |
| |
− | to have the integrals over the normal distribution add up to 1.
| |
− |
| |
− | The normal distribution \(\mathcal{N}\) is used to model that many mutations have only small effects on the fitness, while some have a larger effect. \(\sigma\) is a parameter of the model that influences how much the new scores differ from the previous ones. In this model it is theoretically possible that mutation turns any given fitness into any other fitness, however small values for can \(\sigma\) prevent this.
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | {{Heidelberg/templateus/Imagebox|https://static.igem.org/mediawiki/2017/0/02/T--Heidelberg--2017_phage_titer_fig3.png|{{#tag:html|Figure 3: Constant fitness assumed to be equal for all phages in the lagoon}}|{{#tag:html|The color indicates the share of phages that have a specific fitness (y-axis) at a given time (x-axis). With the constant non-distributional mode the complete phage population has the initial fitness for the whole time.
| |
− | <br>
| |
− | <a href="#parameters">See the full list of parameters.</a>
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Imagebox|https://static.igem.org/mediawiki/2017/7/7d/T--Heidelberg--2017_phage_titer_fig4.png|{{#tag:html|Figure 4: A distribution of fitness assumed with 10 % of new phages being subjected to changes in fitness.}}|{{#tag:html|The color indicates the share of phages that have a specific fitness (y-axis) at a given time (x-axis). With the distributional fitness mode after 10 minutes variants with a higher fitness occur.
| |
− | <br>
| |
− | <a href="#parameters">See the full list of parameters.</a>
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | When the the concentrations are modeled over a longer period of time the fitness of the wildtype is reached. To more accurate model evolution in which the wildtype fitness is never reached, \(\mu_{max}\) can be set to a smaller value. This value will be reached by most of the phages, if enough time is given. Finally almost no phages with the lowest fitness can be found in the lagoon.
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | {{Heidelberg/templateus/Imagebox|https://static.igem.org/mediawiki/2017/b/be/T--Heidelberg--2017_phage_titer_fig5.png|{{#tag:html|Figure 5: <i>E. coli</i> and phage titer modled over 6.5 h with a normal distribution based fitness distribution.}}|{{#tag:html|Blue lines correspond to <i>E. coli</i> titers, the red line is the total phage titer.
| |
− | <br>
| |
− | <a href="#parameters">See the full list of parameters.</a>
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Imagebox|https://static.igem.org/mediawiki/2017/5/55/T--Heidelberg--2017_phage_titer_fig6.png|{{#tag:html|Figure 6: A distribution of fitness is assumed with 10 % of new phages being subjected to changes in fitness over 6.5 h.}}|{{#tag:html|The color indicates the share of phages that have a specific fitness (y-axis) at a given time (x-axis). After 4 h the system goes in a steay state where mutation and selection cancel each other out.
| |
− | <br>
| |
− | <a href="#parameters">See the full list of parameters.</a>
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Imagebox|https://static.igem.org/mediawiki/2017/a/ac/T--Heidelberg--2017_phage_titer_fig7.png|{{#tag:html|Figure 7: Shares of the phage-producing <i>E. coli</i> producing phages with different fitness values.}}|{{#tag:html|Modelled with normal distribution based mutation. Initially all phage-producing <i>E. coli</i> produce phage with 20 % of the wildtype fitness, they make up the largest share for 1 h after which fitter phage-producing <i>E. coli</i> take over the lagoon.
| |
− | <br>
| |
− | <a href="#parameters">See the full list of parameters.</a>
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | Since most mutations decrease fitness in reality, a symmetric function like the normal distributions density function may not be the best choice. Consequently we also implemented a mutation function with a skew normal distribution \(\mathcal{S}\), that replaces \(\mathcal{N}\). It has an additional parameter \(\alpha\) that modulates the skewness.
| |
− |
| |
− | $$
| |
− | s_{i}(t_{n + 1}) = \big(1 - r_{M}\big) \cdot s_{i}(t_{n}) + r_{M} \sum_{i = 0}^{N} \int_{f_{i} - \frac{1}{2} \cdot w}^{f_{i} + \frac{1}{2} \cdot w} \mathcal{S}_{\mu=f_{i}, \: \sigma, \: \alpha}(x) \: dx
| |
− | $$
| |
− |
| |
− |
| |
− | <b>Special cases:</b><br>
| |
− | For \(f_{0}\) the integral is changed to
| |
− |
| |
− | $$
| |
− | \int_{- \infty }^{f_{0} + \frac{1}{2} \cdot w} \mathcal{S}_{\mu=f_{i}, \: \sigma, \: \alpha}(x) \: dx
| |
− | $$
| |
− |
| |
− | For \(f_{0}\) the integral is changed to
| |
− |
| |
− | $$
| |
− | \int_{f_{N} - \frac{1}{2} \cdot w}^{\infty} \mathcal{S}_{\mu=f_{i}, \: \sigma, \: \alpha}(x) \: dx
| |
− | $$
| |
− |
| |
− | to have the integrals over the normal distribution add up to 1.
| |
− | <br>
| |
− |
| |
− | The equation for \(\frac{\partial c_{P} (t)}{\partial t}\) is changed into the following to incorporate the distributed fitness.
| |
− |
| |
− | $$
| |
− | \frac{\partial c_{P} (t)}{\partial t} = -k \cdot c_{u}(t) \cdot c_{P} (t)
| |
− | + \sum_{i = 0}^N f_{i} \cdot s_{i} \cdot \mu \cdot c_{p} (t)
| |
− | $$
| |
− |
| |
− |
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | {{Heidelberg/templateus/Imagebox|https://static.igem.org/mediawiki/2017/c/cc/T--Heidelberg--2017_phage_titer_fig8.png|{{#tag:html|Figure 8: Shares of the phage-producing <i>E. coli</i> producing phages with different fitness values.}}|{{#tag:html|Modeled with skew normal distribution based mutation biased towards lower fitness scores. Initially all phage-producing <i>E. coli</i> produce phage with 20 % of the wildtype fitness, they make up the largest share for 1 h after which fitter phage-producing <i>E. coli</i> take over the lagoon.
| |
− | <br>
| |
− | <a href="#parameters">See the full list of parameters.</a>
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | Other assumptions for the mutation function are possible, for example a function that randomly samples from a normal distribution but is biased towards mutations that decrease fitness.
| |
− | <br>
| |
− | Since this model of fitness and mutation is heavily abstracted it is most likely limeted to qualitative statements. Still it provides an intuitive understanding on how directed evolution can work and illustrates the role of selection and mutation. If the model without mutation (Fig. 3) is compared to one with mutation and selection (Fig. 6) role of mutation, diversificating the pool of phages can be seen. When comparing a model without selection (Fig. 9) to the one with mutation and selection (Fig. 6) the role of selection can be described as channeling the variants caused by mutation into a specific direction.
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | {{Heidelberg/templateus/Imagebox|https://static.igem.org/mediawiki/2017/c/c6/T--Heidelberg--2017_phage_titer_fig9.png|{{#tag:html|Figure 9: Effect of missing selection}}|{{#tag:html|Without selection fitness does not show a clear trend until the boundary values show higher shares. This is most likely due to the equation that gives the boundary values fitness that leaves the interval [0, 1]. The color indicates the share of phages that have a specific fitness (y-axis) at a given time (x-axis).
| |
− | <br>
| |
− | <a href="#parameters">See the full list of parameters.</a>
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | }}
| |
− |
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | <h2>Modeling concentrations over multiple Lagoons</h2>
| |
− | When transfer from one volume to the next is performed, new lagoon can be modeled with starting values calculated from the last lagoons end values.
| |
− | For each concentration from the previous lagoon \(c_{t}\), the concentration in the next lagoon \(c_{t+1}\) is calculated as
| |
− | $$
| |
− | c_{t+1} = \frac{v_{t} }{v_{l} } \cdot c_{t}
| |
− | $$
| |
− | with \(v_{l}\), the volume of a lagoon and \(v_{t}\), the volume that is transferred.
| |
− | If the transfered volume is spinned down before it is added to the new lagoon, the initial value for \(c_{P}\) is calculated this way. The initial concentration of uninfected <i>E. coli</i> is set to the initial cell density. Initial concentrations of infected and phage-producing <i>E. coli</i> are set to zero, because before the transfer, no phages are present in the new lagoon.
| |
− | If the transfer volume is not spinned down, the concentration of infected and phage-producing <i>E. coli</i> are calculated, using the above formula. The initial concentration of uninfected <i>E. coli</i> is the calculated the same way, but the initial cell density is added.
| |
− |
| |
− | In directed evolution the fitness should increase over time. A linear increase in fitness between to given values was implemented to show this. The problem with this approach is its basic assumption being that all phage-producing <i>E. coli</i> are infected by phages with the same fitness.
| |
− | To make the model more plausible, a distribution of fitness was introduced. For a set of discrete fitness values each fitness values share of the phage-producing <i>E. coli</i> population is calculated.
| |
− | That changes the equation for the change in the concentration of phage-producing <i>E. coli</i> to
| |
− |
| |
− | The calculation is for \(N\) different fitness values \(f_{i}\) and their share of the total phage-producing <i>E. coli</i> population \(s_{i}\).
| |
− |
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | <h2>Numeric solutions</h2>
| |
− |
| |
− | The problem described above is a system of four differential equations, of which two ( \(\frac{\partial c_{i} }{\partial t} \:, \: \frac{\partial c_{p} }{\partial t}\) ) are so called delayed differential equations. They contain a term that needs to be evaluated at a timepoint in the past \(t - t_{P}\). A custom script was used to solve the problem numerically, using the explicit Euler method.
| |
− | The basic idea is that from a point in time with all values and all derivatives values given, the next point in time can be calculated by assuming a linear progress between the two points.
| |
− | $$
| |
− | f(t_{n+1}) = f(t_{n}) + (t_{n+1} - t_{n}) \cdot f'(t_{n})
| |
− | $$
| |
− | This is performed for \(c_{u}(t)\), \(c_{i}(t)\), \(c_{p}(t)\) and \(c_{P}(t)\) rotatory, to always have the needed values from \(t_{n}\) ready for \(t_{n+1}\).
| |
− |
| |
− | To explore, how unprecise parameters and noise influence the outcome of the model, a mode was implemented, that adds gaussian noise to all parameters. It uses the function \(n\) that makes a value \(v\) noisy with a random parameter \(r\).
| |
− | $$
| |
− | n(v) = \big(1 - 2r\big) \cdot \sigma_{G} \cdot \sigma_{v} \cdot v, \quad r \in (0, 1)
| |
− | $$
| |
− | Here, \(\sigma_{G}\) is a factor that is the same for all \(v\), \(\sigma_{v}\) is specific for \(v\). This way, it is possible to have one parameter being noisier than another, while being able to tune the noise globally.
| |
− | [Results]
| |
− | }}
| |
− | {{Heidelberg/templateus/Tablebox|
| |
− | Table 2: Additional Variables and Parameters used in the numeric solution of the model |
| |
− | {{#tag:html|
| |
− | <table class="table table-bordered mdl-shadow--4dp" XSSCleaned="overflow-x: scroll !important">
| |
− | <thead>
| |
− | <tr>
| |
− | <th>Symbol</th>
| |
− | <th>Name in Source code</th>
| |
− | <th>Value and Unit</th>
| |
− | <th>Explanation</th>
| |
− |
| |
− | </tr>
| |
− | </thead>
| |
− | <tbody>
| |
− | <tr>
| |
− | <td>\(v_{l}\)</td>
| |
− | <td><code class="python">vl</code></td>
| |
− | <td>[ml]</td>
| |
− | <td>Volume of lagoon</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(t_{l} \)</td>
| |
− | <td><code class="python">tl</code></td>
| |
− | <td>[min]</td>
| |
− | <td>Duration until transfer to the next lagoon</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(c_{u}(t_{0})\)</td>
| |
− | <td><code class="python">ceu0</code></td>
| |
− | <td>[cfu]</td>
| |
− | <td>Concentration of <i>E. coli</i> in a lagoon when M13 phages are transfered to it</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(c_{P}(t_{0})\)</td>
| |
− | <td><code class="python">cp0</code></td>
| |
− | <td>[pfu]</td>
| |
− | <td>Initial concentration of M13 phage in the first lagoon</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(n\)</td>
| |
− | <td><code class="python">epochs</code></td>
| |
− | <td>-</td>
| |
− | <td>Number of epochs that are modeled, one epoch being everything that happens in one particular lagoon</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(s\)</td>
| |
− | <td><code class="python">tsteps</code></td>
| |
− | <td>-</td>
| |
− | <td>Number of time steps for which numeric solutions are calculated, counted per epoch</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(c_{P}^{min}\)</td>
| |
− | <td><code class="python">min_cp</code></td>
| |
− | <td>[pfu]</td>
| |
− | <td>Lower threshold for valid phage titers</td>
| |
− | </tr>
| |
− | <tr>
| |
− | <td>\(c_{P}^{max}\)</td>
| |
− | <td><code class="python">max_cp</code></td>
| |
− | <td>[pfu]</td>
| |
− | <td>Upper threshold for valid phage titers</td>
| |
− | </tr>
| |
− | </tbody>
| |
− | </table>
| |
− | }}|
| |
− | List of all additional paramters and variables used in the numeric solution of this model. When possible values are given.
| |
− | }}
| |
− | {{Heidelberg/templateus/Imagebox|
| |
− | https://static.igem.org/mediawiki/2017/8/88/T--Heidelberg--2017_modeling-graphical-abstract.svg|
| |
− | Fig: 1a Numeric solution calculated with explicit Euler approach|
| |
− | {{#tag:html|
| |
− | Logarithmic plot of the concentrations of all <i>E. coli</i> populations cE, uninfected <i>E. coli</i> ceu, infected <i>E. coli</i> cei, phage-producing <i>E. coli</i> cep and M13 phage cP
| |
− | }}|
| |
− | pos = left
| |
− | }}
| |
− | {{Heidelberg/templateus/Imagebox|
| |
− | https://static.igem.org/mediawiki/2017/8/88/T--Heidelberg--2017_modeling-graphical-abstract.svg|
| |
− | Fig: 1b Numeric solution calculated with explicit Euler approach|
| |
− | {{#tag:html|
| |
− | Non-logarithmic plot of the derivatives of concentrations of all <i>E. coli</i> populations cE, uninfected <i>E. coli</i> ceu, infected <i>E. coli</i> cei, phage-producing <i>E. coli</i> cep and M13 phage cP
| |
− | }}|
| |
− | pos = left
| |
− | }}
| |
− | {{Heidelberg/templateus/Imagebox|
| |
− | https://static.igem.org/mediawiki/2017/8/88/T--Heidelberg--2017_modeling-graphical-abstract.svg|
| |
− | Fig: 1c First derivative of concentrations calculated with explicit Euler approach|
| |
− | {{#tag:html|
| |
− | Logarithmic plot of the concentrations of all <i>E. coli</i> populations cE, uninfected <i>E. coli</i> ceu, infected <i>E. coli</i> cei, phage-producing <i>E. coli</i> cep and M13 phage cP
| |
− | }}|
| |
− | pos = left
| |
− | }}
| |
− | {{Heidelberg/templateus/Imagesection|
| |
− | https://static.igem.org/mediawiki/2017/8/88/T--Heidelberg--2017_modeling-graphical-abstract.svg|
| |
− | Fig: 2 Numeric solution for a range of values for \(t_{l}\) and for \(v_{t}\)|
| |
− | {{#tag:html|
| |
− | All combinations of setups for the two ranges were calculated. The number of epochs plotted is counted until either the phage titer is less than a minimal threshold (orange) or larger than a maximum threshold (blue)
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/templateus/Contentsection|
| |
− | {{#tag:html|
| |
− | <h1 id="parameters">Parameters used for the figures</h1>
| |
− | {{Heidelberg/accpanel|#005493|
| |
− | {{Heidelberg/accord|Figure 1, 3 - 20 % fitness|{{#tag:html|<code>
| |
− | 'capacity': 1000000000.0,
| |
− | 'ceu0': 100000000.0,
| |
− | 'cp0': 100000000.0,
| |
− | 'epochs': 1,
| |
− | 'f0': 0.2,
| |
− | 'f_prec': 21,
| |
− | 'fend': 1.0,
| |
− | 'fitnessmode': 'dist',
| |
− | 'ftype': 'const',
| |
− | 'growth_mode': 'exp',
| |
− | 'k': 3e-11,
| |
− | 'max_cp': 2000000000.0,
| |
− | 'min_cp': 100000.0,
| |
− | 'mumax': 16.667,
| |
− | 'mutation_dist': 'norm',
| |
− | 'noisy': 0.0,
| |
− | 'phageonly': 'True',
| |
− | 'plot_dist': 'True',
| |
− | 'sigma': 0.0,
| |
− | 'skewness': 1.0,
| |
− | 'ti': 30,
| |
− | 'tl': 60,
| |
− | 'to_mutate': 0.0,
| |
− | 'tp': 40,
| |
− | 'tpp': 10,
| |
− | 'tsteps': 100,
| |
− | 'tu': 20,
| |
− | 'vl': 20,
| |
− | 'vt': 1
| |
− | </code>}}
| |
− | |fig1}}
| |
− | {{Heidelberg/accord|Figure 2 - 100 % fitness|{{#tag:html|<code>
| |
− | 'capacity': 1000000000.0,
| |
− | 'ceu0': 100000000.0,
| |
− | 'cp0': 100000000.0,
| |
− | 'epochs': 1,
| |
− | 'f0': 1.0,
| |
− | 'f_prec': 21,
| |
− | 'fend': 1.0,
| |
− | 'fitnessmode': 'const',
| |
− | 'ftype': 'const',
| |
− | 'growth_mode': 'exp',
| |
− | 'k': 3e-11,
| |
− | 'max_cp': 2000000000.0,
| |
− | 'min_cp': 100000.0,
| |
− | 'mumax': 16.667,
| |
− | 'mutation_dist': 'norm',
| |
− | 'noisy': 0.0,
| |
− | 'phageonly': 'True',
| |
− | 'plot_dist': 'False',
| |
− | 'sigma': 0.001,
| |
− | 'skewness': 1.0,
| |
− | 'ti': 30,
| |
− | 'tl': 60,
| |
− | 'to_mutate': 0.0,
| |
− | 'tp': 40,
| |
− | 'tpp': 10,
| |
− | 'tsteps': 100,
| |
− | 'tu': 20,
| |
− | 'vl': 20,
| |
− | 'vt': 1
| |
− | </code>}}
| |
− | |fig2}}
| |
− | {{Heidelberg/accord|Figure 4 - Distributional fitness 1 h|{{#tag:html|<code>
| |
− | 'capacity': 1000000000.0,
| |
− | 'ceu0': 100000000.0,
| |
− | 'cp0': 100000000.0,
| |
− | 'epochs': 1,
| |
− | 'f0': 0.2,
| |
− | 'f_prec': 21,
| |
− | 'fend': 1.0,
| |
− | 'fitnessmode': 'dist',
| |
− | 'ftype': 'const',
| |
− | 'growth_mode': 'exp',
| |
− | 'k': 3e-11,
| |
− | 'max_cp': 2000000000.0,
| |
− | 'min_cp': 100000.0,
| |
− | 'mumax': 16.667,
| |
− | 'mutation_dist': 'norm',
| |
− | 'noisy': 0.0,
| |
− | 'phageonly': 'True',
| |
− | 'plot_dist': 'True',
| |
− | 'sigma': 0.0,
| |
− | 'skewness': 1.0,
| |
− | 'ti': 30,
| |
− | 'tl': 60,
| |
− | 'to_mutate': 0.0,
| |
− | 'tp': 40,
| |
− | 'tpp': 10,
| |
− | 'tsteps': 100,
| |
− | 'tu': 20,
| |
− | 'vl': 20,
| |
− | 'vt': 1
| |
− | </code>}}
| |
− | |fig4}}
| |
− | {{Heidelberg/accord|Figure 5, 6, 7 - Distributional fitness 6.5 h|{{#tag:html|<code>
| |
− | 'capacity': 1000000000.0,
| |
− | 'ceu0': 100000000.0,
| |
− | 'cp0': 100000000.0,
| |
− | 'epochs': 1,
| |
− | 'f0': 0.2,
| |
− | 'f_prec': 21,
| |
− | 'fend': 1.0,
| |
− | 'fitnessmode': 'dist',
| |
− | 'ftype': 'const',
| |
− | 'growth_mode': 'logistic',
| |
− | 'k': 3e-11,
| |
− | 'max_cp': 2000000000.0,
| |
− | 'min_cp': 100000.0,
| |
− | 'mumax': 16.667,
| |
− | 'mutation_dist': 'norm',
| |
− | 'noisy': 0.0,
| |
− | 'phageonly': 'True',
| |
− | 'plot_dist': 'True',
| |
− | 'sigma': 0.1,
| |
− | 'skewness': 1.0,
| |
− | 'ti': 30,
| |
− | 'tl': 400,
| |
− | 'to_mutate': 0.1,
| |
− | 'tp': 40,
| |
− | 'tpp': 10,
| |
− | 'tsteps': 2000,
| |
− | 'tu': 20,
| |
− | 'vl': 20,
| |
− | 'vt': 1
| |
− | </code>}}
| |
− | |fig5_6_7}}
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | }}
| |
− | {{Heidelberg/references2
| |
− | }}
| |
− | {{Heidelberg/footer
| |
− | }}
| |