Team:British Columbia/Consortia

From 2012.igem.org

(Difference between revisions)
 
(67 intermediate revisions not shown)
Line 3: Line 3:
<html>
<html>
<font face=arial narrow size=5><b>Modeling Microbial Consortia: The Auxotroph Approach</b></font></br><font face=arial narrow>
<font face=arial narrow size=5><b>Modeling Microbial Consortia: The Auxotroph Approach</b></font></br><font face=arial narrow>
-
 
<H1 align="center">
<H1 align="center">
<iframe width="640" height="480" src="https://static.igem.org/mediawiki/2012/1/1f/Model_animation.swf" frameborder="0" allowfullscreen></iframe>
<iframe width="640" height="480" src="https://static.igem.org/mediawiki/2012/1/1f/Model_animation.swf" frameborder="0" allowfullscreen></iframe>
</H1>
</H1>
-
To gain a predictive understanding of consortium dynamics in the wet lab, we chose to model a system of simple auxotrophic interdependence. This system also enables us to establish a rapid foundation for which to conduct preliminary model refinements. </br></br>
+
There is a large potential combinatorial space for optimizing and tuning a three-member microbial consortium with auxotrophic interdependence. In order to help address this concern, we set to develop a computational framework to help guide experimental decisions. <b>Our model attempts to develop a predictive understanding of auxotrophic interdependence in a three-member microbial consortium.</b> As it was important for us to be able to predict growth kinetics based on measurable, empirical properties, as well as to develop a mathematically and experimentally tractable system, we decided to base our model on Monod kinetics. </br></br>
-
The three interdependent <i>E. coli</i> auxotrophs studied in our project are <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i>. These three strains are deficient in the production of the amino acids tryptophan, methionine, and tyrosine, respectively. Thus, in order for each strain to survive, they must exist in the context of a consortium. Our model is designed to predict the growth and survival of such a system, and is based on the measured amino acid excretion rates under basal genomic expression. The model is written such that it can be easily updated when specific tuning of the amino acid production rates is desired (for example, by introducing induction systems for amino acid production <i>in trans</i>), rendering it ideal for modeling tuned and un-tuned consortium dynamics. </br></br>
+
The Monod equation, models the growth of microorganisms in aqueous environments. The underlying assumption is that the growth rates are dependent on the concentration of a limiting nutrient.  This equation relates the specific growth rate (µ<sub>g</sub>, the specific growth rate of microorganisms) to the maximum growth rate (µ<sub>m</sub>), the saturation constant (or half-velocity constant, K<sub>s</sub>) as a function of the concentration of the limiting substrate (S) [1]. <br/><br/>
-
The key assumption for this model is that the tryptophan, tethionine, and tyrosine are the only growth limiting substrates for the <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> <i>E. coli</i> knock outs respectively.</br></br>
+
<p align=center><img src="https://static.igem.org/mediawiki/2012/b/b1/British_Columbia_2012_MonodEquation.png"> </p>
-
One important equation which has been incorporated into our model is the Monod equation. This equation is most commonly used to model microbial growth and has been shown to fit a large variety of empirical data[1]. In addition, it shares the key assumption described above. This equation relates the specific growth rate (µ<sub>g</sub>, the increase in cell mass per unit time) as function of the maximum growth rate (µ<sub>m</sub>), and the concentration of a limiting substrate (S). The equation is written as follows:</br></br>
+
The three interdependent <i>E. coli</i> auxotrophs used in our project are <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i>. Each of these strains is missing a gene critical in the respective amino acid biosynthetic pathway. Each of these amino acids are treated as the growth limiting substrates. The model is extends on the work recently presented by Kerner and colleagues [2] and attempts to predict the growth and survival of a three-member consortia.<br/><br/>  
-
<p align=center><img src="https://static.igem.org/mediawiki/2012/b/b1/British_Columbia_2012_MonodEquation.png"></p>
+
It takes into account a number of factors:<br/>
 +
<ol>
 +
<li>The constitutive production of each required amino acid by the two remaining natural prototrophs</li>
 +
<li>The inducible production of each required amino acid by a recombinant prototroph, and</li>
 +
<li>The uptake of amino acids in each auxotroph.</li>
 +
</ol>
 +
<br/><br/>
 +
The following sections detail the mathematical foundation of the model, the experimental measurement of the necessary constants, the MATLAB implementation and some preliminary results.<br/><br/>
-
where K<sub>S</sub> is the limiting substrate concentration when the specific growth rate is at half maximum (K<sub>S</sub> = S when µ<sub>g</sub> = µ<sub>m</sub>/2). K<sub>S</sub> is also known as the <i>saturation constant</i> or <i>half-velocity constant</i>[1]. </br></br>
+
<font face=arial narrow size=4><b>Equations and Constants</b></font></br><font face=arial narrow></br>
-
<font face=arial narrow size=5><b>Equations and Constants</b></font></br><font face=arial narrow>
+
We proposed the following fundamental equations for our consortium model. In this model, each auxotrophic strain is denoted with a superscript minus (i.e. <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> are denoted trpA<sup>-</sup>, metA<sup>-</sup>, and tryA<sup>-</sup>, respectively); [Trp], [Met], and [Tyr] represent the concentrations of tryptophan, methionine, and tyrosine; ODtrpA<sup>-</sup>, ODmetA<sup>-</sup>, and ODtyrA<sup>-</sup> represent the optical densities of the <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> strains; a1, a2, and a3 are the consumption constants with respect to changes in ODtrpA<sup>-</sup>, ODmetA<sup>-</sup>, and ODtyrA<sup>-</sup>, respectively; µtrpA<sup>-</sup>, µmetA<sup>-</sup>, µtyrA<sup>-</sup> are the specific growth rates of the <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> strains; µMaxtrpA<sup>-</sup>, µMaxmetA<sup>-</sup>, µMaxtyrA<sup>-</sup> are the maximum growth rates of the <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> strains; and KstrpA<sup>-</sup>, KsmetA<sup>-</sup>, KStyrA<sup>-</sup> are the <i>half-velocity constants</i> of the <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> strains.  The terms and constants of this equation will be discussed in further detail later.</br></br>
-
 
+
-
Applying the Monod kinetic model, we sought out to measure three variables: the concentration of tryptophan, methionine, and tyrosine in the media available for each specific auxotroph. We were also interested in how these concentrations vary with respect to time. </br></br>
+
-
 
+
-
As there is very limited initial availability of each amino acid in the media, <a href="https://2012.igem.org/Team:British_Columbia/ProjectConsortia">the ability of each auxotroph to grow in co-culture</a> demonstrated that the amino acids necessary for growth are being produced and exported from the cell, and that each auxotroph is feeding on the amino acids produced by the other cells in the consortium. For the sake of the model, we assumed that the environmentally released tryptophan, methionine, and tyrosine were only consumed by the respective auxotrophic strain, and that use of this amino acid was funnelled only into cell growth (i.e. increases in amino acid consumption are attributed to changes in cell growth and not other factors, such as cell maintenance).</br></br>
+
-
 
+
-
Combining the above assumptions with Monod kinetics, we proposed the following fundamental equations for our consortium model. In this model, each auxotrophic strain is denoted with a superscript minus (i.e. <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> are denoted trpA<sup>-</sup>, metA<sup>-</sup>, and tryA<sup>-</sup>, respectively); [Trp], [Met], and [Tyr] represent the concentrations of tryptophan, methionine, and tyrosine; ODtrpA<sup>-</sup>, ODmetA<sup>-</sup>, and ODtyrA<sup>-</sup> represent the optical densities of the <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> strains; a1, a2, and a3 are the consumption constants with respect to changes in ODtrpA<sup>-</sup>, ODmetA<sup>-</sup>, and ODtyrA<sup>-</sup>, respectively; µtrpA<sup>-</sup>, µmetA<sup>-</sup>, µtyrA<sup>-</sup> are the specific growth rates of the <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> strains; µMaxtrpA<sup>-</sup>, µMaxmetA<sup>-</sup>, µMaxtyrA<sup>-</sup> are the maximum growth rates of the <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> strains; and KstrpA<sup>-</sup>, KsmetA<sup>-</sup>, KStyrA<sup>-</sup> are the <i>half-velocity constants</i> of the <i>ΔtrpA</i>, <i>ΔmetA</i>, and <i>ΔtyrA</i> strains.  The terms and constants of this equation will be discussed in further detail later.</br></br>
+
<p align=center><img src="https://static.igem.org/mediawiki/2012/f/f1/British_Columbia_2012_governing_Equation.png"></p>
<p align=center><img src="https://static.igem.org/mediawiki/2012/f/f1/British_Columbia_2012_governing_Equation.png"></p>
-
Please note that: equation (7), (8), and (9) can be substituted into equation (4), (5), and (6) directly, and equation (4), (5), (6) after the substitution can be further substituted into equation (1), (2), and (3) to simplify the code further. The overall three equations shown later in the <a href="https://2012.igem.org/Team:British_Columbia/Consortia#Matlab_Code">Matlab Code</a> section is based on the described substitution. It is indicated here for viewers' convenience of following the Matlab code later. </br></br>
+
Please note that: equation (7), (8), and (9) can be substituted into equation (4), (5), and (6) directly, and equation (4), (5), (6) after the substitution can be further substituted into equation (1), (2), and (3) to simplify the code further. The overall three equations shown later in the Matlab Code section is based on the described substitution. It is indicated here for viewers' convenience of following the Matlab code later. </br></br>
In the above equations, some of the key constants for the Monod Kinetics are obtained through analyzing the growth curves in a 96-well plate, with varying amino acid concentrations. Characteristic growth rates were observed and plotted: </br></br>
In the above equations, some of the key constants for the Monod Kinetics are obtained through analyzing the growth curves in a 96-well plate, with varying amino acid concentrations. Characteristic growth rates were observed and plotted: </br></br>
-
<p align=center><img src="https://static.igem.org/mediawiki/2012/3/3d/GrowthRatesAA_university_of_british_columbia.png"></br><b>Figure 1: Monoculture Growth Rates at various Limiting Amino Acid Concentrations</br></br>
+
Applying the Monod kinetic model, we sought out to measure three variables: the concentration of tryptophan, methionine, and tyrosine in the media available for each specific auxotroph. We were also interested in how these concentrations vary with respect to time. </br></br>
-
<img src="https://static.igem.org/mediawiki/2012/0/05/GrowthRatesAA_LOG_university_of_british_columbia.png"></br>
+
-
Figure 2: Log Scale of Monoculture Growth Rates at various Limiting Amino Acid Concentrations</b></br></br>
+
-
 
+
-
Note: we used lower amino acid concentrations as well, however we found out that when concentration is below 1E<sup>-7</sup> M, we observed no significant overnight growth of the cells. For a detailed protocol, please visit <a href="https://2012.igem.org/Team:British_Columbia/Protocols/Monod">here</a>.</br></br>
+
-
 
+
-
 
+
-
Based on Figures 1 and 2, the key constants, such as maximum growth rates, and half-velocity constants, for each auxotroph were obtained [1]:</br></br><p align=center>
+
-
<img src="https://static.igem.org/mediawiki/2012/b/b8/British_Columbia_2012_constants_from_GrowthRates.png"></p>
+
-
 
+
-
As discussed in the beginning of this section, we assumed that the amino acid consumption is solely dependent on the cell growth rate. In order to find out the consumption rate constants, (a1, a2, and a3), we need to find out a way to measure the amino acid concentrations in the media with respect to the change of its OD for each auxotroph. To do this, we need to find a way to measure media amino acid concentrations. With no good access to HPLC, we noticed in previous experiments that each of the knockout monocultures will reach to a certain final OD at a different known concentration of amino acid. In addition, recently published paper: ''A Programmable <i>Escherichia coli</i> Consortium via Tunable Symbiosis'', Kerner A et. al (2012) confirmed that there is indeed a relationship between the final auxotroph ODs with the environmental amino acid concentrations [2]. We thus generated a calibration curve to relate the limiting amino acid concentrations to their final OD readings. We based this on our own wet lab data shown in the figures below: </br></br></html>
+
-
 
+
-
[[file: ODcalibrationTrp_university_of_british_columbia.png|center| 500x700px]]
+
-
 
+
-
'''Figure 3: TrpA Auxotroph Final OD and Trp Concentration Calibration Curve'''
+
-
 
+
-
 
+
-
[[file: ODcalibrationMet_university_of_british_columbia.png|center| 500x700px]]
+
-
 
+
-
'''Figure 4: MetA Auxotrph Final OD and Met Concentration Calibration Curve'''
+
-
 
+
-
 
+
-
[[file: ODcalibrationTyr_university_of_british_columbia.png|center| 500x700px]]
+
-
 
+
-
'''Figure 5: TyrA Auxotroph Final OD and Tyr Concentration Calibration Curve'''
+
-
 
+
-
Note: all the data are the result of triplicate measurements, and a detailed protocol can be found [https://2012.igem.org/Team:British_Columbia/Protocols/AArate here]. We then tested the accuracy of one of the calibration curves. The blue dot in Figure 5 is a data value we obtained at a known Tyrosine concentration (5E<sup>-5</sup> M), and it is reasonably close to the predicted curve. This test point suggests that this calibration curve is relevant to our wet lab results, however more experimental data is necessary to confirm the accuracy of the curve.
+
-
 
+
-
We then sought out to find out how the amino acid in the environment is consumed with respect to cell growth.
+
-
 
+
-
The three auxotrphs, Δ''trpA'', Δ''metA'', and Δ''tyrA'', were grown in 50 ml flasks with known initial Tryptophan, Methionine, and Tyrosine concentrations (5E<sup>-5</sup> M), respectively, and 5ml of cell free supernatants at various ODs was isolated. These supernatants served as new 96-well plate media for each knock out cultures with newly added M9-Glucose shots (2% glucose in the well) to ensure the amino acids of interest remained as the limiting substrate for all knock outs. A detailed protocol can be found [https://2012.igem.org/Team:British_Columbia/Protocols/AArate here].
+
-
 
+
-
The cells were grown in a 96-well plate for 15 hours at 37 <sup>o</sup>C, and growth curve data was obtained using a plate reader (most of the monocultures reached stationary phase at this point).
+
-
 
+
-
Based on the calibration curves (Figure 3, 4, 5), the amino acid concentrations in the wells were calculated from the final OD readings, and when corrected with a dilution factor of 5/4 (as we added in the 5X, it was 1/5 of the total well media volume, as described [https://2012.igem.org/Team:British_Columbia/Protocols/AArate here]), we obtained the resultant amino acid concentrations in the supernatant at various auxotroph monoculture densities. Again, with the assumption that the only change in the amino acid concentration in the media is due to cell growth, and as they are specific knock outs, they were not able to release any amino acid into the environment, each auxotrophs' consumption constants with respect to cell growth rate (a1, a2, a3) can be calculated. Their values are as follows:
+
-
 
+
-
[[file: ConsumptionRateConstants_university_of_british_columbia.png|center| 200x300px]]
+
-
 
+
-
 
+
-
Now that we have our consupmtion constants, we were interested in finding out how the other two auxotrophs will contribute to changes in environmental amino acid concentrations. 
+
-
 
+
-
With regards to the behaviour of auxotrophs in coculture under changing amino acid concentrations, the closest assumption we can make is that each auxotroph will behave similarly to the conditions of monoculture. Thus, we used the same calibration curve for relating the final OD to the limiting substrate amino acid concentration in the media. The difference here is that, instead of finding out the corresponding limiting amino acid concentration, e.g., Δ''metA'' media for [Met] measurements, we are interested in measuring the other two non-limiting amino acid concentrations of each knocked out ''E. coli'' auxotrophs, e.g. Δ''metA'' media for [Trp] and [Tyr] concentrations, at various OD readings '''[2]'''. We were then able to derive six functions that relate the change of all amino acid concentrations with respect to time (e.g. d[Trp]/dt), based on two auxotrophs' optical densities (e.g. ODmetA<sup>-</sup> and ODtyrA<sup>-</sup>), as shown below:
+
-
 
+
-
[[file: equation10-15_data_analyzed_data_university_of_british_columbia.png|center| 700x900px]]
+
-
 
+
-
Note: These equations can now be directly substituted into equations (1), (2), and (3), in order to simplify the [https://2012.igem.org/Team:British_Columbia/Consortia#Matlab_Code Matlab Code] section.
+
-
 
+
-
One shortcoming in the use of these equations is their dependency on the accuracy of the calibration curves (Figure 3, 4, and 5), as well as the OD readings, especially when OD readings are low and noisy (< 0.1, nearing the limits of the plate reader's accuracy). 
+
-
 
+
-
One extreme example is equation (15). The raw data are shown below:
+
-
 
+
-
[[file: tyrA_in_metAknockoutssupernatants_university_of_british_columbia.png|center| 900x1000px]]
+
-
 
+
-
'''Figure 6:  Δ''tyrA'' auxotroph growth curve in various Δ''metA'' ODs cell free supernatants in 96-well plate reader environment
+
-
 
+
-
Note: As discussed before, this may lead to inaccuracies in calculation from low OD readings. All data sets are labelled correspondingly, and triplicate measurements are noted by wells 1, 2, and 3. As we can see, there are some distinct differences in the OD readings among the three different supernatant data sets; however, when corrected by focusing on the difference between the initial reading and the final reading with a base adjustment of 0.025 (the lower value used for all the calibration curves), they average roughly the same, with an average OD of 0.03847, 0.04043, and 0.04218, respectively, for ODmet 0.219, 0.546, and 0.764. 
+
-
 
+
-
 
+
-
To illustrate this point more clearly, here is a comparison with another set of growth curve data run in the same plate.
+
-
 
+
-
[[file: tyrA_and_trpA_in_metAknockoutssupernatants_university_of_british_columbia.png|center| 900x1000px]]
+
-
 
+
-
'''Figure 7: Comparison between Δ''trpA'' and Δ''tyrA'' auxotroph growth curve in the same supernatants of Δ''metA'' at its various optical density media.
+
-
 
+
-
Note that all three of the trpA<sup>-</sup> sets of growth curve grew to a much higher OD (reaching about 0.17) at the end of 15 hours and did not reach stationary phase, whereas all tyrA<sup>-</sup> sets grew significantly less, no significant change in OD at the end of the experiment.
+
-
==Matlab Code==
+
<p align=center><img src="https://static.igem.org/mediawiki/2012/3/3d/GrowthRatesAA_university_of_british_columbia.png"></br><b>Figure 1: Monoculture Growth Rates at various Limiting Amino Acid Concentrations.
-
Now with all the key functions and constants approximated, we are able to encode our model into Matlab, where the six key ODE functions can be solved and output the our prediction of population dynamics
+
<p align=center></br></br>These data are fit to the Monod equation to determine the constants listed below.</br></br>
 +
<p align=center><img src="https://static.igem.org/mediawiki/2012/0/05/GrowthRatesAA_LOG_university_of_british_columbia.png"></br>
 +
Figure 2: Log Scale of Monoculture Growth Rates at various Limiting Amino Acid Concentrations.</b></br></br>
-
The code is shown below, which contains a '''detailed step by step instruction''' for '''future iGEM teams or related scientific researches use''', as well as the clarifications of our own code. It is also written is a way that it can be directly copied and pasted into Matlab blank m.files with all the comments in Matlab commenting format already, so that the coder can read the coded instructions and explanations in the coding command window without having to switching between, for example, the matlab and browser windows.
+
</br></br>
-
Of course, copying and pasting the code here is welcomed!
+
<p align=left>Note: we used lower amino acid concentrations as well, however we found out that when concentration is below 1E<sup>-7</sup> M, we observed no significant overnight growth of the cells. For a detailed protocol, please visit <a href="https://2012.igem.org/Team:British_Columbia/Protocols/Monod">here</a>.</br></br>
-
'''Code begins here:'''
+
Based on the fits presented in Figures 1 and 2, the key constants, such as maximum growth rates, and half-velocity constants, for each auxotroph were obtained [1]:</br></br><p align=center>
 +
<img src="https://static.igem.org/mediawiki/2012/b/b8/British_Columbia_2012_constants_from_GrowthRates.png" width=400></p>
-
% input the following commands, which are all in '''bold''', into MATLAB command window, and '''not the m.file''', before you call the ODE function.
+
<p align=left>As discussed in the beginning of this section, we assumed that the amino acid consumption is solely dependent on the cell growth rate. In order to find out the consumption rate constants, (a<sub>1</sub>, a<sub>2</sub>, and a<sub>3</sub>), we need to find out a way to measure the amino acid concentrations in the media with respect to the change of its OD for each auxotroph. To do this, we need to find a way to measure media amino acid concentrations. With no good access to HPLC, we noticed in previous experiments that each of the knockout monocultures will reach to a certain final OD at a different known concentration of amino acid. In addition, recently published paper: ''A Programmable <i>Escherichia coli</i> Consortium via Tunable Symbiosis'', Kerner A et. al (2012) confirmed that there is indeed a relationship between the final auxotroph ODs with the environmental amino acid concentrations [2]. We thus generated a calibration curve to relate the limiting amino acid concentrations to their final OD readings. We based this on our own wet lab data shown in the figures below: </br></br>
-
%firstly, define a time array, set the upper limit to be the time (hr) you want this model to predict. For this model to be accurate, it is advised not to use extreme values.
+
<p align=center><img src="https://static.igem.org/mediawiki/2012/b/be/ODcalibrationMet_university_of_british_columbia.png"width=600>
 +
<p align=left></br><b>Figure 3: Calibration curves used to convert final OD600 to initial amino acid concentration. Standard solutions of known amino acid concentrations were innoculated with the respective auxotroph and grown for 20 hours at 37oC shaken at 200RPM, after which final OD600 were measured. Data were fit to quartic polynomials to inter- polate OD600 readings. Error bars represent standard deviation (n=3).</b></br></br>.  
-
%in our cases, the upper limit is set to 12 as some of the modelling equations are based on 11 hour culture supernatant data. Thus accuracy is expected within 12 hours.
+
<p align=left>We then sought out to find out how the amino acid in the environment is consumed with respect to cell growth. </br></br>
-
%''' >> xspan = [0 12]''';  
+
<p align=left>The three auxotrophs were grown in 50 ml flasks with known initial Tryptophan, Methionine, and Tyrosine concentrations (5E<sup>-5</sup> M), respectively, and 5ml of cell free supernatants at various ODs was isolated. These supernatants served as new 96-well plate media for each knock out cultures with newly added M9-Glucose shots (2% glucose in the well) to ensure the amino acids of interest remained as the limiting substrate for all knock outs. A detailed protocol can be found <a href="https://2012.igem.org/Team:British_Columbia/Protocols/AArate">here</a>. </br></br>
-
%in order to set up the initial conditions, where they corespond to the initial values of y(1), y(2), y(3)..., to y(6)  in our case, and y(n) if you have ''n'' number of ODE equations
+
The cells were grown in a 96-well plate for 15 hours at 37 <sup>o</sup>C, and growth curve data was obtained using a plate reader (most of the monocultures reached stationary phase at this point). </br></br>
-
% >>''' ynot = [1E-7 1E-7 1E-7 0.01 0.01 0.01]';'''  
+
Based on the calibration curves (Figure 3), the amino acid concentrations in the wells were calculated from the final OD readings, and when corrected with a dilution factor of 5/4 (as we added in the 5X, it was 1/5 of the total well media volume, as described <a href="https://2012.igem.org/Team:British_Columbia/Protocols/AArate">here</a>), we obtained the resultant amino acid concentrations in the supernatant at various auxotroph monoculture densities. Again, with the assumption that the only change in the amino acid concentration in the media is due to cell growth, and as they are specific knock outs, they were not able to release any amino acid into the environment, each auxotrophs' consumption constants with respect to cell growth rate (a1, a2, a3) can be calculated. Their values are as follows:  </br></br>
-
% the first three values are the initial values for y(1), y(2), and y(3) respectively, which in out cases are the initial amino acid concentrations, and as we are adding the cells directly into the M9 media without supplementing any amino acids, it is believed to be at very low concentrations, and thus is set to 1E-7 mole/L.  
+
<p align=center><img src="https://static.igem.org/mediawiki/2012/1/1f/ConsumptionRateConstants_university_of_british_columbia.png"width=600></p>
-
% the remaining three values are the initial conditions for y(4), y(5), and y(6), which are the initial cell ODs in out case, and they are all set to 0.01, which is based on the lower values of the OD plate readings after correcting with blanks.  
+
</br><b>Figure 4. Amino acid consumption measured from auxotroph cultures in minimial media spiked with an initial concentration of 0.15 mM of the required amino acid. Linear regression was used to find the following consumption rates: Trp: 0.304 ± 0.009 mM/OD (a1), Met: 0.115 ± 0.047 mM/OD (a2), Tyr: 0.143 ± 0.020 mM/OD (a3). Error bars represent 95% confidence interval as determined by regression in the calibration curves. </br></br>
-
%Then RUN THE FUNCTION
+
<p align=left>
 +
Now that we have our consupmtion constants, we were interested in finding out how the other two auxotrophs will contribute to changes in environmental amino acid concentrations.  </br></br>
-
% >>'''[X,Y] = ode45(@UBCiGEM2012_ConsortiaModel,xspan,ynot);'''  
+
With regards to the behaviour of auxotrophs in coculture under changing amino acid concentrations, the closest assumption we can make is that each auxotroph will behave similarly to the conditions of monoculture. Thus, we used the same calibration curve for relating the final OD to the limiting substrate amino acid concentration in the media. The difference here is that, instead of finding out the corresponding limiting amino acid concentration, e.g., <i>ΔmetA</i> media for [Met] measurements, we are interested in measuring the other two non-limiting amino acid concentrations of each knocked out <i>E. coli</i> auxotrophs, e.g. <i>ΔmetA</i> media for [Trp] and [Tyr] concentrations, at various OD readings [2]. We were then able to derive six functions that relate the change of all amino acid concentrations with respect to time (e.g. d[Trp]/dt), based on two auxotrophs' optical densities (e.g. ODmetA<sup>-</sup> and ODtyrA<sup>-</sup>), as shown below: </br></br>
-
% this takes the function name in your m.file, the range of your interest, and the initial conditions which is just defined, respectively
+
<p align=center><img src="https://static.igem.org/mediawiki/2012/f/f0/ODcalibrationTrp_university_of_british_columbia.png"></br><b>
-
%Note: have to make sure that the name is exactly the same as the function name in your m.file for it to be able to run correctly.  
+
<p align=center><img src="https://static.igem.org/mediawiki/2012/b/b7/Equation10-15_data_analyzed_data_university_of_british_columbia.png">
 +
</p>
 +
Note: These equations can now be directly substituted into equations (1), (2), and (3), in order to simplify the Matlab Code section.</br></br>
 +
<p align=left>
 +
One shortcoming in the use of these equations is their dependency on the accuracy of the calibration curves (Figure 3, 4, and 5), as well as the OD readings, especially when OD readings are low and noisy (< 0.1, nearing the limits of the plate reader's accuracy).  </br></br>
-
'''%the following code is for the actual mfile.'''
+
For example, one of the experimental raw data obtained are shown below: </br></br>
 +
<p align=center><img src="https://static.igem.org/mediawiki/2012/2/2c/TyrA_in_metAknockoutssupernatants_university_of_british_columbia.png" width=800>
 +
</br><b>Figure 5: <i>ΔtyrA</i> auxotroph growth curve in various <i>ΔmetA</i> ODs cell free supernatants in 96-well plate reader environment. </b></br></br>.  
-
% 1) Declare the name of the function:
+
<p align=left>
 +
Note: As discussed before, this may lead to inaccuracies in calculation from low OD readings. All data sets are labelled correspondingly, and triplicate measurements are noted by wells 1, 2, and 3. As we can see, there are some distinct differences in the OD readings among the three different supernatant data sets; however, when corrected by focusing on the difference between the initial reading and the final reading with a base adjustment of 0.025 (the lower value used for all the calibration curves), they average roughly the same, with an average OD of 0.03847, 0.04043, and 0.04218, respectively, for ODmet 0.219, 0.546, and 0.764.  </br></br>
-
function dy = UBCiGEM2012_ConsortiaModel(t,y);
 
-
% 2) define all your ODE variables clearly for your own understanding as they can get quite confusing if you don't.  
+
To illustrate this point more clearly, here is a comparison with another set of growth curve data run in the same plate.</br></br>
 +
<p align=center><img src="https://static.igem.org/mediawiki/2012/0/05/TyrA_and_trpA_in_metAknockoutssupernatants_university_of_british_columbia.png" width=800></br><b>
 +
Figure 6: Comparison between <i>ΔtrpA</i> and <i>ΔtyrA</i> auxotroph growth curve in the same supernatants of <i>ΔmetA</i> at its various optical density media.</p></b>
 +
<p align=left>
 +
Note that all three of the trpA<sup>-</sup> sets of growth curve grew to a much higher OD (reaching about 0.17) at the end of 15 hours and did not reach stationary phase, whereas all tyrA<sup>-</sup> sets grew significantly less, no significant change in OD at the end of the experiment.</br></br>
-
% in our case:
 
-
'''% y(1)  = [Trp];
+
<font face=arial narrow size=4><b>Matlab Code</b></font></br><font face=arial narrow></br>
-
'''% dy(1) = d[Trp]/dt
+
Now with all the key functions and constants approximated, we are able to encode our model into Matlab, where the six key ODE functions can be solved and output the our prediction of population dynamics. </br></br>
-
'''% y(2) = [Met];
+
The code is shown below, which contains a detailed step by step instruction for future iGEM teams or related scientific researches use, as well as the clarifications of our own code. It is also written is a way that it can be directly copied and pasted into Matlab blank m.files with all the comments in Matlab commenting format already, so that the coder can read the coded instructions and explanations in the coding command window without having to switching between, for example, the matlab and browser windows. </br></br>
-
'''% dy(2) = d[Met]/dt;
+
Of course, copying and pasting the code here is welcomed!  </br></br>
 +
</br></br>
 +
Code begins here:</br></br>
 +
% input the following commands, which are all in bold, into MATLAB command window, and not the m.file, before you call the ODE function. </br></br>
-
'''% y(3) = [Tyr];
+
%firstly, define a time array, set the upper limit to be the time (hr) you want this model to predict. For this model to be accurate, it is advised not to use extreme values. </br></br>
-
'''% dy(3) = d[Tyr]/dt;
+
%in our cases, the upper limit is set to 12 as some of the modelling equations are based on 11 hour culture supernatant data. Thus accuracy is expected within 12 hours. </br></br>
-
'''% y(4)  = [OD_trpA-];
+
% xspan = [0 12]; </br></br>
-
'''% dy(4) = d[OD_trpA-]/dt;
+
%in order to set up the initial conditions, where they corespond to the initial values of y(1), y(2), y(3)..., to y(6) in our case, and y(n) if you have n number of ODE equations </br></br>
-
'''% y(5)  = [OD_tyrA-];
+
% ynot = [4E-5 4E-5 4E-5 0.05 0.05 0.05]'; </br></br>
-
'''% dy(5) = d[OD_tyrA-]/dt;
+
% the first three values are the initial values for y(1), y(2), and y(3) respectively, which in out cases are the initial amino acid concentrations, and as we are adding the cells directly into the M9 media without supplementing any amino acids, it is believed to be at a low concentrations, though there will be some left over amino acids within the living initial cells, and thus is set to 4E-5 mole/L. </br></br>
-
'''% y(6) = [OD_metA-];
+
% the remaining three values are the initial conditions for y(4), y(5), and y(6), which are the initial cell ODs in out case, and they are all set to 0.05, which is the initial OD reading we obtained after we innoculated the culture, with the assumption that all the cells are still alive. </br></br>
-
'''% dy(6) = d[OD_metA-]/dt;'''
+
%Then RUN THE FUNCTION </br></br>
 +
% [X,Y] = ode45(@UBCiGEM2012_ConsortiaModel,xspan,ynot); </br></br>
-
% 3) define your constants first that will not depend on variables
+
% this takes the function name in your m.file, the range of your interest, and the initial conditions which is just defined, respectively </br></br>
-
% in our case, it was all measured through our own wet lab data and is explained in the previous section
+
%Note: have to make sure that the name is exactly the same as the function name in your m.file for it to be able to run correctly. </br></br>
-
%define maximum growth rate constants
+
%the following code is for the actual mfile. </br></br>
-
u_maxtrpA = 0.2442;      % units = hr-1
+
% 1) Declare the name of the function: </br></br>
-
u_maxmetA = 0.5524;   % units = hr-1
+
function dy = UBCiGEM2012_ConsortiaModel(t,y); </br></br>
-
u_maxtyrA = 0.3332;      % units = hr-1
+
% 2) define all your ODE variables clearly for your own understanding as they can get quite confusing if you don't. </br></br>
 +
% in our case: </br></br>
-
%define half-velocity constants
+
% y(1) = [Trp]; </br></br>
-
Ks_trpA = 1E-7;       % units = M
+
% dy(1) = d[Trp]/dt; </br></br>
-
Ks_metA = 5E-6;     % units = M
+
% y(2) = [Met]; </br></br>
-
Ks_tyrA = 8.36E-8;   % units = M
+
% dy(2) = d[Met]/dt; </br></br>
 +
% y(3) = [Tyr]; </br></br>
-
%define the consumption rate constants
+
% dy(3) = d[Tyr]/dt; </br></br>
-
a1 = 4.08E-4; %units= M/OD
+
% y(4) = [OD_trpA-]; </br></br>
-
a2 = 1.44E-4; %units= M/OD
+
% dy(4) = d[OD_trpA-]/dt; </br></br>
-
a3 = 1.23E-5; %units= M/OD
+
% y(5) = [OD_tyrA-]; </br></br>
 +
% dy(5) = d[OD_tyrA-]/dt; </br></br>
-
% 4) write out ODE CODE, suggest to write out all equations on paper first, as they are a lot more clear than coding them directly, and will reduce the chance for you to make error why coding significantly.
+
% y(6) = [OD_metA-]; </br></br>
-
dy = zeros(6,1);
+
% dy(6) = d[OD_metA-]/dt; </br></br>
-
dy(1) = ((1e-8)*(exp(1))^(16.586*y(4)))  +        ((-0.023*(y(5))^2)+0.021*y(5)-3.5e-3) - a1*(u_maxtrpA*(y(1))/(Ks_trpA+y(1)))*y(4);
+
% 3) define your constants first that will not depend on variables </br></br>
-
dy(2) = ((9e-6)*(y(6))^2-(7e-6)*y(6)+1e-6)  +  (((2e-6)*(y(4))^2)-(2e-6)*y(4)+9e-7)    - a2*(u_maxmetA*(y(2))/(Ks_metA+y(2)))*y(5);
+
% in our case, it was all measured through our own wet lab data and is explained in the previous section </br></br>
-
dy(3) = ((3e-7)*(y(4))^2-(8e-7)*y(4)+4e-7)  +  (((1e-6)*(y(5))^2)-(2e-6)*y(5)+6e-7)    - a3*(u_maxtyrA*(y(3))/(Ks_tyrA+y(3)))*y(6);
+
%define maximum growth rate constants </br></br>
-
dy(4) = (u_maxtrpA*y(1))/(Ks_trpA+y(1))*(y(4));
+
u_maxtrpA = 0.23; % units = hr-1 </br></br>
-
dy(5) = (u_maxmetA*y(2))/(Ks_metA+y(2))*(y(5));
+
u_maxmetA = 0.34; % units = hr-1 </br></br>
-
dy(6) = (u_maxtyrA*y(3))/(Ks_tyrA+y(3))*(y(6));
+
u_maxtyrA = 0.28; % units = hr-1 </br></br>
-
% note: '''For easy coding and checking purposes, all this equations are exactly the same as the one shown in equation (1), (2), and (3) for dy(1), dy(2), and dy(3) respectively, with also the same arrangements of each equation term within them.'''
+
%define half-velocity constants </br></br>
-
% and '''Please also note:''' these equation has been derived with direct simple substitution of equations, where equation (4), (5), (6), (7), (8), (9), (10), (11), (12), (13), (14) and (15) have been substituted into the equation (1), (2) and (3).  
+
Ks_trpA = 3.30E-7; % units = M </br></br>
-
%if you want, you can choose to plot diagrams and display the predicting dynamics within the m.file or manually plot the arrays of your interests in command window
+
Ks_metA = 5.10E-6; % units = M </br></br>
-
%For example, for this project, we are interesting in predicting the ODs of each auxotrophs, thus, we manually plotted values in y(4), y(5), and y(6) (which again, are the OD values of each auxotrophs) agaisnt time, by typing the following in the command window after run the ODE45 functions:
+
Ks_tyrA = 8.50E-7; % units = M </br></br>
-
'''%>>plot(X,Y(:,4:6)) '''
+
%define the consumption rate constants </br></br>
 +
a1 = 3.05E-4; %units= M/OD trp</br></br>
-
'''End of the m.file'''
+
a2 = 1.15E-4; %units= M/OD met</br></br>
 +
a3 = 1.4E-4; %units= M/OD tyr</br></br>
-
'''Note: I will indicate here that the direct translation of the previous discussed equations with simple substitutions at either the beginning or the end of this section'''
+
% 4) write out ODE CODE, suggest to write out all equations on paper first, as they are a lot more clear than coding them directly, and will reduce the chance for you to make error why coding significantly. </br></br>
-
==Simulation Results, Analysis and Future Work==
+
dy = zeros(6,1); </br></br>
-
When the [https://2012.igem.org/Team:British_Columbia/Consortia#Matlab_Code Matlab Code] was run, it generated a graphic result predicting the population dynamics without inducing, shown below:
+
dy(1) = 2.5E-7 + 7.2E-8 - a1*(u_maxtrpA*(y(1))/(Ks_trpA+y(1)))*y(4); </br></br>
 +
dy(2) = 1.7E-7 + 5.1E-8 - a2*(u_maxmetA*(y(2))/(Ks_metA+y(2)))*y(5); </br></br>
-
[[file: 12hours_nomordificationprediction_university_of_british_columbia.png|centre| 700x700px]]
+
dy(3) = -3.6E-8 + 1.7E-6 - a3*(u_maxtyrA*(y(3))/(Ks_tyrA+y(3)))*y(6); </br></br>
-
'''Figure 8. Population Dynamics Prediction within 12-hour Confidence Range'''
+
dy(4) = (u_maxtrpA*y(1))/(Ks_trpA+y(1))*(y(4)); </br></br>
 +
dy(5) = (u_maxmetA*y(2))/(Ks_metA+y(2))*(y(5)); </br></br>
-
[[file: 16hours_nomordificationprediction_university_of_british_columbia.png|centre| 700x700px]]
+
dy(6) = (u_maxtyrA*y(3))/(Ks_tyrA+y(3))*(y(6)); </br></br>
-
'''Figure 9. Population Dynamics Prediction for 16 hours'''
+
% note: For easy coding and checking purposes, all this equations are exactly the same as the one shown in equation (1), (2), and (3) for dy(1), dy(2), and dy(3) respectively, with also the same arrangements of each equation term within them. </br></br>
-
+
-
As we can see here, the prediction is no longer reasonable as the Δ''tyrA'' OD shoots off into 1.8 after 16 hours of incubation.  
+
-
'''However''', as we explained in the end of [https://2012.igem.org/Team:British_Columbia/Consortia#Equations_and_Constants Equation and Constants] section, equation (15) can be an outlier equation for this modelling, and the [Tyr] concentration is proven to be so low in the environment that we can barely observe any growth. Thus, we were very interested in finding out how the predictions would be different if we removed equation (15) from the simulation code, and assumed the environmental tyrosine concentration had no relationship with Δ''metA'' growth. The result of both 12 and 16 hour predictions are shown in Figures 10, and 11.  
+
% and Please also note: these equation has been derived with direct simple substitution of equations, where equation (4), (5), (6), (7), (8), (9), (10), (11), (12), (13), (14) and (15) have been substituted into the equation (1), (2) and (3). </br></br>
-
[[file: 12hours_Withmordificationpredictionno32_university_of_british_columbia.png|centre| 700x700px]]
+
%if you want, you can choose to plot diagrams and display the predicting dynamics within the m.file or manually plot the arrays of your interests in command window </br></br>
-
'''Figure 10. Population Dynamics 12-hour Prediction after eliminating one potential inaccurate function, equation (15)'''
+
%For example, for this project, we are interesting in predicting the ODs of each auxotrophs, thus, we manually plotted values in y(4), y(5), and y(6) (which again, are the OD values of each auxotrophs) agaisnt time, by typing the following in the command window after run the ODE45 functions: </br></br>
-
[[file: 16hours_Withmordificationpredictionno32_university_of_british_columbia.png|centre| 700x700px]]
+
%>>plot(X,Y(:,4:6)) </br></br>
-
'''Figure 11. Population Dynamics 16-hour Prediction after eliminating one potential inaccurate function, equation (15)'''
+
</br></br>
 +
End of the m.file </br></br>
-
From these figures, it was not surprising to see that the prediction becomes reasonable once more. This indicates that the attempt of generating the functions to describe d[Tyr]/dt as a function of ODmetA<sup>-</sup> from small OD readings was detrimental accuracy of the model. Assuming this, the growth related tyrosine production or consumption from the environment was so insignificant that it was assumed to be zero (d[Tyr]/dt= f(ODmetA<sup>-</sup>)tyr=0).
 
-
Also, please note that the 12 hour predictions are similar independent of the inclusion of equation 15. This shows that within 12 hours, our model works accurately despite some of the equations losing accuracy at later time points.
+
<font face=arial narrow size=4><b>Simulation Results, Analysis and Future Work</b></font></br><font face=arial narrow>
 +
</br>
 +
When the Matlab Code was run, it generated a graphic result predicting the population dynamics without inducing, shown below: </br></br>
-
[[file: 12hours_comparisionWithwithoutmordificationpredictionno32_university_of_british_columbia.png|center| 700x700px]]
+
<p align=center><img src="https://static.igem.org/mediawiki/2012/c/c8/12hours_nomordificationprediction_university_of_british_columbia.png" width=700></br>
-
'''Figure 12. Population Dynamics 12-hour predictions with and without eliminating one potential inaccurate function, equation (15)'''
+
<b>Figure 7. A comparison of model predictions versus empirical measurements (n=3) of each auxotroph’s growth in a co-culture.</br></br>
-
For  our '''future work''', we can refine our model if we have more experimental data. This can be accomplished by running the [https://2012.igem.org/Team:British_Columbia/Protocols/AArate amino acid] experiment data points of interest. Alternatively, we can use more direct methods of amino acid measurement, like HPLC analysis.
+
<p align=left>As shown in the figure above, this model can give reasonable predictions though still can be further modified for better accuracy.  For  our <b>future work</b>, we will refine our model with more experimental data. This can be accomplished by running the <a href="https://2012.igem.org/Team:British_Columbia/Protocols/AArate">amino acid</a> experiment data points of interest. Alternatively, we can use more direct methods of amino acid measurement, like HPLC analysis.</br></br>
-
This code can also be adapted to predict the population dynamics of our cocultures when tuning effects are introduced. This is accomplished by by generating six new functions to describe the amino acid dynamics of each monoculture. We can then use this model to decide the amount of tuning (by adding in different amount of inducer) needed to obtain a desired population of each auxotroph.
+
This code can also be adapted to predict the population dynamics of our cocultures when tuning effects are introduced. This is accomplished by by generating six new functions to describe the amino acid dynamics of each monoculture. We can then use this model to decide the amount of tuning (by adding in different amount of inducer) needed to obtain a desired population of each auxotroph.</br></br>
-
==References==
+
<font face=arial narrow size=4><b>References</b></font></br><font face=arial narrow></br>
-
'''[1]''' Shuler, ML; Kargi, F; Bioprocess Engineering Basic Concepts, 2002 2nd edition. Prentice Hall PTR.
+
[1] Shuler, ML; Kargi, F; Bioprocess Engineering Basic Concepts, 2002 2nd edition. Prentice Hall PTR.</br></br>
-
'''[2]'''      Kerner A; Park J; Williams A; Lin XN; A Programmable Escherichia coli Consortium via Tunable Symbiosis, 2012. PLoS ONE 7(3): e34032. doi:10.1371/journal.pone.0034032
+
[2] Kerner A; Park J; Williams A; Lin XN; A Programmable Escherichia coli Consortium via Tunable Symbiosis, 2012. PLoS ONE 7(3): e34032. doi:10.1371/journal.pone.0034032

Latest revision as of 04:06, 26 October 2012

British Columbia - 2012.igem.org

Modeling Microbial Consortia: The Auxotroph Approach

There is a large potential combinatorial space for optimizing and tuning a three-member microbial consortium with auxotrophic interdependence. In order to help address this concern, we set to develop a computational framework to help guide experimental decisions. Our model attempts to develop a predictive understanding of auxotrophic interdependence in a three-member microbial consortium. As it was important for us to be able to predict growth kinetics based on measurable, empirical properties, as well as to develop a mathematically and experimentally tractable system, we decided to base our model on Monod kinetics.

The Monod equation, models the growth of microorganisms in aqueous environments. The underlying assumption is that the growth rates are dependent on the concentration of a limiting nutrient. This equation relates the specific growth rate (µg, the specific growth rate of microorganisms) to the maximum growth rate (µm), the saturation constant (or half-velocity constant, Ks) as a function of the concentration of the limiting substrate (S) [1].

The three interdependent E. coli auxotrophs used in our project are ΔtrpA, ΔmetA, and ΔtyrA. Each of these strains is missing a gene critical in the respective amino acid biosynthetic pathway. Each of these amino acids are treated as the growth limiting substrates. The model is extends on the work recently presented by Kerner and colleagues [2] and attempts to predict the growth and survival of a three-member consortia.

It takes into account a number of factors:
  1. The constitutive production of each required amino acid by the two remaining natural prototrophs
  2. The inducible production of each required amino acid by a recombinant prototroph, and
  3. The uptake of amino acids in each auxotroph.


The following sections detail the mathematical foundation of the model, the experimental measurement of the necessary constants, the MATLAB implementation and some preliminary results.

Equations and Constants

We proposed the following fundamental equations for our consortium model. In this model, each auxotrophic strain is denoted with a superscript minus (i.e. ΔtrpA, ΔmetA, and ΔtyrA are denoted trpA-, metA-, and tryA-, respectively); [Trp], [Met], and [Tyr] represent the concentrations of tryptophan, methionine, and tyrosine; ODtrpA-, ODmetA-, and ODtyrA- represent the optical densities of the ΔtrpA, ΔmetA, and ΔtyrA strains; a1, a2, and a3 are the consumption constants with respect to changes in ODtrpA-, ODmetA-, and ODtyrA-, respectively; µtrpA-, µmetA-, µtyrA- are the specific growth rates of the ΔtrpA, ΔmetA, and ΔtyrA strains; µMaxtrpA-, µMaxmetA-, µMaxtyrA- are the maximum growth rates of the ΔtrpA, ΔmetA, and ΔtyrA strains; and KstrpA-, KsmetA-, KStyrA- are the half-velocity constants of the ΔtrpA, ΔmetA, and ΔtyrA strains. The terms and constants of this equation will be discussed in further detail later.

Please note that: equation (7), (8), and (9) can be substituted into equation (4), (5), and (6) directly, and equation (4), (5), (6) after the substitution can be further substituted into equation (1), (2), and (3) to simplify the code further. The overall three equations shown later in the Matlab Code section is based on the described substitution. It is indicated here for viewers' convenience of following the Matlab code later.

In the above equations, some of the key constants for the Monod Kinetics are obtained through analyzing the growth curves in a 96-well plate, with varying amino acid concentrations. Characteristic growth rates were observed and plotted:

Applying the Monod kinetic model, we sought out to measure three variables: the concentration of tryptophan, methionine, and tyrosine in the media available for each specific auxotroph. We were also interested in how these concentrations vary with respect to time.


Figure 1: Monoculture Growth Rates at various Limiting Amino Acid Concentrations.



These data are fit to the Monod equation to determine the constants listed below.


Figure 2: Log Scale of Monoculture Growth Rates at various Limiting Amino Acid Concentrations.




Note: we used lower amino acid concentrations as well, however we found out that when concentration is below 1E-7 M, we observed no significant overnight growth of the cells. For a detailed protocol, please visit here.

Based on the fits presented in Figures 1 and 2, the key constants, such as maximum growth rates, and half-velocity constants, for each auxotroph were obtained [1]:

As discussed in the beginning of this section, we assumed that the amino acid consumption is solely dependent on the cell growth rate. In order to find out the consumption rate constants, (a1, a2, and a3), we need to find out a way to measure the amino acid concentrations in the media with respect to the change of its OD for each auxotroph. To do this, we need to find a way to measure media amino acid concentrations. With no good access to HPLC, we noticed in previous experiments that each of the knockout monocultures will reach to a certain final OD at a different known concentration of amino acid. In addition, recently published paper: ''A Programmable Escherichia coli Consortium via Tunable Symbiosis'', Kerner A et. al (2012) confirmed that there is indeed a relationship between the final auxotroph ODs with the environmental amino acid concentrations [2]. We thus generated a calibration curve to relate the limiting amino acid concentrations to their final OD readings. We based this on our own wet lab data shown in the figures below:


Figure 3: Calibration curves used to convert final OD600 to initial amino acid concentration. Standard solutions of known amino acid concentrations were innoculated with the respective auxotroph and grown for 20 hours at 37oC shaken at 200RPM, after which final OD600 were measured. Data were fit to quartic polynomials to inter- polate OD600 readings. Error bars represent standard deviation (n=3).

.

We then sought out to find out how the amino acid in the environment is consumed with respect to cell growth.

The three auxotrophs were grown in 50 ml flasks with known initial Tryptophan, Methionine, and Tyrosine concentrations (5E-5 M), respectively, and 5ml of cell free supernatants at various ODs was isolated. These supernatants served as new 96-well plate media for each knock out cultures with newly added M9-Glucose shots (2% glucose in the well) to ensure the amino acids of interest remained as the limiting substrate for all knock outs. A detailed protocol can be found here.

The cells were grown in a 96-well plate for 15 hours at 37 oC, and growth curve data was obtained using a plate reader (most of the monocultures reached stationary phase at this point).

Based on the calibration curves (Figure 3), the amino acid concentrations in the wells were calculated from the final OD readings, and when corrected with a dilution factor of 5/4 (as we added in the 5X, it was 1/5 of the total well media volume, as described here), we obtained the resultant amino acid concentrations in the supernatant at various auxotroph monoculture densities. Again, with the assumption that the only change in the amino acid concentration in the media is due to cell growth, and as they are specific knock outs, they were not able to release any amino acid into the environment, each auxotrophs' consumption constants with respect to cell growth rate (a1, a2, a3) can be calculated. Their values are as follows:


Figure 4. Amino acid consumption measured from auxotroph cultures in minimial media spiked with an initial concentration of 0.15 mM of the required amino acid. Linear regression was used to find the following consumption rates: Trp: 0.304 ± 0.009 mM/OD (a1), Met: 0.115 ± 0.047 mM/OD (a2), Tyr: 0.143 ± 0.020 mM/OD (a3). Error bars represent 95% confidence interval as determined by regression in the calibration curves.

Now that we have our consupmtion constants, we were interested in finding out how the other two auxotrophs will contribute to changes in environmental amino acid concentrations.

With regards to the behaviour of auxotrophs in coculture under changing amino acid concentrations, the closest assumption we can make is that each auxotroph will behave similarly to the conditions of monoculture. Thus, we used the same calibration curve for relating the final OD to the limiting substrate amino acid concentration in the media. The difference here is that, instead of finding out the corresponding limiting amino acid concentration, e.g., ΔmetA media for [Met] measurements, we are interested in measuring the other two non-limiting amino acid concentrations of each knocked out E. coli auxotrophs, e.g. ΔmetA media for [Trp] and [Tyr] concentrations, at various OD readings [2]. We were then able to derive six functions that relate the change of all amino acid concentrations with respect to time (e.g. d[Trp]/dt), based on two auxotrophs' optical densities (e.g. ODmetA- and ODtyrA-), as shown below:


Note: These equations can now be directly substituted into equations (1), (2), and (3), in order to simplify the Matlab Code section.

One shortcoming in the use of these equations is their dependency on the accuracy of the calibration curves (Figure 3, 4, and 5), as well as the OD readings, especially when OD readings are low and noisy (< 0.1, nearing the limits of the plate reader's accuracy).

For example, one of the experimental raw data obtained are shown below:


Figure 5: ΔtyrA auxotroph growth curve in various ΔmetA ODs cell free supernatants in 96-well plate reader environment.

.

Note: As discussed before, this may lead to inaccuracies in calculation from low OD readings. All data sets are labelled correspondingly, and triplicate measurements are noted by wells 1, 2, and 3. As we can see, there are some distinct differences in the OD readings among the three different supernatant data sets; however, when corrected by focusing on the difference between the initial reading and the final reading with a base adjustment of 0.025 (the lower value used for all the calibration curves), they average roughly the same, with an average OD of 0.03847, 0.04043, and 0.04218, respectively, for ODmet 0.219, 0.546, and 0.764.

To illustrate this point more clearly, here is a comparison with another set of growth curve data run in the same plate.


Figure 6: Comparison between ΔtrpA and ΔtyrA auxotroph growth curve in the same supernatants of ΔmetA at its various optical density media.

Note that all three of the trpA- sets of growth curve grew to a much higher OD (reaching about 0.17) at the end of 15 hours and did not reach stationary phase, whereas all tyrA- sets grew significantly less, no significant change in OD at the end of the experiment.

Matlab Code

Now with all the key functions and constants approximated, we are able to encode our model into Matlab, where the six key ODE functions can be solved and output the our prediction of population dynamics.

The code is shown below, which contains a detailed step by step instruction for future iGEM teams or related scientific researches use, as well as the clarifications of our own code. It is also written is a way that it can be directly copied and pasted into Matlab blank m.files with all the comments in Matlab commenting format already, so that the coder can read the coded instructions and explanations in the coding command window without having to switching between, for example, the matlab and browser windows.

Of course, copying and pasting the code here is welcomed!



Code begins here:

% input the following commands, which are all in bold, into MATLAB command window, and not the m.file, before you call the ODE function.

%firstly, define a time array, set the upper limit to be the time (hr) you want this model to predict. For this model to be accurate, it is advised not to use extreme values.

%in our cases, the upper limit is set to 12 as some of the modelling equations are based on 11 hour culture supernatant data. Thus accuracy is expected within 12 hours.

% xspan = [0 12];

%in order to set up the initial conditions, where they corespond to the initial values of y(1), y(2), y(3)..., to y(6) in our case, and y(n) if you have n number of ODE equations

% ynot = [4E-5 4E-5 4E-5 0.05 0.05 0.05]';

% the first three values are the initial values for y(1), y(2), and y(3) respectively, which in out cases are the initial amino acid concentrations, and as we are adding the cells directly into the M9 media without supplementing any amino acids, it is believed to be at a low concentrations, though there will be some left over amino acids within the living initial cells, and thus is set to 4E-5 mole/L.

% the remaining three values are the initial conditions for y(4), y(5), and y(6), which are the initial cell ODs in out case, and they are all set to 0.05, which is the initial OD reading we obtained after we innoculated the culture, with the assumption that all the cells are still alive.

%Then RUN THE FUNCTION

% [X,Y] = ode45(@UBCiGEM2012_ConsortiaModel,xspan,ynot);

% this takes the function name in your m.file, the range of your interest, and the initial conditions which is just defined, respectively

%Note: have to make sure that the name is exactly the same as the function name in your m.file for it to be able to run correctly.

%the following code is for the actual mfile.

% 1) Declare the name of the function:

function dy = UBCiGEM2012_ConsortiaModel(t,y);

% 2) define all your ODE variables clearly for your own understanding as they can get quite confusing if you don't.

% in our case:

% y(1) = [Trp];

% dy(1) = d[Trp]/dt;

% y(2) = [Met];

% dy(2) = d[Met]/dt;

% y(3) = [Tyr];

% dy(3) = d[Tyr]/dt;

% y(4) = [OD_trpA-];

% dy(4) = d[OD_trpA-]/dt;

% y(5) = [OD_tyrA-];

% dy(5) = d[OD_tyrA-]/dt;

% y(6) = [OD_metA-];

% dy(6) = d[OD_metA-]/dt;

% 3) define your constants first that will not depend on variables

% in our case, it was all measured through our own wet lab data and is explained in the previous section

%define maximum growth rate constants

u_maxtrpA = 0.23; % units = hr-1

u_maxmetA = 0.34; % units = hr-1

u_maxtyrA = 0.28; % units = hr-1

%define half-velocity constants

Ks_trpA = 3.30E-7; % units = M

Ks_metA = 5.10E-6; % units = M

Ks_tyrA = 8.50E-7; % units = M

%define the consumption rate constants

a1 = 3.05E-4; %units= M/OD trp

a2 = 1.15E-4; %units= M/OD met

a3 = 1.4E-4; %units= M/OD tyr

% 4) write out ODE CODE, suggest to write out all equations on paper first, as they are a lot more clear than coding them directly, and will reduce the chance for you to make error why coding significantly.

dy = zeros(6,1);

dy(1) = 2.5E-7 + 7.2E-8 - a1*(u_maxtrpA*(y(1))/(Ks_trpA+y(1)))*y(4);

dy(2) = 1.7E-7 + 5.1E-8 - a2*(u_maxmetA*(y(2))/(Ks_metA+y(2)))*y(5);

dy(3) = -3.6E-8 + 1.7E-6 - a3*(u_maxtyrA*(y(3))/(Ks_tyrA+y(3)))*y(6);

dy(4) = (u_maxtrpA*y(1))/(Ks_trpA+y(1))*(y(4));

dy(5) = (u_maxmetA*y(2))/(Ks_metA+y(2))*(y(5));

dy(6) = (u_maxtyrA*y(3))/(Ks_tyrA+y(3))*(y(6));

% note: For easy coding and checking purposes, all this equations are exactly the same as the one shown in equation (1), (2), and (3) for dy(1), dy(2), and dy(3) respectively, with also the same arrangements of each equation term within them.

% and Please also note: these equation has been derived with direct simple substitution of equations, where equation (4), (5), (6), (7), (8), (9), (10), (11), (12), (13), (14) and (15) have been substituted into the equation (1), (2) and (3).

%if you want, you can choose to plot diagrams and display the predicting dynamics within the m.file or manually plot the arrays of your interests in command window

%For example, for this project, we are interesting in predicting the ODs of each auxotrophs, thus, we manually plotted values in y(4), y(5), and y(6) (which again, are the OD values of each auxotrophs) agaisnt time, by typing the following in the command window after run the ODE45 functions:

%>>plot(X,Y(:,4:6))



End of the m.file

Simulation Results, Analysis and Future Work

When the Matlab Code was run, it generated a graphic result predicting the population dynamics without inducing, shown below:


Figure 7. A comparison of model predictions versus empirical measurements (n=3) of each auxotroph’s growth in a co-culture.

As shown in the figure above, this model can give reasonable predictions though still can be further modified for better accuracy. For our future work, we will refine our model with more experimental data. This can be accomplished by running the amino acid experiment data points of interest. Alternatively, we can use more direct methods of amino acid measurement, like HPLC analysis.

This code can also be adapted to predict the population dynamics of our cocultures when tuning effects are introduced. This is accomplished by by generating six new functions to describe the amino acid dynamics of each monoculture. We can then use this model to decide the amount of tuning (by adding in different amount of inducer) needed to obtain a desired population of each auxotroph.

References

[1] Shuler, ML; Kargi, F; Bioprocess Engineering Basic Concepts, 2002 2nd edition. Prentice Hall PTR.

[2] Kerner A; Park J; Williams A; Lin XN; A Programmable Escherichia coli Consortium via Tunable Symbiosis, 2012. PLoS ONE 7(3): e34032. doi:10.1371/journal.pone.0034032