Difference between revisions of "Team:Cologne-Duesseldorf/Model"

 
(73 intermediate revisions by 2 users not shown)
Line 2: Line 2:
 
{{Template:Cologne-Duesseldorf/header}}
 
{{Template:Cologne-Duesseldorf/header}}
 
<html>
 
<html>
<body>
+
<body>
<article>
+
<div id="ToC"></div>
    <h1>Model</h1>
+
<article>
    <div id="ToC"></div>
+
<h1>Model</h1>
    <h2>Metabolic Modeling</h2>
+
<div class="callout">
    <h3>Overview</h3>
+
<h2>Summary</h2>
    <p>In the following we present our model of the Nootkatone biosynthesis pathway, to give you an insight into its behaviour and dynamics. We start with an oversimplified luminar model to get a sense for the behaviour of the enzymes in the pathway. Then we will continue with a model introducing a function penalizing high concentrations of some of the products, as they have been shown to be toxic at certain levels. As the toxicity is the main culprit of Nootkatone production, we further modeled the production inside a peroxisome, as we assume that intermediates inside the peroxisome cannot pass the membrane and thus have no toxic effect on the cells.</p>
+
<p>To enable full control over the peroxisomal protein import we predicted the structure for the yeast peroxisomal matrix import protein. In this structure we exchanged amino acids in the TPR regions using PyMol to create an orthogonal binding pocket. Using AMBER and VMD we predicted a binding pocket which binds a non wild type but not the wild type targeting signal. <br> To optimize our proof-of-concept project we modeled the <a href="#MetabolicModel">Nootkatone pathway</a> using python and showed the advantages of  cellular compartmentalization. Finally we were able to create a yeast strain optimized for the production of the pathway precursor by using <a href="#OptKnock">OptFlux analysis</a>.</p>
    <h3>Basic System</h3>
+
</div>
    <p>The basic reactions of the Nootkatone pathway that are introduced by our team are the following.</p>
+
<button class="accordion">
    <p>$$\ce{FPP ->[ValS] Valencene ->[\text{HPO & CPR}][NADH +  H+ + O2 -> NAD+ + H2O] Nootkatol <->[ADH][NAD+ + H+ -> NADH] Nootkatone}$$</p>
+
<h2 id=StructuralModel>Structural model</h2>
    <p>However during research we found that using the p450-BM3 enzyme will simplify and enhance Nootkatone production, giving the following reaction pathway.</p>
+
</button>
    <p>$$\ce{FPP ->[ValS] Valencene ->[\text{p450-BM3}][NADH +  H+ + O2 -> NAD+ + H2O] Nootkatol <->[ADH][NAD+ + H+ -> NADH] Nootkatone}$$</p>
+
<div class="panel">
    <p>We assumed Michaelis-Menten kinetics for each reaction, with the last step being reversible.</p>
+
<h3 id=h3-1>Infrastructure and modelling software</h3>
    <p>Michaelis-Menten kinetics</p>
+
<p>For the targeted mutagenesis of PEX5 we used molecular dynamic techniques. Professor Gohlke of the University of Duesseldorf kindly provided us with the necessary infrastructure (e.g. server and software access) and advisors to perform our calculations.
    <p>$$\frac{dP}{dt} = \frac{V_{Max} \cdot c_{S}}{K_{M} + c_{S}}$$</p>
+
<br>
    <p>Reversible Michaelist-Menten kinetics</p>
+
Molecular dynamics are a tool simulate the cells environment, regarding its temperature and ion contents, to calculate protein&minus;protein interactions. We simulated the movement of our peroxisomal targeting signal (PTS) within the binding pocket of the PEX5 receptor.
    <p>$$\frac{dP}{dt} = \frac{\frac{V_{M+} \cdot c_{S}}{K_{M+}} - \frac{V_{M-} \cdot c_{P}}{K_{M-}}}{1 + \frac{c_{S}}{K_{M+}} + \frac{c_{P}}{K_{M-}}}$$</p>
+
<br>
    <p>We further assumend a permanent FPP production proportional to the need, but with an upper boundary and a factor controlling the production speed. This behaviour is similar to an unlimited pool and diffusion. </p>
+
The molecular dynamics software <b>AMBER</b> (Assisted Model Building with Energy Refinement) uses so called force fields to calculate the movement of each atom. For that we start with an equilibrated state which means that the PTS and every other molecule sit at the most favorable position. After equilibration we proceed with the actual simulation. The simulations only differ in the temperature of the environment which is more or less 300 K in each simulation. The whole workflow is depicted in the following graphic.
    <p>$$\frac{dFPP_{in}}{dt} = \mu_{FPP} \cdot (Max_{FPP} - c_{FPP})$$</p>
+
</p>
    <p>This gives us the following system of differential equations.</p>
+
<figure>
    <p>$$\frac{dFPP}{dt} = \mu_{FPP} \cdot (Max_{FPP} - c_{FPP}) - \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} $$</p>
+
<img src="https://static.igem.org/mediawiki/2017/7/7f/Artico_mdwork.svg">
    <p>$$\frac{dValencene}{dt} = \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} -\frac{V_{Max,p450\_BM3} \cdot c_{Valencene}}{K_{M, p450\_BM3} + c_{Valencene}}$$</p>
+
<figcaption>
    <p>$$\frac{dNootkatol}{dt} = \frac{V_{Max,p450\_BM3} \cdot c_{Valencene}}{K_{M, p450\_BM3} + c_{Valencene}} - \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$</p>
+
Workflow for the molecular dynamics simulations
    <p>$$\frac{dNootkatone}{dt} = \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$</p>
+
</figcaption>
    <h3>Parameters</h3>
+
</figure>
<p>Our crude first assumption was a constant enzyme concentration of $1 \ \text{µM}$, a maximal FPP concentration of $2.5 \  \frac{\text{nmol}}{\text{OD}}$, based on a typical wildtype FPP concentration according to <abbr title="2017, Sebastián Rubat - Increasing the intracellular isoprenoid pool in Saccharomyces cerevisiae by structural fine-tuning of a bifunctional farnesyl diphosphate synthase">Rubat 2017</abbr>, which we transformed to $1.39E-3  \frac{\text{mol}}{\text{L}}$ by using the estimation that one OD roughly equals $3E+7 \text{ cells}$ (<a href="http://bionumbers.hms.harvard.edu/bionumber.aspx?id=100986&ver=3">Bionumbers</a>) and that the typical yeast volume is about $6E-14 \ \text{L}$ (<abbr title="2012, Rob Phillips - Physical Biology of the Cell">Philips 2012</abbr>).</p>
+
<p>
<p>$$c_{\text{Max FPP}} \ [\frac{\text{mol}}{\text{L}}] = \frac{c_{\text{FPP, Wildtype}} \ [\frac{\text{nmol}}{\text{OD}}]}{N \frac{\text{cells}}{\text{OD}} \cdot V_{\text{Yeast}} [\text{L}]}$$</p>
+
As one can see, we start with a targeted mutagenesis for our PEX5 receptor, then proceed with the actual simulation to get finally to data evaluation. This is the point where we either decide to reject this receptor variant or to let it synthesize for experiments in the lab.
<p>Another assumption we made is a five-fold reduction in the speed of the reversible reaction of the ADH-21, based on the work by <abbr title="2015, Sebastian Schulz - Cascade Reactions combining a Cytochrome P450 Monooxygenase and an Alcohol Dehydrogenase for the Synthesis of (+)-Nootkatone">Sebastian Schulz (2015)</abbr>, that the forward reaction is favored. The permeability for FPP was set to $1E-6 \frac{1}{\text{s}}$, which severed as a lower bound for which the production was still maximal.</p>
+
</p>
    <table>
+
<h3 id=h3-2>Three dimensional structure of the yeast PEX5 receptor</h3>
<thead>
+
<p>
      <tr>
+
Currently there is no crystal structure of the yeasts PEX5 and due to that we had to predict its structure. To achieve that, we used a program provided by Daniel Mulnaes that uses existing files of the <a href="http://www.rcsb.org/pdb/home/home.do">pdb database</a> to create the structural prediction of the input sequence. One of those is the crystal structure of the TPR domains of the human PEX5 receptor interacting with the PTS1 ( PDB-entry: <a href="http://www.rcsb.org/pdb/explore/explore.do?structureId=1FCH">1FCH</a> ). Once we got this pdb file, we could proceed with our targeted mutagenesis in PyMOL.
        <th>Parameter</th>
+
<br>
        <th>Value</th>
+
Unfortunately, the program could not predict the whole structure, but only about 51% of it. It contains the important TPR domains and is very similar to the human crystal structure as you see in the figure below.
        <th>Source</th>
+
</p>
</tr>
+
<figure>
</thead>
+
<img src="https://static.igem.org/mediawiki/2017/d/d2/Artico_p5align.png">
<tbody>
+
<figcaption>
      <tr>
+
Alignment of the pdb file 1FCH (gray) to the predicted structure of the yeasts PEX5 (red).
        <td>$c_{\text{FPP, Wildtype}}$</td>
+
</figcaption>
        <td>$2.5 \  \frac{\text{nmol}}{\text{OD}}$</td>
+
</figure>
        <td><abbr title="2017, Sebastián Rubat - Increasing the intracellular isoprenoid pool in Saccharomyces cerevisiae by structural fine-tuning of a bifunctional farnesyl diphosphate synthase">Rubat 2017</abbr></td>
+
<h3 id=h3-3>PyMOLs 'mutagenesis wizard'</h3>
</tr>
+
<p>
      <tr>
+
PyMOL provides a built-in function called 'mutagenesis wizard' making it possible to introduce site-directed mutations in the 3D structure. With this tool we exchanged amino acids in the TPR regions to create beneficial interactions between receptor and targeting signal. Our new receptor should only recognize our new peptide and not the wild type PTS1 and in exchange the wild type receptor should not recognize the new designed PTS.
        <td>$N_{\text{cells per OD}}$</td>
+
</p>
        <td>$3E+7 \  \frac{\text{cells}}{\text{OD}}$</td>
+
<figure>
        <td><a href="http://bionumbers.hms.harvard.edu/bionumber.aspx?id=100986&ver=3">Bionumbers</a></td>
+
<img src="https://static.igem.org/mediawiki/2017/c/c5/Artico_p5wt_polar.png">
</tr>
+
<figcaption>TPR domains of the yeasts PEX5 receptor with the PTS1. The yellow lines indicate interacting amino acids.</figcaption>
<tr>
+
</figure>
        <td>$V_{\text{Yeast}}$</td>
+
<figure>
        <td>$6E-14 \ \text{L}$</td>
+
<img src="https://static.igem.org/mediawiki/2017/f/f6/Artico_p5elector.png">
        <td><abbr title="2012, Rob Phillips - Physical Biology of the Cell">Philips 2012</abbr></td>
+
<figcaption>
</tr>
+
<p>
      <tr>
+
Calculated vacuum electrostatics of the PEX5 receptor with the PTS. Red indicates positive, blue negative polarity.
        <td>$c_{\text{Max FPP}}$</td>
+
</p>
        <td>$1.39E-3  \frac{\text{mol}}{\text{L}}$</td>
+
</figcaption>
        <td>$\frac{c_{\text{FPP, Wildtype}}}{N_{\text{cells per OD}} \cdot V_{\text{Yeast}}}$</td>
+
</figure>
</tr>
+
<br>
<tr>
+
<p>
<td>$\mu_{FPP}$</td>
+
The two figures above show the visualization possibilities in PyMOL &minus; the upper one shows interacting amino acids while the lower one depicts the overall polarity. Both features helped us to set mutations in an educated way. As soon as we designed our receptor-PTS combination, we proceeded with the preparation for the molecular dynamics simulation.
<td>$1E-6 \frac{1}{\text{s}}$</td>
+
</p>
<td>Assumption</td>
+
<h3 id=h3-4>Equilibration and molecular dynamics simulation</h3>
</tr>
+
<p>
      <tr>
+
Once the mutations were set and the peptide was build, we equilibrated and simulated our experiment. After a couple of days the simulations were finished and we could start with the data evaluation.
        <td>$\text{kM}_{\text{Valencene Synthase}}$</td>
+
</p>
        <td>$1.04 \text{µM}$</td>
+
<h4 id=h4-1>Graphical visualization</h4>
        <td><a href="http://www.brenda-enzymes.org/enzyme.php?ecno=4.2.3.73">Brenda</a></td>
+
<p>
</tr>
+
<a href="http://www.ks.uiuc.edu/Research/vmd/">VMD</a> (Visual Molecular Dynamics) uses the coordinate files generated by AMBER to illustrate the simulation in an animated way as it can be seen below.
      <tr>
+
</p>
        <td>$\text{kM}_{\text{p450 BM3}}$</td>
+
<div class="center">
        <td>$126 \text{µM}$</td>
+
<video controls="controls" width="800" height="600" name="Video Name" src="https://static.igem.org/mediawiki/2017/9/9e/Artico_R6WT.mov"></video>
        <td><a href="http://www.brenda-enzymes.de/enzyme.php?ecno=1.14.14.1">Brenda</a></td>
+
</div>
</tr>
+
<p>
      <tr>
+
This already looked neat and gabe a rough hint on how promising the results are but for scientific evaluation we proceeded with numerical analysis.
        <td>$\text{kM}_{\text{ADH-21}}$</td>
+
</p>
        <td>$161 \text{µM}$</td>
+
<h4 id=h4-2>Diffusion</h4>
        <td><abbr title="2017, Sebastián Rubat - Increasing the intracellular isoprenoid pool in Saccharomyces cerevisiae by structural fine-tuning of a bifunctional farnesyl diphosphate synthase">Rubat 2017</abbr></td>
+
<p>
<tr>
+
To get numerical data out of the coordinate files, we then calculated the diffusion of the PTS from its starting point in the equilibrated state. A low value indicates stable binding while a high value indicates unfavorable interactions. Hence we had five replicates for each 'experiment', we calculated an average value and the standard deviation of all five replicates for point in time. Due to fluctuating values, we decided to implement a triangular smoothing algorithm to get more representative values. After the calculation we used R's ggplot2 to generate plots that set the experiments in relation with its controls. Our whole setup contains the following simulations.
      <tr>
+
</p>
        <td>$\text{kcat}_{\text{Valencene Synthase}}$</td>
+
<br>
        <td>$0.0032 \frac{1}{\text{s}}$</td>
+
<ul>
        <td><a href="http://www.brenda-enzymes.org/enzyme.php?ecno=4.2.3.73">Brenda</a></td>
+
<li>our receptor &minus; our PT</li>
</tr>
+
<li>our receptor &minus; wild type PTS</li>
      <tr>
+
<li>wt receptor &minus; our PTS</li>
        <td>$\text{kcat}_{\text{p450 BM3}}$</td>
+
<li>wt receptor &minus; wild type PTS</li>
        <td>$2.619 \frac{1}{\text{s}}$</td>
+
</ul>
        <td><a href="http://www.brenda-enzymes.de/enzyme.php?ecno=1.14.14.1">Brenda</a></td>
+
<br>
</tr>
+
<p>The following plots show examplaric how our results look like.</p>
<tr>
+
<figure>
        <td>$\text{kcat}_{\text{ADH-21 forward}}$</td>
+
<img src="https://static.igem.org/mediawiki/2017/e/eb/Artico_rec_003_ydsyd.svg">
        <td>$6 \frac{1}{\text{s}}$</td>
+
<figcaption>
        <td><a href="http://onlinelibrary.wiley.com/doi/10.1002/cctc.201402952/full">Schulz 2015</a></td>
+
PEX5 variant R3 with the PTS1 variant -YDSYD. This shows an example for a unfavorable result &minus; the receptor prefers the PTS1 above the PTS1*.
</tr>
+
</figcaption>
      <tr>
+
</figure>
        <td>$\text{kcat}_{\text{ADH-21 backward}}$</td>
+
<p>
        <td>$1.2 \frac{1}{\text{s}}$</td>
+
The figure above shows the one of our plots generated from the simulations data. We calculated the diffusion of the PTS1 from its starting point in angstrom and plotted it against the time in nanoseconds. The lines show the average diffusion value for each experiment while the shaded area depicts the standard deviation of the different replicates. Furthermore we calculated a value which indicates if the PEX5 variant has a higher preference for the PTS1* or the PTS1. A positive value implies a higher affinity while a negative value implies the opposite &minus; one has to bear in mind that negative values reach higher numbers than positive ones. This is caused by the simulations conditions because if the binding is unstable, the targeting signal moves a lot.
        <td>$\frac{\text{kcat}_{\text{ADH-21 forward}}}{5}$</td>
+
<br>
</tr>
+
To return to the figure, the red line represents the PEX5 variant with the PTS1 and the blue with the PTS1*. The figure above is an example for an unfavorable result &minus; one sees that wild type signal is prefered above the designed one and thereby this would not lead to the achievement of our goal.
<tr>
+
</p>
        <td>$c_{\text{Enzyme}}$</td>
+
<figure>
        <td>$1 \text{µM}$</td>
+
<img src="https://static.igem.org/mediawiki/2017/8/86/Artico_rec_008_ytnqe.svg">
        <td>Assumption</td>
+
<figcaption>
</tr>
+
PEX5 variant R8 with the PTS1 variant -YTNQE. This shows an example for a quite favorable result. The preference coefficient is positive which means that the receptor prefers the PTS1* above the PTS1.
</tbody>
+
</figcaption>
    </table>
+
</figure>
 +
<p>
 +
This figure shows a more favorable result. On average the PEX5 variant has a slightly higher preference for the PTS1* and due to that we figured this one would be worth a test in our laboratory.
 +
</p>
 +
<figure>
 +
<img src="https://static.igem.org/mediawiki/2017/a/a4/Artico_rec_015_ytnwd.svg">
 +
<figcaption>
 +
PEX5 variant R15 with the PTS1 variant -YTNWD. The results of this simulation were also quite positive hence the receptor prefers the PTS1* above the natural PTS1. Unfortunately, the standard deviation is nearly as high as the preference coefficient, which means that this result should be considered with skepticism. Nevertheless we decided for us for laboratory tests.
 +
</figcaption>
 +
</figure>
 +
<h3>Experimental results</h3>
 +
<h4>PEX5 variant R19</h4>
 +
<p>
 +
This PEX5 variant did not directly develop from molecular dynamics in the first place. <a href="https://www.nature.com/articles/s41467-017-00487-7"><abbr title="Towards designer organelles by subverting the peroxisomal import pathway">Baker et al.</abbr></a> worked on a similar project and obtained results that we took in consideration for the design of the PEX5 variant R19 (see <a href="https://2017.igem.org/Team:Cologne-Duesseldorf/Design#h3-3">here</a> for more detailed information).
 +
</p>
 +
<figure>
 +
<div class="flex-row-2">
 +
<div>
 +
<img src="https://static.igem.org/mediawiki/2017/9/98/Artico_br_bpts.svg">
 +
</div>
 +
<div>
 +
<img src="https://static.igem.org/mediawiki/2017/8/84/Artico_br_yqsyy.svg">
 +
</div>
 +
</div>
 +
<figcaption>
 +
PEX5 variant R19 with to PTS1* variants &minus; the left figure shows the result of the full 15 amino acid long PTS1* while the right one was only done with the last five amino acids.
 +
</figcaption>
 +
</figure>
 +
<p>
 +
The figure above shows the result of the molecular dynamics simulation with our PEX5 variant R19. As one can see, the simulation with the 15 amino acid long peptide shows very unstable behaviour. Since our assumption for this was the long peptide and missing structures in the PEX5 model, we tried again with only five amino acids and obtained better results.
 +
<br>
 +
The very interesting part is, that this receptor was tested positively in our experiment &minus; it successfully imported mTurquoise with the corresponding PTS1* (visit our <a href="https://2017.igem.org/Team:Cologne-Duesseldorf/Results">results section</a> for more information). Since the value of the preference coefficient is quite low, this means that our molecular dynamics approach was condemned to failure.
 +
</p>
 +
<h3>Review: molecular dynamics</h3>
 +
<p>
 +
Molecular dynamics are definitely an interesting and promising instrument regarding protein design and synthetic biology but our experiments showed the obstacles that come up once you work with it. As described before we achieved a positive result with one of our PEX5 variants but this very combination of PEX5 variant and PTS1* showed undesirable results in the simulation.
 +
<br>
 +
We think that the predicted PEX5 of yeast is the cause of this behaviour. The structure could only be predicted to about 51% which means that there could be more structures involved in PTS1 binding than presently assumed. In the beginning we assumed that the TPR regions would be enough, but now we think that we would need the whole crystal structure to do successful protein engineering from scratch. Unfortunately there are currently no crystal structures of the whole protein &minus; neither of the yeast nor of any other organism &minus; and due to its size it is unlikely to be crystallised in the near future.
 +
</p>
 +
</div>
  
 +
<button class="accordion">
 +
<h2 id=MetabolicModel>Nootkatone Metabolic Model</h2>
 +
</button>
 +
<div class="panel">
 +
<h3>Overview</h3>
 +
<p>In the following we present our model of the nootkatone biosynthesis pathway. We modeled the system in order to understand how to maximize nootkatone production.  We start with an oversimplified model to give you a sense for the behavior of the enzymes in the pathway. Then we continue with a model introducing a function penalizing high concentrations of toxic products. As the toxicity is one of two main culprits of nootkatone production, we further show that the production inside a peroxisome can greatly increase nootkatone yield. Afterwards we discuss possible ways to overcome the shortage of the cellular FPP pool.</p>
 +
<h3>Basic System</h3>
 +
<p>The basic reactions of the nootkatone pathway are the following:</p>
 +
<img class="half-width" src="https://static.igem.org/mediawiki/2017/8/8f/T--Cologne-Duesseldorf--nkl-pathway.svg">
 +
<p>This already implies using an alcohol dehydrogenase with similar behaviour to ADH-21 used by <a href="http://onlinelibrary.wiley.com/doi/10.1002/cctc.201402952/full"><abbr title="2015, Sebastian Schulz - Cascade Reactions combining a Cytochrome P450 Monooxygenase and an Alcohol Dehydrogenase for the Synthesis of (+)-nootkatone">Sebastian Schulz (2015)</abbr></a>. This ADH on the one hand is not stereospecific, in this case meaning that it can convert both <em>cis</em> and <em>trans</em>-nootkatol. On the other hand it favours the forward reaction, thus increasing the $\frac{\text{nootkatone}}{\text{nootkatol}}$ ratio. However due to the lack of stereospecificity we modeled the pathway using only one "nootkatol" species.</p>
 +
<img class="half-width" src="https://static.igem.org/mediawiki/2017/f/fb/T--Cologne-Duesseldorf--nkl-pathway-simple.svg">
 +
<p>We assumed Michaelis-Menten kinetics for each reaction, with the last step being reversible.</p>
 +
<p>Michaelis-Menten kinetics</p>
 +
<p>$$\frac{dP}{dt} = \frac{V_{Max} \cdot c_{S}}{K_{M} + c_{S}}$$</p>
 +
<p>Reversible Michaelis-Menten kinetics</p>
 +
<p>$$\frac{dP}{dt} = \frac{\frac{V_{M+} \cdot c_{S}}{K_{M+}} - \frac{V_{M-} \cdot c_{P}}{K_{M-}}}{1 + \frac{c_{S}}{K_{M+}} + \frac{c_{P}}{K_{M-}}}$$</p>
 +
<p>We further assumed a permanent FPP production, which we fitted in the <a href="#Penalty-Model">Penalty model</a>.</p>
 +
<p>This gives us the following system of differential equations.</p>
 +
<p>$$\frac{dFPP}{dt} = v_{\text{FPP in}} - \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} $$</p>
 +
<p>$$\frac{dValencene}{dt} = \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} -\frac{V_{Max,\text{P450 BM3}} \cdot c_{Valencene}}{K_{M, \text{P450 BM3}} + c_{Valencene}}$$</p>
 +
<p>$$\frac{dNootkatol}{dt} = \frac{V_{Max,\text{P450 BM3}} \cdot c_{Valencene}}{K_{M, \text{P450 BM3}} + c_{Valencene}} - \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$</p>
 +
<p>$$\frac{dNootkatone}{dt} = \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$</p>
 +
<p>Since the main cofactor is regenerated inside the pathway we chose to not model the cofactors.</p>
 +
<h3>Parameters</h3>
 +
<p>Our crude first assumption was a constant enzyme concentration of $1 \ \text{µM}$. We mostly used kinetic parameters from the <a href="http://www.brenda-enzymes.de/">Brenda</a> database. If S. cerevisiae was not available as the host we used the nearest relative, if the reaction was not available we used the kinetics for the respective co-substrate as an upper boundary. Another assumption we made is a five-fold reduction in the speed of the reversible reaction of the ADH-21, based on the work by <a href="http://onlinelibrary.wiley.com/doi/10.1002/cctc.201402952/full"><abbr title="2015, Sebastian Schulz - Cascade Reactions combining a Cytochrome P450 Monooxygenase and an Alcohol Dehydrogenase for the Synthesis of (+)-nootkatone">Sebastian Schulz (2015)</abbr></a>, that the forward reaction is favored.</p>
 +
<table>
 +
<thead>
 +
<tr>
 +
<th>Parameter</th>
 +
<th>Value</th>
 +
<th>Source</th>
 +
</tr>
 +
</thead>
 +
<tbody>
 +
<tr>
 +
<td>$v_{\text{FPP in}}$</td>
 +
<td>$4.18E-9 \frac{1}{\text{s}}$</td>
 +
<td>Penalty model</td>
 +
</tr>
 +
<tr>
 +
<td>$\text{kM}_{\text{Valencene Synthase}}$</td>
 +
<td>$1.04 \text{ µM}$</td>
 +
<td><a href="http://www.brenda-enzymes.org/enzyme.php?ecno=4.2.3.73">Brenda</a></td>
 +
</tr>
 +
<tr>
 +
<td>$\text{kM}_{\text{P450 BM3}}$</td>
 +
<td>$126 \text{ µM}$</td>
 +
<td><a href="http://www.brenda-enzymes.de/enzyme.php?ecno=1.14.14.1">Brenda</a></td>
 +
</tr>
 +
<tr>
 +
<td>$\text{kM}_{\text{ADH-21}}$</td>
 +
<td>$161 \text{ µM}$</td>
 +
<td><a href="http://onlinelibrary.wiley.com/doi/10.1002/cctc.201402952/full">Schulz 2015</a></td>
 +
</tr>
 +
<tr>
 +
<td>$\text{kcat}_{\text{Valencene Synthase}}$</td>
 +
<td>$0.0032 \frac{1}{\text{s}}$</td>
 +
<td><a href="http://www.brenda-enzymes.org/enzyme.php?ecno=4.2.3.73">Brenda</a></td>
 +
</tr>
 +
<tr>
 +
<td>$\text{kcat}_{\text{P450 BM3}}$</td>
 +
<td>$2.619 \frac{1}{\text{s}}$</td>
 +
<td><a href="http://www.brenda-enzymes.de/enzyme.php?ecno=1.14.14.1">Brenda</a></td>
 +
</tr>
 +
<tr>
 +
<td>$\text{kcat}_{\text{ADH-21 forward}}$</td>
 +
<td>$6 \frac{1}{\text{s}}$</td>
 +
<td><a href="http://onlinelibrary.wiley.com/doi/10.1002/cctc.201402952/full"><abbr title="2015, Sebastian Schulz - Cascade Reactions combining a Cytochrome P450 Monooxygenase and an Alcohol Dehydrogenase for the Synthesis of (+)-nootkatone">Sebastian Schulz (2015)</abbr></a>
 +
</tr>
 +
<tr>
 +
<td>$\text{kcat}_{\text{ADH-21 backward}}$</td>
 +
<td>$1.2 \frac{1}{\text{s}}$</td>
 +
<td>$\frac{\text{kcat}_{\text{ADH-21 forward}}}{5}$</td>
 +
</tr>
 +
<tr>
 +
<td>$c_{\text{Enzyme}}$</td>
 +
<td>$1 \text{ µM}$</td>
 +
<td>Assumption</td>
 +
</tr>
 +
</tbody>
 +
</table>
 +
<h3>Simple model</h3>
 +
<p>In order to simulate the system of differential equations we set up a few python files. One file containing a model class which consists of the parameters, the models and the integration function. One file containing all the kinetics used and finally one which we used to actually run the simulations. We wanted to show some example code on how to set up such a project, while the code size was still manageable, in order to help new iGEM teams that might need help with their modeling.</p>
 +
<h4>Kinetics File</h4>
 +
<pre>
 +
<code>
 +
def ConstantInflux(substrate,speed):
 +
return(speed)
  
    <h3>Simple model</h3>
+
def MichaelisMenten(
    <p>In order to simulate the system of differential equations we set up a few python files, one containing a model class which consists of the parameters, the models and the integration function, one containing all the kinetics used and one which we used to actually run the simulations. We wanted to show some example code on how to set up such a project, while the code size was still managable, in order to help new iGEM teams that might need help with their modeling.</p>
+
substrate,enzymeConcentration,kcat,km):
<h4>Kinetics File</h4>
+
return(
<pre>
+
(enzymeConcentration*kcat*substrate)
<code>
+
/(km+substrate))
def Influx(substrate,maximum,permeability):
+
    return (permeability * (maximum - substrate))
+
  
def MichaelisMenten(substrate,enzymeConcentration,
+
def MichaelisMentenReversible(
                    kcat,km):
+
substrate,product,enzymeConcentration,
    return((enzymeConcentration*kcat*substrate)
+
kcats,kcatp,kms,kmp):
            /(km+substrate))
+
return (
 +
(
 +
((enzymeConcentration*kcats*substrate)/kms)
 +
-((enzymeConcentration*kcatp*product)/kmp)
 +
)
 +
/(1+(substrate/kms)+(product/kmp)
 +
))
 +
</code>
 +
</pre>
 +
<h4>Model File</h4>
 +
<pre>
 +
<code>
 +
import kinetics as k
 +
import numpy as np
 +
import scipy.integrate
  
def MichaelisMentenReversible(substrate,product,
 
                              enzymeConcentration,kcats,
 
                              kcatp,kms,kmp):
 
    return ((((enzymeConcentration*kcats*substrate)/kms)
 
            -((enzymeConcentration*kcatp*product)/kmp))
 
            /(1+(substrate/kms)+(product/kmp)))
 
</code>
 
</pre>
 
<h4>Model File</h4>
 
<pre>
 
<code>
 
 
class model(object):
 
class model(object):
    def __init__(self):
+
def __init__(self):
        self.c_FPP_Max = 1.388E-3 #mol/L
+
self.c_ValS = 1E-6 #[M]
        self.km_ValS = 1.04E-6  #[M]
+
self.c_ADH = 1E-6 #[M]
        self.km_p450 = 126E-6 #[M]
+
self.c_P450 = 1E-6 #[M]
        self.km_ADH = 161E-6 #[M]
+
        self.kcat_ValS = 0.0032 #[1/s]
+
        self.kcat_p450 = 6 #[1/s]
+
        self.kcat_ADH = 2.619 #[1/s]
+
        self.kcat_ValSrev = self.kcat_ValS/5 #[1/s]
+
        self.kcat_p450rev = self.kcat_p450/5 #[1/s]
+
        self.kcat_ADHrev = self.kcat_ADH/5 #[1/s]
+
        self.Permeabily_FPP = 1E-6 #[1/s]
+
        self.c_ValS = 1E-6 #[M]
+
        self.c_ADH = 1E-6 #[M]
+
        self.c_p450 = 1E-6 #[M]
+
  
    def p450_Model(self,time,initvalues):
+
self.km_ValS = 1.04E-6  #[M]
        FPP,Val,Nkl,Nkt = initvalues
+
self.km_P450 = 126E-6 #[M]
        dFPPdt = (
+
self.km_ADH = 161E-6 #[M]
                k.Influx(FPP,self.c_FPP_Max,self.Permeabily_FPP)
+
                -k.MichaelisMenten(FPP,self.c_ValS,self.kcat_ValS,self.km_ValS)
+
                )
+
        dValdt = (
+
                k.MichaelisMenten(FPP,self.c_ValS,self.kcat_ValS,self.km_ValS)
+
                -k.MichaelisMenten(Val,self.c_p450,self.kcat_p450,self.km_p450)
+
                )
+
        dNkldt = (
+
                k.MichaelisMenten(Val,self.c_p450,self.kcat_p450,self.km_p450)
+
                -k.MichaelisMentenReversible(Nkl,Nkt,self.c_ADH,self.kcat_ADH,
+
                                                    self.kcat_ADHrev,self.km_ADH,self.km_ADH)
+
                )
+
        dNtkdt = (
+
                k.MichaelisMentenReversible(Nkl,Nkt,self.c_ADH,self.kcat_ADH,
+
                                                    self.kcat_ADHrev,self.km_ADH,self.km_ADH)
+
                )
+
        return [dFPPdt,dValdt,dNkldt,dNtkdt]
+
  
    def Integration(self,time,initvalues,model):
+
self.kcat_ValS = 0.0032*3600 #[1/s]
        #model = getattr(self, modelName)
+
self.kcat_P450 = 6*3600 #[1/s]
        Y = np.zeros([len(time),len(initvalues)])
+
self.kcat_ADH = 2.619*3600 #[1/s]
        r = scipy.integrate.ode(model)
+
self.k_influxSpeed = 1.03562761862e-05 #[1/s]
        r.set_integrator('lsoda')
+
        r.set_initial_value(initvalues)
+
        cnt=0
+
        while r.successful() and r.t&lt;time[-1]:
+
            cnt+=1
+
            Y[cnt,:] = r.integrate(time[cnt])
+
        return Y
+
</code>
+
</pre>
+
  
<h4>Simulation file</h4>
+
 
<pre>
+
def FPPInflux(self,FPP):
<code>
+
return(
 +
k.ConstantInflux(
 +
FPP,
 +
self.k_influxSpeed)
 +
)
 +
 
 +
def ValenceneSynthase(self,FPP):
 +
return(
 +
k.MichaelisMenten(
 +
FPP,
 +
self.c_ValS,
 +
self.kcat_ValS,
 +
self.km_ValS)
 +
)
 +
def P450(self,Valencene):
 +
return(
 +
k.MichaelisMenten(
 +
Valencene,
 +
self.c_P450,
 +
self.kcat_P450,
 +
self.km_P450)
 +
)
 +
def ADH(self,nootkatol,nootkatone):
 +
return (
 +
k.MichaelisMentenReversible(
 +
nootkatol,
 +
nootkatone,
 +
self.c_ADH,
 +
self.kcat_ADH,
 +
self.kcat_ADHrev,
 +
self.km_ADH,
 +
self.km_ADH)
 +
)
 +
 
 +
def P450_Model(self,time,initvalues):
 +
FPP,Val,Nkl,Nkn = initvalues
 +
dFPPdt = self.FPPInflux(FPP) - self.ValenceneSynthase(FPP)
 +
dValdt = self.ValenceneSynthase(FPP) - self.P450(Val)
 +
dNkldt = self.P450(Val) - self.ADH(Nkl,Nkn)
 +
dNtkdt = self.ADH(Nkl,Nkn)
 +
return [dFPPdt,dValdt,dNkldt,dNtkdt]
 +
 
 +
 
 +
def Integration(self,time,initvalues,model):
 +
Y = np.zeros([len(time),len(initvalues)])
 +
Y[0] = np.transpose(initvalues)
 +
r = scipy.integrate.ode(model)
 +
r.set_integrator('lsoda')
 +
r.set_initial_value(initvalues)
 +
cnt=1
 +
while r.successful() and cnt &lt; len(time):
 +
Y[cnt,:] = r.integrate(time[cnt])
 +
cnt+=1
 +
return Y
 +
</code>
 +
</pre>
 +
<h4>Simulation file</h4>
 +
<pre>
 +
<code>
 
from model import model
 
from model import model
 
import numpy as np
 
import numpy as np
Line 192: Line 341:
  
 
m = model()
 
m = model()
wikiPrefix = &quot;img/T--Cologne-Duesseldorf--&quot;
+
time = np.linspace(0,1,1000)
 
+
data = m.Integration(time,[0,0,0,0],m.P450_Model)
time = np.linspace(0,60,6000)
+
initvalues = [0,0,0,0]
+
data = m.Integration(time,initvalues,m.p450_Model)
+
 
plt.plot(time,data[:,0],label=(
 
plt.plot(time,data[:,0],label=(
        r&quot;FPP, $\mu_{FPP}$ = &quot;+&quot;{:.0e}&quot;.format(m.Permeabily_FPP)+r&quot; $\frac{1}{s}$&quot;
+
r&quot;FPP, $k_{FPP}$ = &quot;
        ))
+
+&quot;{:.2e}&quot;.format(m.k_influxSpeed)
 +
+r&quot; $\frac{1}{h}$&quot;
 +
))
 
plt.plot(time,data[:,1],label=(
 
plt.plot(time,data[:,1],label=(
        r&quot;Valencene, $c_{ValS}$ = &quot;+&quot;{:.0e}&quot;.format(m.c_ValS)+r&quot; $\frac{mol}{L}$&quot;
+
r&quot;Valencene, $c_{ValS}$ = &quot;
        ))
+
+&quot;{:.0e}&quot;.format(m.c_ValS)
 +
+r&quot; $\frac{mol}{L}$&quot;
 +
))
 
plt.plot(time,data[:,2],label=(
 
plt.plot(time,data[:,2],label=(
        r&quot;Nootkatol, $c_{p450}$ = &quot;+&quot;{:.0e}&quot;.format(m.c_p450)+r&quot; $\frac{mol}{L}$&quot;
+
r&quot;nootkatol, $c_{P450}$ = &quot;
        ))
+
+&quot;{:.0e}&quot;.format(m.c_P450)
 +
+r&quot; $\frac{mol}{L}$&quot;
 +
))
 
plt.plot(time,data[:,3],label=(
 
plt.plot(time,data[:,3],label=(
        r&quot;Nootkatone, $c_{ADH-21}$ = &quot;+&quot;{:.0e}&quot;.format(m.c_ADH)+r&quot; $\frac{mol}{L}$&quot;
+
r&quot;nootkatone, $c_{ADH-21}$ = &quot;
        ))
+
+&quot;{:.0e}&quot;.format(m.c_ADH)
 +
+r&quot; $\frac{mol}{L}$&quot;
 +
))
 
plt.yscale(&quot;log&quot;)
 
plt.yscale(&quot;log&quot;)
 
plt.legend(loc=9, bbox_to_anchor=(0.5, -0.2), ncol=2)
 
plt.legend(loc=9, bbox_to_anchor=(0.5, -0.2), ncol=2)
 
plt.title(&quot;First Simulation&quot;)
 
plt.title(&quot;First Simulation&quot;)
plt.xlabel(r&quot;Time in $[s]$&quot;)
+
plt.xlabel(r&quot;Time in $[h]$&quot;)
 
plt.ylabel(r&quot;Yield in $\frac{mol}{cell}$&quot;)
 
plt.ylabel(r&quot;Yield in $\frac{mol}{cell}$&quot;)
plt.savefig(wikiPrefix+&quot;first-model&quot;+&quot;.svg&quot;,bbox_inches='tight')
 
 
plt.show()
 
plt.show()
</code>
+
</code>
</pre>
+
</pre>
    <img src="https://static.igem.org/mediawiki/2017/c/cd/T--Cologne-Duesseldorf--Nootkatone-Simple-Model.svg" class="max-width">
+
<p>The results of our first simulation are the following:</p>
 
+
<img class="max-width" src="https://static.igem.org/mediawiki/2017/3/38/T--Cologne-Duesseldorf--Basic-model.svg">
    <h3>Bioreactor simulation</h3>
+
<p>What is visible in this first simulation is that the FPP import is faster than Valencene Synthase since FPP is agglomerating. However Valencene synthase, P450 BM3 and ADH are all saturated around 20 minutes, since the valencene concentration becomes stationary and nootkatol and nootkatone levels keep rising proportionally, due to the back-reaction of ADH. This is why choosing an ADH favouring the forward reaction increases the yield while keeping the metabolic stress on the cells low. </p>
    <p>In order to check the validity of our model we took the results of <abbr title="2014, Tamara Wriessnegger - Production of the sesquiterpenoid (+)-nootkatone by metabolic engineering of Pichia pastoris">Wriessnegger 2014</abbr> ()$208 \ \frac{\text{mg}}{\text{L}}$ Nootkatone production after 108 h) as a point of reference. For that we changed our modeling approach from a single cell model to a population-based model. We did this by assuming a bioreactor cell density of $200 \frac{\text{g dry  weight}}{\text{L}}$ (<a href="https://microbialcellfactories.biomedcentral.com/articles/10.1186/s12934-015-0295-4">Source</a>). This combined with a yeast dry weight of approximately $17.5E-12 \text{ g}$ (<a href="http://kirschner.med.harvard.edu/files/bionumbers/Size%20and%20composition%20of%20yeast%20cells.pdf">Kirschner Lab</a>), cell volume of $6E-14 \text{ L}$ and respective molar mass leads to a conversion factor of</p>
+
<h3>Bioreactor model</h3>
<p>$$c_{\text{Yield}} = \frac{\rho_{Bioreactor}}{m_{\text{Yeast dry weight}}} \cdot V_{\text{Yeast}} \cdot M_{\text{Product}}$$</p>
+
<p>In order to check the validity of our model we took the results of <a href="http://www.sciencedirect.com/science/article/pii/S1096717614000421"><abbr title="2014, Tamara Wriessnegger - Production of the sesquiterpenoid (+)-nootkatone by metabolic engineering of Pichia pastoris">Tamara Wriessnegger 2014</abbr></a> as a point for reference. Wriessnegger achieved $208 \ \frac{\text{mg}}{\text{L}}$ nootkatone production after $108 \text{ 0}h$ in an in-vitro production in <em>Pichia pastoris</em>. We therefore had to scale up our single cell model to a bioreactor simulation.</p>
<p>in $\frac{\text{mol}}{\text{L}}$.</p>
+
<p>In order to do this we first calculated the number of product molecules per cell.</p>
<table>
+
<p>$$\frac{\text{N}_{\text{Product}}}{\text{cell}} \ [\text{mol}]= c_{Product} [\frac{\text{mol}}{\text{L}}]\cdot V_{\text{Yeast}} \ [\text{L}]$$</p>
<thead>
+
<p>Then we calculated the number of cells per Liter bioreactor.</p>
      <tr>
+
<p>$$ \text{cells per Liter} \ [\frac{\text{1}}{\text{L}}] = \frac{\rho_{\text{Cells in Bioreactor}} \  [\frac{\text{g d.w.}}{\text{L}}] }{m_{\text{Yeast dry weight}} \ [\text{g d.w.}] } $$</p>
        <th>Parameter</th>
+
<p>With these two equations we could scale up the production of a single cell for each product.</p>
        <th>Value</th>
+
<p>$$\text{Yield}_{\text{Bioreactor}} \ [\frac{\text{mg}}{\text{L}}] = \frac{\text{N}_{\text{Product}}}{\text{cell}} \ [\text{mol}] \cdot \text{cells per Liter} \ [\frac{\text{1}}{\text{L}}] \cdot \text{M}_{\text{Product}} \ [\frac{\text{g}}{\text{mol}}]  \cdot 1000$$ </p>
        <th>Source</th>
+
<p>We used the following constants for the calculations above.</p>
</tr>
+
<table>
</thead>
+
<thead>
<tbody>
+
<tr>
      <tr>
+
<th>Parameter</th>
        <td>$\rho_{Bioreactor}$</td>
+
<th>Value</th>
        <td>$200 \ \frac{\text{g d.w.}}{\text{L}}$</td>
+
<th>Source</th>
        <td><a href="https://microbialcellfactories.biomedcentral.com/articles/10.1186/s12934-015-0295-4">Biomedcentral</a></td>
+
</tr>
</tr>
+
</thead>
<tr>
+
<tbody>
        <td>$m_{\text{Yeast dry weight}}$</td>
+
<tr>
        <td>$17.5E-12 \text{ g}$</td>
+
<td>$\rho_{Bioreactor}$</td>
        <td><a href="http://kirschner.med.harvard.edu/files/bionumbers/Size%20and%20composition%20of%20yeast%20cells.pdf">Kirschner Lab</a></td>
+
<td>$200 \ \frac{\text{g d.w.}}{\text{L}}$</td>
</tr>
+
<td><a href="https://microbialcellfactories.biomedcentral.com/articles/10.1186/s12934-015-0295-4">Biomedcentral</a></td>
<tr>
+
</tr>
        <td>$V_{\text{Yeast}}$</td>
+
<tr>
        <td>$6E-14 \text{ L}$</td>
+
<td>$m_{\text{Yeast dry weight}}$</td>
        <td><abbr title="2012, Rob Phillips - Physical Biology of the Cell">Philips 2012</abbr></td>
+
<td>$17.5E-12 \text{ g}$</td>
</tr>
+
<td><a href="http://kirschner.med.harvard.edu/files/bionumbers/Size%20and%20composition%20of%20yeast%20cells.pdf">Kirschner Lab</a></td>
<tr>
+
</tr>
        <td>$M_{\text{FPP}}$</td>
+
<tr>
        <td>$382.33 \  \frac{\text{g}}{\text{mol}}$</td>
+
<td>$V_{\text{Yeast}}$</td>
        <td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/445713">Pubchem</a></td>
+
<td>$6E-14 \text{ L}$</td>
</tr>
+
<td><abbr title="2012, Rob Phillips - Physical Biology of the Cell">Philips 2012</abbr></td>
<tr>
+
</tr>
        <td>$M_{\text{Valencene}}$</td>
+
<tr>
        <td>$204.36 \  \frac{\text{g}}{\text{mol}}$</td>
+
<td>$M_{\text{FPP}}$</td>
        <td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/valencene">Pubchem</a></td>
+
<td>$382.33 \  \frac{\text{g}}{\text{mol}}$</td>
</tr>
+
<td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/445713">Pubchem</a></td>
<tr>
+
</tr>
        <td>$M_{\text{Nootkatol}}$</td>
+
<tr>
        <td>$220.35 \ \frac{\text{g}}{\text{mol}}$</td>
+
<td>$M_{\text{Valencene}}$</td>
        <td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/nootkatol">Pubchem</a></td>
+
<td>$204.36 \  \frac{\text{g}}{\text{mol}}$</td>
</tr>
+
<td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/valencene">Pubchem</a></td>
<tr>
+
</tr>
        <td>$M_{\text{Nootkatone}}$</td>
+
<tr>
        <td>$218.34 \ \frac{\text{g}}{\text{mol}}$</td>
+
<td>$M_{\text{Nootkatol}}$</td>
        <td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/nootkatone">Pubchem</a></td>
+
<td>$220.35 \ \frac{\text{g}}{\text{mol}}$</td>
</tr>
+
<td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/nootkatol">Pubchem</a></td>
</tbody>
+
</tr>
</table>
+
<tr>
 
+
<td>$M_{\text{Nootkatone}}$</td>
 +
<td>$218.34 \ \frac{\text{g}}{\text{mol}}$</td>
 +
<td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/nootkatone">Pubchem</a></td>
 +
</tr>
 +
</tbody>
 +
</table>
 +
<h3>Bioreactor simulation</h3>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/2/26/T--Cologne-Duesseldorf--Bioreactor-Dynamics.svg">
 +
<p>Our model predicts a nootkatone Yield of $154.24 \ \frac{\text{mg}}{\text{L}}$ and a nootkatol Yield of $31.06  \ \frac{\text{mg}}{\text{L}}$. Wriessnegger produced $208 \ \frac{\text{mg}}{\text{L}}$ nootkatone and $44 \ \frac{\text{mg}}{\text{L}}$ nootkatol. This showed us that our assumption of a five-fold reduction in the backwards reaction of alcohol dehydrogenase is valid, as our $\frac{\text{nootkatone}}{\text{nootkatol}}$ ratio was 4.96, which is quite close to the 4.72 by Wriessnegger. We then took a look at how differently expressing the enzymes would have an influence on nootkatone production.</p>
 +
<h4>Expression analysis</h4>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/a/a3/T--Cologne-Duesseldorf--Bioreactor-Expression-2D.svg">
 +
<img class="max-width"  src="https://static.igem.org/mediawiki/2017/8/8f/T--Cologne-Duesseldorf--Bioreactor-Expression-3D.svg">
 +
<p>The first figure shows the nootkatone yield based on a varied enzyme concentration of all enzymes, while the other enzyme concentrations were kept constant at $1 \text{ µM}$. The second plot shows varied enzyme concentrations for all enzymes at the same time. The smallest concentration with almost maximal nootkatone production is at about $2 \text{ µM}$ Valencene Synthase, when not over increasing the other enzymes. Therefore we chose to double the expression of Valencene Synthase to ensure that our pathway is saturated.</p>
 +
<img class="max-width"  src="https://static.igem.org/mediawiki/2017/5/5e/T--Cologne-Duesseldorf--Bioreactor-ValS-Up.svg">
 +
<p>This increased our yield above the results by Wriessnegger. But our model still lacks the important factor of product toxicity at high concentration, which is why we did not fit the FPP import to this, but to the <a href="Penalty-Model">next model</a>.</p>
 +
<h3>Toxicity</h3>
 +
<p>According to <a href="http://www.sciencedirect.com/science/article/pii/S1096717613000293"><abbr title="2013, Gavira - Challenges and pitfalls of P450-dependent (+)-valencene bioconversion by Saccharomyces cerevisiae">Carole Gavira 2013</abbr></a> both nootkatone and nootkatol exhibit toxicity at high levels. At $100 \ \frac{\text{mg}}{\text{L}}$ nootkatol the cell viability was decreased to 55%, at $100 \ \frac{\text{mg}}{\text{L}}$ nootkatone to 80%. For both substances all cells were dead around $1000 \ \frac{\text{mg}}{\text{L}}$. We used hill kinetics to fit this behaviour.</p>
 +
<p>$$\frac{K_{Tox}^n}{K_{Tox}^n + [S]^n}$$</p>
 +
<p>We fitted the data of Gavira using <code>scipy.optimize.brent</code> and multiple factors <code>n</code>. This is due to the fact that <code>n</code> is only valid in integer values and <code>scipy</code> does not support mixed-integer optimizations. We further chose to only implement nootkatone toxicity, even if it is the less toxic compound, as it is concentrated approximately five times higher than nootkatol in the cell. This also helped to keep our model simple.</p>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/b/bf/T--Cologne-Duesseldorf--Toxicity.svg">
 +
<table>
 +
<thead>
 +
<tr>
 +
<th>$\text{n}$</th>
 +
<th>$K_{\text{Toxic nootkatol}}$</th>
 +
<th>Error</th>
 +
</tr>
 +
</thead>
 +
<tbody>
 +
<tr>
 +
<td>2</td>
 +
<td>200</td>
 +
<td>0.136</td>
 +
</tr>
 +
<tr>
 +
<td>3</td>
 +
<td>158.74</td>
 +
<td>0.104</td>
 +
</tr>
 +
<tr>
 +
<td>4</td>
 +
<td>141.42</td>
 +
<td>0.100</td>
 +
</tr>
 +
<tr>
 +
<td>5</td>
 +
<td>131.95</td>
 +
<td>0.100</td>
 +
</tr>
 +
<tr>
 +
<td>6</td>
 +
<td>125.99</td>
 +
<td>0.100</td>
 +
</tr>
 +
</tbody>
 +
</table>
 +
<p>Even though the error produced by functions with a higher <code>n</code> was decreasing we chose to use <code>n = 3</code> to prevent overfitting, since <code>n = 3</code> already fit both points quite well.</p>
 +
<p>We used this penalty function only on our FPP import. The idea behind that was that since the whole pathway depends linearly on the FPP influx it can act representative for the cell viability. This turned out to show some problems later in the model but we chose to keep this assumption, as the problems can be addressed by proper interpretation of the data and because we wanted to keep our model simple.</p>
 +
<p>This changes our system in the following way.</p>
 +
<img class="half-width" src="https://static.igem.org/mediawiki/2017/b/b7/T--Cologne-Duesseldorf--nkl-pathway-inhibition.svg">
 +
<p>$$\frac{dFPP}{dt} = v_{\text{FPP in}} \cdot \frac{K_{\text{Tox Nkn}}^3}{K_{\text{Tox Nkn}}^3 + [\text{Nkn}]^3} - \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} $$</p>
 +
<h3 id="Penalty-Model">Penalty model</h3>
 +
<h4>Dynamics</h4>
 +
<p>This is the model where we actually fitted our import parameter to the data supplied by Wriessnegger, as we assumed it to be sufficiently close to the actual biological reality. We did this by using <code>scipy.optimize.brent</code> to minimize the error function $\text{abs}(208 - [S]_{\text{nootkatol}})$. This gave us an import rate of $6.55E-9 \frac{1}{\text{s}}$, which we then also used in all other models, including the ones shown previously.</p>
 +
<!-- img penalty -->
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/2/27/T--Cologne-Duesseldorf--Bioreactor-Penalty-Dynamics.svg">
 +
<p>The nootkatone yield is approximately at the results of Wriessnegger and we can see that the FPP import declines with increasing nootkatone production. The penalty function can be interpreted as the fraction of alive cells, which at the final point of the simulation is $52.16 \ \%$. This huge number already gives us an understanding that nootkatol and nootkatone production limit themselves in cytosolic production, thus showing us the first culprit of nootkatone production.</p>
 +
<h4>Expression</h4>
 +
<p>We wanted to check whether over- or underexpression of any of the enzymes could improve our nootkatone yield under penalty conditions.</p>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/1/15/T--Cologne-Duesseldorf--Bioreactor-Penalty-Expression-2D.svg">
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/0/00/T--Cologne-Duesseldorf--Bioreactor-Penalty-Expression-3D.svg">
 +
<p>Interestingly the peak nootkatone yield is now under submaximal Valencene Synthase expression. This is possibly due to the increased toxicity. In order to check this we further increased the FPP import tenfold over the fitted value.</p>
 +
<h4>Increased FPP import dynamics</h4>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/7/74/T--Cologne-Duesseldorf--Bioreactor-Penalty-FPP-Up-Dynamics.svg">
 +
<p>The maximal yield under increased FPP import conditions is increased, but at the end of the simulation only around $11 \ \%$ of the cell population is alive. This is the problem of the model that we talked earlier about. In this case the early FPP import so fast compared to the enzymatic reactions so that FPP accumulates. Since only the import is penalized, but not the other reactions, all that follows is an simulation of dead cells still transforming an large FPP pool. This is obviously biologically wrong and an artifact of the way the penalty is set up. The effects of this error can be seen in the variation of single enzyme concentrations in the plots below.</p>
 +
<h4>Increased FPP import expression</h4>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/a/ac/T--Cologne-Duesseldorf--Bioreactor-Penalty-FPP-Up-Expression-2D.svg">
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/c/c0/T--Cologne-Duesseldorf--Bioreactor-Penalty-FPP-Up-Expression-3D.svg">
 +
<h4 id="Bioreactor-Penalty-FPP-Up-Enzymes-Up-Dynamics">Increased FPP import and enzyme concentration dynamics</h4>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/6/62/T--Cologne-Duesseldorf--Bioreactor-Penalty-FPP-Up-Enzymes-Up-Dynamics.svg">
 +
<p>Even with this submaximal production only $4 \ \%$ of cells are alive at the end of the simulation. So even if the results of the production with a tenfold increased FPP influx have to be interpreted carefully, the general takeaway of the simulation is that given a sufficiently high FPP influx, nootkatone toxicity is the main remaining culprit of nootkatone production. This is where our nootkatone subproject comes in. By transferring the enzymes needed for nootkatone production into the peroxisome we assume that the products cannot diffuse back into the cell and therefore do not impose any toxicity on the cells. This can be seen by the great increase in nootkatone production in the models below.</p>
 +
<h3 id="Peroxisome-model">Peroxisome model</h3>
 +
<!-- Beta-nootkatol seems to accumulate in membranes which changes their permeability, integrity and the function of membrane proteins which therefore contributes to the toxicity -> therefore not toxic in peroxisome? -->
 +
<p>Since peroxisomes vary greatly in size we first assumed them to be as large as the yeast cells. While this assumption is clearly wrong, we later show the minimal size needed under specific conditions to outperform cytosolic production. Since we assume no nootkatone and nootkatol toxicity inside the peroxisome, the general reaction dynamics are equal to the simple bioreactor model, but with overexpressed Valencene Synthase. We first modeled the maximal nootkatone yield with varying enzyme concentrations.</p>
 +
<h4>Expression</h4>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/3/38/T--Cologne-Duesseldorf--Bioreactor-Peroxisome-Expression-2D.svg">
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/c/c0/T--Cologne-Duesseldorf--Bioreactor-Peroxisome-Expression-3D.svg">
 +
<p>What can be seen here as before is that the maximal nootkatone yield is determined by the FPP import and that Valencene Synthase is the velocity dictating enzyme. Even at a high expression of Valencene Synthase increasing either P450 BM3 or ADH over $1E-8 \ \frac{\text{mol}}{\text{L}}$ does not further increase the nootkatone yield, as the two enzymes are faster than Valencene Synthase. To further increase nootkatone yield the FPP import has to be increased. In this case the nootkatone yield can be increased linearly, as shown below.</p>
 +
<h4>Increased FPP import dynamics</h4>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/f/f5/T--Cologne-Duesseldorf--Bioreactor-Peroxisome-FPP-Up-Dynamics.svg">
 +
<h4>Increased FPP import expression</h4>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/b/b5/T--Cologne-Duesseldorf--Bioreactor-Peroxisome-FPP-Up-Expression-2D.svg">
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/9/92/T--Cologne-Duesseldorf--Bioreactor-Peroxisome-FPP-Up-Expression-3D.svg">
 +
<h4 id="Bioreactor-Peroxisome-FPP-Up-Enzymes-Up-Dynamics">Increased FPP increased enzyme concentration dynamics</h4>
 +
<img class="max-width" src="https://static.igem.org/mediawiki/2017/5/5f/T--Cologne-Duesseldorf--Bioreactor-Peroxisome-FPP-Up-Enzymes-Up-Dynamics.svg">
 +
<h3>Conclusion</h3>
 +
<table>
 +
<thead>
 +
<tr>
 +
<th>Model</th>
 +
<th>Nootkatone</th>
 +
<th>Nootkatol</th>
 +
</tr>
 +
</thead>
 +
<tbody>
 +
<tr>
 +
<td>Bioreactor</td>
 +
<td>154.24*</td>
 +
<td>31.06*</td>
 +
</tr>
 +
<tr>
 +
<td>Bioreactor ValS Up</td>
 +
<td>302.87*</td>
 +
<td>61.36*</td>
 +
</tr>
 +
<tr>
 +
<td>Penalty</td>
 +
<td>206.10</td>
 +
<td>41.40</td>
 +
</tr>
 +
<tr>
 +
<td>Penalty FPP Up</td>
 +
<td>309.62**</td>
 +
<td>62.73**</td>
 +
</tr>
 +
<tr>
 +
<td>Penalty FPP + Enzymes Up</td>
 +
<td>456.93**</td>
 +
<td>91.43**</td>
 +
</tr>
 +
<tr>
 +
<td>Peroxisome Enzymes Up</td>
 +
<td>317.83</td>
 +
<td>64.65</td>
 +
</tr>
 +
<tr>
 +
<td>Peroxisome FPP Up</td>
 +
<td>309.63</td>
 +
<td>62.73</td>
 +
</tr>
 +
<tr>
 +
<td>Peroxisome FPP + Enzymes Up</td>
 +
<td>3082.86</td>
 +
<td>624.14</td>
 +
</tr>
 +
</tbody>
 +
</table>
 +
<p>As can be seen from our simulations, the two main culprits of nootkatone production are the toxicity of the products at high concentrations and the FPP influx. The toxicity can be avoided by transferring the pathway into the peroxisome, which is one of the projects of our team. To address the problem of FPP influx our team did an <a href="#optknock">opt-knock FBA analysis</a> to show how S. cerevisiae cells can be engineered to stably produce more FPP. Note that the values marked with an asterisk were produced by an incomplete model and values marked with two asterisks are assumed to be false due to the model setup as explained in the sections above.</p>
 +
<h3>Further thoughts</h3>
 +
<p>A false assumption in the peroxisomal models above is that the size of the peroxisome is equal to that of the yeast cell. This is obviously not correct. We wanted to get a feeling how large the peroxisome actually has to be in order for production to be superior to cytosolic production. We therefore took the the results of the cytosolic model with <a href="Bioreactor-Penalty-FPP-Up-Enzymes-Up-Dynamics">increased FPP intake and enzyme concentration</a> and then calculated the yield of the <a href="Bioreactor-Peroxisome-FPP-Up-Enzymes-Up-Dynamics">corresponding peroxisomal model</a> with varying peroxisome size.</p>
 +
<img class="max-width"  src="https://static.igem.org/mediawiki/2017/7/73/T--Cologne-Duesseldorf--Size-comparison.svg">
 +
<p>We calculated the volume for equal production</p>
 +
<p>$$V_{\text{Perox. Equal}} = \frac{\text{Yield}_{\text{Cyt.}} \cdot V_{\text{Yeast}}}{\text{Yield}_{\text{Perox.}}}$$</p>
 +
<p>to be $1.24E-14 \ \text{L}$, so approximately a fifth of the cell volume. Since in methylotrophic yeasts such as Pichia pastoris peroxisomes can take up to 80% of the total cell volume (<abbr title="1988, Gleeson - The methylotrophic yeasts">Gleeson </abbr>), a fifth of the cell volume is very achievable. To further increase the possible yield our team is working on a <a ref="#!">Pex11-knockout</a> that aims to increase peroxisome size</p>
 +
</div>
  
 +
<button class="accordion">
 +
<h2 id=OptKnock>OptKnock Analysis</h2>
 +
</button>
 +
<div class="panel">
 +
<h3>Background</h3>
 +
<h4>Constraint based modeling</h4>
 +
<p>Constraint based modeling is a mechanistically method to simulate complex metabolic networks under the critical assumption that the network is in a steady state. It requires a reconstructed metabolic network, in which all reactions have been characterized stoichiometrically. The network is then represented by the stoichiometric matrix $S$, in which each column corresponds to a reaction and each row to a metabolite. The reactions are further constrained only allowing positive fluxes $v_i \geq 0$ (elementary modes) and by putting upper and lower bounds on the flux (turnover rate). This reduces the solution space into a convex polyhedral cone, in which every point is a non-negative combination of elementary modes and every edge a unique elementary mode. As metabolic networks typically have more reactions than metabolites, the systems are underdetermined and therefore the flux distribution is not definitive. To find the actual biological solution additional constraints have to be added, for example an objective function that is to be optimized.</p>
 +
<h4>Flux Balance Analysis</h4>
 +
<p>A sensible objective function should in our case describe the main driver behind evolution - natural selection. This can be accomplished by defining a biomass production term $Z = c^Tv$, which consists of several biomass precursor reactions merged into one unit. Therefore the optimization finds the flux distribution with which maximal biomass production is accomplished, which is in accordance to natural selection.</p>
 +
<p> In matrix formalism this can be written as
 +
$Sv = 0$, where $S$ is the stoichiometric matrix and $v$ the vector of fluxes that is to be solved.$c$ is the vector that defines the weights of each flux in the objective function. The canonical form of a Flux Balance Analysis thus can be written as
 +
</p>
 +
<p>$$\text{maximize } c^Tv$$</p>
 +
<p>$$\text{subject to } Sv = 0$$</p>
 +
<p>$$\text{and lower bound } \leq v \leq \text{upper bound}$$</p>
 +
<p>This is a linear optimization which due to the convex solution space can be calculated efficiently with linear programming.</p>
 +
<h4 id="OptKnock">OptKnock</h4>
 +
<p>Metabolic engineering faces two big problems. Firstly the precursor molecule for the wanted reaction can only be found in trace amounts in the cell, leading to minor yields of the wanted product. Secondly adding pathways to the metabolism of an organism increases the metabolic stress on that organism. Thus if the cell loses the ability to produce the desired compound it can overgrow the other cells in a large-scale bioreactor setting. OptKnock (<a href="http://onlinelibrary.wiley.com/doi/10.1002/bit.10803/"><abbr title="Anthony P. Burgard 2003 - Optknock: A bilevel programming framework for identifying gene knockout strategies for microbial strain optimization">Anthony P. Burgard 2003</abbr></a>) is a two step optimization in which biomass production is coupled to the production of a desired product by calculating a set of gene knockouts, solving both problems above.In principle the algorithm works like this:</p>
 +
<p>
 +
$$
 +
\left[
 +
\begin{array}{ll}
 +
\text{Maximize Product} \\
 +
\text{(over knockouts)} \\
 +
\text{Subject to} &
 +
\left[
 +
\begin{array}{ll}
 +
\text{Maximize biomass} \\
 +
\text{(over fluxes)} \\
 +
\text{Subject to} &
 +
\left[
 +
\begin{array}{l}
 +
\text{Fixed substrate uptake rate} \\
 +
\text{Network Stoichiometry} \\
 +
\text{Knockouts identified by outer problem} \\
 +
\end{array}
 +
\right] \\
 +
\end{array}
 +
\right] \\
 +
\text{Minimum biomass yield} \\
 +
\text{N}_{\text{Knockouts}} \leq \text{ limit}
 +
\end{array}
 +
\right]
 +
$$
 +
</p>
 +
<p>We visualized the concept in the following two pictures. The important point here is to notice that the maximal biomass flux in the OptKnock model at the same time corresponds to a high product flux.</p>
 +
<div class="flex-row-2">
 +
<div><img class="max-width" src="https://static.igem.org/mediawiki/2017/b/b4/T--Cologne-Duesseldorf--OptKnock-Solution-Space-Wildtype.svg"></div>
 +
<div><img class="max-width" src="https://static.igem.org/mediawiki/2017/3/34/T--Cologne-Duesseldorf--OptKnock-Solution-Space-OptKnock.svg"></div>
 +
</div>
 +
<h3>Results</h3>
 +
<p>We analyzed the FPP pool by using Geranyltranstransferase (GRTT) as the reaction to be optimized. GRTT takes geranyl diphosphate and isopentenyl diphosphate and converts them to farnesyl pyrophosphate and diphosphate. The two results below show the maximal GRTT production with a minimal biomass yield of 0.1 and 0.2 respectively. </p>
 +
<div class="flex-row-2">
 +
<div><img class="max-width" src="https://static.igem.org/mediawiki/2017/c/cd/T--Cologne-Duesseldorf--OptKnock.svg"></div>
 +
<div><img class="max-width" src="https://static.igem.org/mediawiki/2017/0/02/T--Cologne-Duesseldorf--OptKnock-Biomass-Up.svg"></div>
 +
</div>
  
    <!-- Plot p450 Bioreactor -->
+
<p>Compared to the wild type FPP flux (0.0013) the maximal fluxes that could be achieved with four knockouts were 0.61
    <img src="https://static.igem.org/mediawiki/2017/f/f7/T--Cologne-Duesseldorf--Nootkatone-p450-Model-Bioreactor.svg">
+
and 0.29, respective to the minimal biomass yield of 0.1 and 0.2. This roughly corresponds to a 480- and 230-fold increase in FPP flux. While we do not think that these results are close to the actual biological truth, as a 230- or 480-fold increase is rather extreme, we did notice an accumulation of knockouts in genes related to the pentose phosphate pathway (TKT2 = TransketolaseG6PDH2r = Glucose-6-phosphate dehydrogenase) or citric acid cycle (ALATA_L L-alanine transaminase). Further reactions like ADK3 (Adentylate kinase (GTP)), which is indirectly involved in the TCA by supplying GDP or IPPSm (2 isopropylmalate synthase mitochondrial) that takes acetyl-CoA as a substrate lead us to the conclusion that the cellular FPP pool can be increased by shifting to a fatty acid metabolism. This is further solidified by the fact that the FPP precursor isopentenyl diphosphate ultimately is build from acetyl-CoA <abbr title="2017, Sebastián Rubat - Increasing the intracellular isoprenoid pool in Saccharomyces cerevisiae by structural fine-tuning of a bifunctional farnesyl diphosphate synthase">Sebastián Rubat 2017</abbr>.
    <p>The yield of $154.9 \ \frac{\text{mg}}{\text{L}}$ Nootkatol was lower than the published results of Wriessnegger 2014. Our first guess was that the assumption of all enzymes being equally concentrated was probably false. We therefore varied the enzyme concentrations and found that overexpression of valencene synthase increased the yield dramatically by converting way more FPP than before, while overexpressing the other enzymes had little to no effect at all:</p>
+
</p>
    <!-- Plot Expression analysis -->
+
<p>We then integrated the nootkatone pathway into the metabolic model and reran the optimization.</p>
    <img src="https://static.igem.org/mediawiki/2017/8/8a/T--Cologne-Duesseldorf--Nootkatone-Expression-3D.svg">
+
<img class="max-width" src="https://static.igem.org/mediawiki/2017/d/d8/T--Cologne-Duesseldorf--OptKnock-Nootkatol.svg">
    <p>What can be seen in the plot above is that the system is mostly influenced by concentration changes of valencene synthase. Since the Nootkatone production did not seem to increase further after increasing the valencene synthase concentration by 20-fold, we stuck to that number and simulated our model under the changed conditions.</p>
+
<p>The general trend of the knockouts continued in this model. In this fashion reactions in the TCA (MDH = Malate dehydrogenase), glycolysis (G6PI3 = Glucose 6 phosphate isomerase) and fermentation (PYRDC = Pyruvate decarboxylase) were knocked-out. This further solidifies our hypothesis, that the analysis builds a cell metabolism that favors fatty acid breakdown.</p>
    <!-- Plot p450 Bioreactor ValS Up-->
+
</div>
    <img src="https://static.igem.org/mediawiki/2017/e/ed/T--Cologne-Duesseldorf--Nootkatone-p450-Model-Bioreactor-Val-Up.svg">
+
</article>
    <p>The maximal yield of this simulation was $2965.0 \ \frac{\text{mg}}{\text{L}}$ Nootkatone and $670.0 \frac{\text{mg}}{\text{L}}$ Nootkatol, greatly exceeding the maximal concentration achieved by Wriessnegger 2014. But our $\frac{\text{Nootkatone}}{\text{Nootkatol}}$ ratio was quite similar and we therefore deduced that the reaction mechanism we assumed seemed to be quite accurate. We found two possible explanations for the overly high yield. On the one hand our assumption for the maximal FPP concentration could have been false. The total yield of the model scales with FPP supply, so that could be the error. On the other hand, a known fact about Nootkatone production is the the toxicity of the Nootkatone precursor Nootkatol. According to <a href="http://www.sciencedirect.com/science/article/pii/S1096717613000293">Gavira 2013</a> the toxic nootkatol concentration for yeast is around $ 100 \frac{\text{mg}}{\text{L}}$.</p>
+
</body>
    <h3>Nootkatol penalty</h3>
+
    <p>We therefore expanded our model using a Hill function alike penalty function for increasing nootkatol concentration, which we applied to the FPP production representative for the whole yeast cell biomass production:
+
    $$\frac{dFPP}{dt} = \mu_{FPP} \cdot (Max_{FPP} - c_{FPP}) \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot K_M^n} - \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} $$
+
    The system reacted in the following way:</p>
+
    <!-- Plot Nootkatol FPP penalty -->
+
    <img src="https://static.igem.org/mediawiki/2017/d/de/T--Cologne-Duesseldorf--Nootkatone-Penalty-FPP.svg">
+
    <p>The yield of $438.5 \ \frac{\text{mg}}{\text{L}}$ Nootkatone and $88.7 \frac{\text{mg}}{\text{L}}$ Nootkatol with a $\frac{\text{Nootkatone}}{\text{Nootkatol}}$ ratio of $\approx 4.9$ is way closer to the publication of <a href="http://www.sciencedirect.com/science/article/pii/S1096717614000421">Wriessnegger 2014</a> ($208 \ \frac{\text{mg}}{\text{L}}$), which led us to the conclusion that our model is already a quite accurate description of the pathway.</p>
+
    <h3>Extended Nootkatol penalty</h3>
+
    <p>The assumption of penalizing only the FPP influx representative for the whole activity of the cell is rather crude and we therefore wanted to check whether penalizing every reaction in the pathway with increased Nootkatol concentration would yield different results.</p>
+
    <p>$$\frac{dFPP}{dt} = \mu_{FPP} \cdot (Max_{FPP} - c_{FPP}) \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n} - \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}}$$</p>
+
    <p>$$\frac{dValencene}{dt} = \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot K_M^n} - \frac{V_{Max,p450\_BM3} \cdot c_{Valencene}}{K_{M, p450\_BM3} + c_{Valencene}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n} $$</p>
+
    <p>$$\frac{dNootkatol}{dt} = \frac{V_{Max,p450\_BM3} \cdot c_{Valencene}}{K_{M, p450\_BM3} + c_{Valencene}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n} - \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n} $$</p>
+
    <p>$$\frac{dNootkatone}{dt} = \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot K_M^n}$$</p>
+
    <!-- Plot Nootkatol all penalty -->
+
    <img src="https://static.igem.org/mediawiki/2017/7/75/T--Cologne-Duesseldorf--Nootkatone-Penalty-All.svg">
+
    <p>This model yielded a maximal yield of $398.4 \ \frac{\text{mg}}{\text{L}}$ Nootkatone, $90.4 \frac{\text{mg}}{\text{L}}$ Nootkatol and a $\frac{\text{Nootkatone}}{\text{Nootkatol}}$ ratio of $ \approx 4.4$.</p>
+
    <h3>Reversibility</h3>
+
    <p>Since we assumed that Nootkatone is not degraded and that the reaction is reversible both substances accumulate in our model. This challenges the assumption that only the reaction catalysed by the alcohol dehydrogenase is reversible. We therefore set up a model in which every reaction is reversible and varied the speed of the back reaction to get a feeling of how the system might react to the overaccumulation. We kept the penalty on FPP.</p>
+
    <p>$$\ce{FPP <->[ValS] Valencene <->[HPO] ValenceneO <->[CPR] Nootkatol <->[ADH] Nootkatone}$$</p>
+
    <p>$$\frac{dFPP}{dt} = \mu_{FPP} \cdot (Max_{FPP} - c_{FPP}) \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n}  - \frac{\frac{V_{M,ValS+} \cdot c_{FPP}}{K_{M,ValS+}} - \frac{V_{M,ValS-} \cdot c_{Valencene}}{K_{M,ADH-}}}{1 + \frac{c_{FPP}}{K_{M,ValS+}} + \frac{c_{Valencene}}{K_{M,ValS-}}}$$</p>
+
    <p>$$\frac{dValencene}{dt} = \frac{\frac{V_{M,ValS+} \cdot c_{FPP}}{K_{M,ValS+}} - \frac{V_{M,ValS-} \cdot c_{Valencene}}{K_{M,ADH-}}}{1 + \frac{c_{FPP}}{K_{M,ValS+}} + \frac{c_{Valencene}}{K_{M,ValS-}}} - \frac{\frac{V_{M,p450+} \cdot c_{Valencene}}{K_{M,p450+}} - \frac{V_{M,p450-} \cdot c_{Nootkatol}}{K_{M,p450-}}}{1 + \frac{c_{Valencene}}{K_{M,p450+}} + \frac{c_{Nootkatol}}{K_{M,p450-}}}$$</p>
+
    <p>$$\frac{dNootkatol}{dt} = \frac{\frac{V_{M,p450+} \cdot c_{Valencene}}{K_{M,p450+}} - \frac{V_{M,p450-} \cdot c_{Nootkatol}}{K_{M,p450-}}}{1 + \frac{c_{Valencene}}{K_{M,p450+}} + \frac{c_{Nootkatol}}{K_{M,p450-}}} - \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$</p>
+
    <p>$$\frac{dNootkatone}{dt} = \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$</p>
+
    <!-- Plot Reversible FPP penalty -->
+
    <img src="https://static.igem.org/mediawiki/2017/2/2b/T--Cologne-Duesseldorf--Nootkatone-All-Reversible.svg">
+
    <p>This model yielded a maximal yield of $437.9 \ \frac{\text{mg}}{\text{L}}$ Nootkatone,  $88.6 \frac{\text{mg}}{\text{L}}$ Nootkatol and a $\frac{\text{Nootkatone}}{\text{Nootkatol}}$ ratio of $ \approx 4.9$.</p>
+
    <p>As with the non-reversible model we wanted to check how a penalty on all reactions would change the way the model behaved.</p>
+
    <p>$$\frac{dFPP}{dt} = \mu_{FPP} \cdot (Max_{FPP} - c_{FPP}) \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n}  - \frac{\frac{V_{M,ValS+} \cdot c_{FPP}}{K_{M,ValS+}} - \frac{V_{M,ValS-} \cdot c_{Valencene}}{K_{M,ADH-}}}{1 + \frac{c_{FPP}}{K_{M,ValS+}} + \frac{c_{Valencene}}{K_{M,ValS-}}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n} $$</p>
+
    <p>$$\frac{dValencene}{dt} = \frac{\frac{V_{M,ValS+} \cdot c_{FPP}}{K_{M,ValS+}} - \frac{V_{M,ValS-} \cdot c_{Valencene}}{K_{M,ADH-}}}{1 + \frac{c_{FPP}}{K_{M,ValS+}} + \frac{c_{Valencene}}{K_{M,ValS-}}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n} - \frac{\frac{V_{M,p450+} \cdot c_{Valencene}}{K_{M,p450+}} - \frac{V_{M,p450-} \cdot c_{Nootkatol}}{K_{M,p450-}}}{1 + \frac{c_{Valencene}}{K_{M,p450+}} + \frac{c_{Nootkatol}}{K_{M,p450-}}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n} $$</p>
+
    <p>$$\frac{dNootkatol}{dt} = \frac{\frac{V_{M,p450+} \cdot c_{Valencene}}{K_{M,p450+}} - \frac{V_{M,p450-} \cdot c_{Nootkatol}}{K_{M,p450-}}}{1 + \frac{c_{Valencene}}{K_{M,p450+}} + \frac{c_{Nootkatol}}{K_{M,p450-}}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n} - \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n} $$</p>
+
    <p>$$\frac{dNootkatone}{dt} = \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}} \cdot \frac{c_{Nootkatol,Toxic} \cdot K_M^n}{c_{Nootkatol}+ c_{Nootkatol,Toxic} \cdot  K_M^n}$$</p>
+
    <!-- Plot All Reversible All penalty -->
+
    <img src="https://static.igem.org/mediawiki/2017/b/bb/T--Cologne-Duesseldorf--Nootkatone-All-Reversible-All-Penalty-Model.svg">
+
    <p>This model yielded a maximal yield of $394.2 \ \frac{\text{mg}}{\text{L}}$ Nootkatone,  $88.1 \frac{\text{mg}}{\text{L}}$ Nootkatol and a $\frac{\text{Nootkatone}}{\text{Nootkatol}}$ ratio of $ \approx 4.4$.</p>
+
    <p>A thing we wanted to check at this point was if the introduction of reversible reactions and penalty terms changed the behaviour of our expression analysis and we thus conducted it for a second time, now with the changed model:</p>
+
    <!-- Plot 3D Expression All Reversible All Penalty -->
+
    <img src="https://static.igem.org/mediawiki/2017/1/1f/T--Cologne-Duesseldorf--Nootkatone-Expression-3D-All-Reversible-All-Penalty.svg">
+
    <p>Apparently, less overexpression of Valencene synthase is needed, whereas now the overexpression of ADH-21 has little effect of overall Nootkatone production, compared to no effect before.</p>
+
    <h3>Peroxisome model</h3>
+
    <p>Having explored the dynamics of the reactions involved we further wanted know whether using peroxisomes to produce Nootkatone would increase the yield as expected. Since we assume that the toxic intermediate Nootkatol cannot diffuse out of the peroxisome, the production has no penalty terms, but we assume all processes to be reversible:</p>
+
    <p>$$\frac{dFPP}{dt} = \mu_{FPP} \cdot (Max_{FPP} - c_{FPP}) - \frac{\frac{V_{M,ValS+} \cdot c_{FPP}}{K_{M,ValS+}} - \frac{V_{M,ValS-} \cdot c_{Valencene}}{K_{M,ADH-}}}{1 + \frac{c_{FPP}}{K_{M,ValS+}} + \frac{c_{Valencene}}{K_{M,ValS-}}}$$</p>
+
    <p>$$\frac{dValencene}{dt} = \frac{\frac{V_{M,ValS+} \cdot c_{FPP}}{K_{M,ValS+}} - \frac{V_{M,ValS-} \cdot c_{Valencene}}{K_{M,ADH-}}}{1 + \frac{c_{FPP}}{K_{M,ValS+}} + \frac{c_{Valencene}}{K_{M,ValS-}}} - \frac{\frac{V_{M,p450+} \cdot c_{Valencene}}{K_{M,p450+}} - \frac{V_{M,p450-} \cdot c_{Nootkatol}}{K_{M,p450-}}}{1 + \frac{c_{Valencene}}{K_{M,p450+}} + \frac{c_{Nootkatol}}{K_{M,p450-}}}$$</p>
+
    <p>$$\frac{dNootkatol}{dt} = \frac{\frac{V_{M,p450+} \cdot c_{Valencene}}{K_{M,p450+}} - \frac{V_{M,p450-} \cdot c_{Nootkatol}}{K_{M,p450-}}}{1 + \frac{c_{Valencene}}{K_{M,p450+}} + \frac{c_{Nootkatol}}{K_{M,p450-}}} - \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$</p>
+
    <p>$$\frac{dNootkatone}{dt} = \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$</p>
+
    <!-- Plot All Reversible, no Penalty -->
+
    <img src="https://static.igem.org/mediawiki/2017/6/63/T--Cologne-Duesseldorf--Nootkatone-All-Reversible-No-Penalty.svg">
+
    <p>All of the above results summarized in a table.</p>
+
    <table>
+
<thead>
+
      <tr>
+
        <th>Model</th>
+
        <th>Nootkatone yield $[\frac{\text{mg}}{\text{L}}]$</th>
+
        <th>Nootkatol yield $[\frac{\text{mg}}{\text{L}}]$</th>
+
        <th>Nootkatone/Nootkatol</th>
+
</tr>
+
</thead>
+
<tbody>
+
      <tr>
+
        <td>No Penalty</td>
+
        <td>2965.0</td>
+
        <td>670</td>
+
        <td>4.4</td>
+
</tr>
+
      <tr>
+
        <td>FPP Penalty</td>
+
        <td>438.5</td>
+
        <td>88.7</td>
+
        <td>4.9</td>
+
</tr>
+
      <tr>
+
        <td>All Penalty</td>
+
        <td>398.3</td>
+
        <td>90.4</td>
+
        <td>4.4</td>
+
</tr>
+
      <tr>
+
        <td>Reversible, FPP Penalty</td>
+
        <td>437.9</td>
+
        <td>88.6</td>
+
        <td>4.9</td>
+
</tr>
+
      <tr>
+
        <td>Reversible, All Penalty</td>
+
        <td>394.2</td>
+
        <td>88.1</td>
+
        <td>4.4</td>
+
</tr>
+
      <tr>
+
        <td>Reversible, No Penalty</td>
+
        <td>2552.8</td>
+
        <td>567.9</td>
+
        <td>4.4</td>
+
</tr>
+
</tbody>
+
    </table>
+
    <p>During this investigation we noticed that under those conditions the maximal Nootkatone production is only dependent on the size of the peroxisome and therefore modeled the production depending on the peroxisomal size.</p>
+
    <!-- Plot Peroxisomal vs luminar production -->
+
    <img src="https://static.igem.org/mediawiki/2017/9/93/T--Cologne-Duesseldorf--Nootkatone-Peroxisome-Model.svg">
+
    <img src="https://static.igem.org/mediawiki/2017/4/46/T--Cologne-Duesseldorf--Nootkatone-Peroxisome-Model-Diameter.svg">
+
    <p>With the minimal peroxisomal diameter for equal production being $5.79 \ \text{µm}$, which we obtained by linear regression, we thus decided to create a <a href="">Pex11 knockout</a> mutant in which we can control the size of the peroxisome. </p>
+
</article>
+
</body>
+
 
</html>
 
</html>
 
{{Template:Cologne-Duesseldorf/footer}}
 
{{Template:Cologne-Duesseldorf/footer}}
 
{{Template:Cologne-Duesseldorf/js}}
 
{{Template:Cologne-Duesseldorf/js}}

Latest revision as of 15:22, 1 November 2017

Model

Summary

To enable full control over the peroxisomal protein import we predicted the structure for the yeast peroxisomal matrix import protein. In this structure we exchanged amino acids in the TPR regions using PyMol to create an orthogonal binding pocket. Using AMBER and VMD we predicted a binding pocket which binds a non wild type but not the wild type targeting signal.
To optimize our proof-of-concept project we modeled the Nootkatone pathway using python and showed the advantages of cellular compartmentalization. Finally we were able to create a yeast strain optimized for the production of the pathway precursor by using OptFlux analysis.

Infrastructure and modelling software

For the targeted mutagenesis of PEX5 we used molecular dynamic techniques. Professor Gohlke of the University of Duesseldorf kindly provided us with the necessary infrastructure (e.g. server and software access) and advisors to perform our calculations.
Molecular dynamics are a tool simulate the cells environment, regarding its temperature and ion contents, to calculate protein−protein interactions. We simulated the movement of our peroxisomal targeting signal (PTS) within the binding pocket of the PEX5 receptor.
The molecular dynamics software AMBER (Assisted Model Building with Energy Refinement) uses so called force fields to calculate the movement of each atom. For that we start with an equilibrated state which means that the PTS and every other molecule sit at the most favorable position. After equilibration we proceed with the actual simulation. The simulations only differ in the temperature of the environment which is more or less 300 K in each simulation. The whole workflow is depicted in the following graphic.

Workflow for the molecular dynamics simulations

As one can see, we start with a targeted mutagenesis for our PEX5 receptor, then proceed with the actual simulation to get finally to data evaluation. This is the point where we either decide to reject this receptor variant or to let it synthesize for experiments in the lab.

Three dimensional structure of the yeast PEX5 receptor

Currently there is no crystal structure of the yeasts PEX5 and due to that we had to predict its structure. To achieve that, we used a program provided by Daniel Mulnaes that uses existing files of the pdb database to create the structural prediction of the input sequence. One of those is the crystal structure of the TPR domains of the human PEX5 receptor interacting with the PTS1 ( PDB-entry: 1FCH ). Once we got this pdb file, we could proceed with our targeted mutagenesis in PyMOL.
Unfortunately, the program could not predict the whole structure, but only about 51% of it. It contains the important TPR domains and is very similar to the human crystal structure as you see in the figure below.

Alignment of the pdb file 1FCH (gray) to the predicted structure of the yeasts PEX5 (red).

PyMOLs 'mutagenesis wizard'

PyMOL provides a built-in function called 'mutagenesis wizard' making it possible to introduce site-directed mutations in the 3D structure. With this tool we exchanged amino acids in the TPR regions to create beneficial interactions between receptor and targeting signal. Our new receptor should only recognize our new peptide and not the wild type PTS1 and in exchange the wild type receptor should not recognize the new designed PTS.

TPR domains of the yeasts PEX5 receptor with the PTS1. The yellow lines indicate interacting amino acids.

Calculated vacuum electrostatics of the PEX5 receptor with the PTS. Red indicates positive, blue negative polarity.


The two figures above show the visualization possibilities in PyMOL − the upper one shows interacting amino acids while the lower one depicts the overall polarity. Both features helped us to set mutations in an educated way. As soon as we designed our receptor-PTS combination, we proceeded with the preparation for the molecular dynamics simulation.

Equilibration and molecular dynamics simulation

Once the mutations were set and the peptide was build, we equilibrated and simulated our experiment. After a couple of days the simulations were finished and we could start with the data evaluation.

Graphical visualization

VMD (Visual Molecular Dynamics) uses the coordinate files generated by AMBER to illustrate the simulation in an animated way as it can be seen below.

This already looked neat and gabe a rough hint on how promising the results are but for scientific evaluation we proceeded with numerical analysis.

Diffusion

To get numerical data out of the coordinate files, we then calculated the diffusion of the PTS from its starting point in the equilibrated state. A low value indicates stable binding while a high value indicates unfavorable interactions. Hence we had five replicates for each 'experiment', we calculated an average value and the standard deviation of all five replicates for point in time. Due to fluctuating values, we decided to implement a triangular smoothing algorithm to get more representative values. After the calculation we used R's ggplot2 to generate plots that set the experiments in relation with its controls. Our whole setup contains the following simulations.


  • our receptor − our PT
  • our receptor − wild type PTS
  • wt receptor − our PTS
  • wt receptor − wild type PTS

The following plots show examplaric how our results look like.

PEX5 variant R3 with the PTS1 variant -YDSYD. This shows an example for a unfavorable result − the receptor prefers the PTS1 above the PTS1*.

The figure above shows the one of our plots generated from the simulations data. We calculated the diffusion of the PTS1 from its starting point in angstrom and plotted it against the time in nanoseconds. The lines show the average diffusion value for each experiment while the shaded area depicts the standard deviation of the different replicates. Furthermore we calculated a value which indicates if the PEX5 variant has a higher preference for the PTS1* or the PTS1. A positive value implies a higher affinity while a negative value implies the opposite − one has to bear in mind that negative values reach higher numbers than positive ones. This is caused by the simulations conditions because if the binding is unstable, the targeting signal moves a lot.
To return to the figure, the red line represents the PEX5 variant with the PTS1 and the blue with the PTS1*. The figure above is an example for an unfavorable result − one sees that wild type signal is prefered above the designed one and thereby this would not lead to the achievement of our goal.

PEX5 variant R8 with the PTS1 variant -YTNQE. This shows an example for a quite favorable result. The preference coefficient is positive which means that the receptor prefers the PTS1* above the PTS1.

This figure shows a more favorable result. On average the PEX5 variant has a slightly higher preference for the PTS1* and due to that we figured this one would be worth a test in our laboratory.

PEX5 variant R15 with the PTS1 variant -YTNWD. The results of this simulation were also quite positive hence the receptor prefers the PTS1* above the natural PTS1. Unfortunately, the standard deviation is nearly as high as the preference coefficient, which means that this result should be considered with skepticism. Nevertheless we decided for us for laboratory tests.

Experimental results

PEX5 variant R19

This PEX5 variant did not directly develop from molecular dynamics in the first place. Baker et al. worked on a similar project and obtained results that we took in consideration for the design of the PEX5 variant R19 (see here for more detailed information).

PEX5 variant R19 with to PTS1* variants − the left figure shows the result of the full 15 amino acid long PTS1* while the right one was only done with the last five amino acids.

The figure above shows the result of the molecular dynamics simulation with our PEX5 variant R19. As one can see, the simulation with the 15 amino acid long peptide shows very unstable behaviour. Since our assumption for this was the long peptide and missing structures in the PEX5 model, we tried again with only five amino acids and obtained better results.
The very interesting part is, that this receptor was tested positively in our experiment − it successfully imported mTurquoise with the corresponding PTS1* (visit our results section for more information). Since the value of the preference coefficient is quite low, this means that our molecular dynamics approach was condemned to failure.

Review: molecular dynamics

Molecular dynamics are definitely an interesting and promising instrument regarding protein design and synthetic biology but our experiments showed the obstacles that come up once you work with it. As described before we achieved a positive result with one of our PEX5 variants but this very combination of PEX5 variant and PTS1* showed undesirable results in the simulation.
We think that the predicted PEX5 of yeast is the cause of this behaviour. The structure could only be predicted to about 51% which means that there could be more structures involved in PTS1 binding than presently assumed. In the beginning we assumed that the TPR regions would be enough, but now we think that we would need the whole crystal structure to do successful protein engineering from scratch. Unfortunately there are currently no crystal structures of the whole protein − neither of the yeast nor of any other organism − and due to its size it is unlikely to be crystallised in the near future.

Overview

In the following we present our model of the nootkatone biosynthesis pathway. We modeled the system in order to understand how to maximize nootkatone production. We start with an oversimplified model to give you a sense for the behavior of the enzymes in the pathway. Then we continue with a model introducing a function penalizing high concentrations of toxic products. As the toxicity is one of two main culprits of nootkatone production, we further show that the production inside a peroxisome can greatly increase nootkatone yield. Afterwards we discuss possible ways to overcome the shortage of the cellular FPP pool.

Basic System

The basic reactions of the nootkatone pathway are the following:

This already implies using an alcohol dehydrogenase with similar behaviour to ADH-21 used by Sebastian Schulz (2015). This ADH on the one hand is not stereospecific, in this case meaning that it can convert both cis and trans-nootkatol. On the other hand it favours the forward reaction, thus increasing the $\frac{\text{nootkatone}}{\text{nootkatol}}$ ratio. However due to the lack of stereospecificity we modeled the pathway using only one "nootkatol" species.

We assumed Michaelis-Menten kinetics for each reaction, with the last step being reversible.

Michaelis-Menten kinetics

$$\frac{dP}{dt} = \frac{V_{Max} \cdot c_{S}}{K_{M} + c_{S}}$$

Reversible Michaelis-Menten kinetics

$$\frac{dP}{dt} = \frac{\frac{V_{M+} \cdot c_{S}}{K_{M+}} - \frac{V_{M-} \cdot c_{P}}{K_{M-}}}{1 + \frac{c_{S}}{K_{M+}} + \frac{c_{P}}{K_{M-}}}$$

We further assumed a permanent FPP production, which we fitted in the Penalty model.

This gives us the following system of differential equations.

$$\frac{dFPP}{dt} = v_{\text{FPP in}} - \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} $$

$$\frac{dValencene}{dt} = \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} -\frac{V_{Max,\text{P450 BM3}} \cdot c_{Valencene}}{K_{M, \text{P450 BM3}} + c_{Valencene}}$$

$$\frac{dNootkatol}{dt} = \frac{V_{Max,\text{P450 BM3}} \cdot c_{Valencene}}{K_{M, \text{P450 BM3}} + c_{Valencene}} - \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$

$$\frac{dNootkatone}{dt} = \frac{\frac{V_{M,ADH+} \cdot c_{Nootkatol}}{K_{M,ADH+}} - \frac{V_{M,ADH-} \cdot c_{Nootkatone}}{K_{M,ADH-}}}{1 + \frac{c_{Nootkatol}}{K_{M,ADH+}} + \frac{c_{Nootkatone}}{K_{M,ADH-}}}$$

Since the main cofactor is regenerated inside the pathway we chose to not model the cofactors.

Parameters

Our crude first assumption was a constant enzyme concentration of $1 \ \text{µM}$. We mostly used kinetic parameters from the Brenda database. If S. cerevisiae was not available as the host we used the nearest relative, if the reaction was not available we used the kinetics for the respective co-substrate as an upper boundary. Another assumption we made is a five-fold reduction in the speed of the reversible reaction of the ADH-21, based on the work by Sebastian Schulz (2015), that the forward reaction is favored.

Parameter Value Source
$v_{\text{FPP in}}$ $4.18E-9 \frac{1}{\text{s}}$ Penalty model
$\text{kM}_{\text{Valencene Synthase}}$ $1.04 \text{ µM}$ Brenda
$\text{kM}_{\text{P450 BM3}}$ $126 \text{ µM}$ Brenda
$\text{kM}_{\text{ADH-21}}$ $161 \text{ µM}$ Schulz 2015
$\text{kcat}_{\text{Valencene Synthase}}$ $0.0032 \frac{1}{\text{s}}$ Brenda
$\text{kcat}_{\text{P450 BM3}}$ $2.619 \frac{1}{\text{s}}$ Brenda
$\text{kcat}_{\text{ADH-21 forward}}$ $6 \frac{1}{\text{s}}$ Sebastian Schulz (2015)
$\text{kcat}_{\text{ADH-21 backward}}$ $1.2 \frac{1}{\text{s}}$ $\frac{\text{kcat}_{\text{ADH-21 forward}}}{5}$
$c_{\text{Enzyme}}$ $1 \text{ µM}$ Assumption

Simple model

In order to simulate the system of differential equations we set up a few python files. One file containing a model class which consists of the parameters, the models and the integration function. One file containing all the kinetics used and finally one which we used to actually run the simulations. We wanted to show some example code on how to set up such a project, while the code size was still manageable, in order to help new iGEM teams that might need help with their modeling.

Kinetics File

				
def ConstantInflux(substrate,speed):
return(speed)

def MichaelisMenten(
	substrate,enzymeConcentration,kcat,km):
return(
			(enzymeConcentration*kcat*substrate)
			/(km+substrate))

def MichaelisMentenReversible(
	substrate,product,enzymeConcentration,
	kcats,kcatp,kms,kmp):
return (
			(
							((enzymeConcentration*kcats*substrate)/kms)
							-((enzymeConcentration*kcatp*product)/kmp)
							)
							/(1+(substrate/kms)+(product/kmp)
							))
				
				

Model File

				
import kinetics as k
import numpy as np
import scipy.integrate

class model(object):
def __init__(self):
	self.c_ValS = 1E-6 #[M]
	self.c_ADH = 1E-6 #[M]
	self.c_P450 = 1E-6 #[M]

	self.km_ValS = 1.04E-6  #[M]
	self.km_P450 = 126E-6 #[M]
	self.km_ADH = 161E-6 #[M]

	self.kcat_ValS = 0.0032*3600 #[1/s]
	self.kcat_P450 = 6*3600 #[1/s]
	self.kcat_ADH = 2.619*3600 #[1/s]
	self.k_influxSpeed = 1.03562761862e-05 #[1/s]


def FPPInflux(self,FPP):
	return(
					k.ConstantInflux(
									FPP,
									self.k_influxSpeed)
					)

def ValenceneSynthase(self,FPP):
	return(
					k.MichaelisMenten(
									FPP,
									self.c_ValS,
									self.kcat_ValS,
									self.km_ValS)
					)
def P450(self,Valencene):
	return(
					k.MichaelisMenten(
									Valencene,
									self.c_P450,
									self.kcat_P450,
									self.km_P450)
					)
def ADH(self,nootkatol,nootkatone):
	return (
					k.MichaelisMentenReversible(
									nootkatol,
									nootkatone,
									self.c_ADH,
									self.kcat_ADH,
									self.kcat_ADHrev,
									self.km_ADH,
									self.km_ADH)
					)

def P450_Model(self,time,initvalues):
	FPP,Val,Nkl,Nkn = initvalues
	dFPPdt = self.FPPInflux(FPP) - self.ValenceneSynthase(FPP)
	dValdt = self.ValenceneSynthase(FPP) - self.P450(Val)
	dNkldt = self.P450(Val) - self.ADH(Nkl,Nkn)
	dNtkdt = self.ADH(Nkl,Nkn)
	return [dFPPdt,dValdt,dNkldt,dNtkdt]


def Integration(self,time,initvalues,model):
	Y = np.zeros([len(time),len(initvalues)])
	Y[0] = np.transpose(initvalues)
	r = scipy.integrate.ode(model)
	r.set_integrator('lsoda')
	r.set_initial_value(initvalues)
	cnt=1
	while r.successful() and cnt < len(time):
			Y[cnt,:] = r.integrate(time[cnt])
			cnt+=1
	return Y
				
				

Simulation file

				
from model import model
import numpy as np
import matplotlib.pyplot as plt

m = model()
time = np.linspace(0,1,1000)
data = m.Integration(time,[0,0,0,0],m.P450_Model)
plt.plot(time,data[:,0],label=(
	r"FPP, $k_{FPP}$ = "
	+"{:.2e}".format(m.k_influxSpeed)
	+r" $\frac{1}{h}$"
	))
plt.plot(time,data[:,1],label=(
	r"Valencene, $c_{ValS}$ = "
	+"{:.0e}".format(m.c_ValS)
	+r" $\frac{mol}{L}$"
	))
plt.plot(time,data[:,2],label=(
	r"nootkatol, $c_{P450}$ = "
	+"{:.0e}".format(m.c_P450)
	+r" $\frac{mol}{L}$"
	))
plt.plot(time,data[:,3],label=(
	r"nootkatone, $c_{ADH-21}$ = "
	+"{:.0e}".format(m.c_ADH)
	+r" $\frac{mol}{L}$"
	))
plt.yscale("log")
plt.legend(loc=9, bbox_to_anchor=(0.5, -0.2), ncol=2)
plt.title("First Simulation")
plt.xlabel(r"Time in $[h]$")
plt.ylabel(r"Yield in $\frac{mol}{cell}$")
plt.show()
				
				

The results of our first simulation are the following:

What is visible in this first simulation is that the FPP import is faster than Valencene Synthase since FPP is agglomerating. However Valencene synthase, P450 BM3 and ADH are all saturated around 20 minutes, since the valencene concentration becomes stationary and nootkatol and nootkatone levels keep rising proportionally, due to the back-reaction of ADH. This is why choosing an ADH favouring the forward reaction increases the yield while keeping the metabolic stress on the cells low.

Bioreactor model

In order to check the validity of our model we took the results of Tamara Wriessnegger 2014 as a point for reference. Wriessnegger achieved $208 \ \frac{\text{mg}}{\text{L}}$ nootkatone production after $108 \text{ 0}h$ in an in-vitro production in Pichia pastoris. We therefore had to scale up our single cell model to a bioreactor simulation.

In order to do this we first calculated the number of product molecules per cell.

$$\frac{\text{N}_{\text{Product}}}{\text{cell}} \ [\text{mol}]= c_{Product} [\frac{\text{mol}}{\text{L}}]\cdot V_{\text{Yeast}} \ [\text{L}]$$

Then we calculated the number of cells per Liter bioreactor.

$$ \text{cells per Liter} \ [\frac{\text{1}}{\text{L}}] = \frac{\rho_{\text{Cells in Bioreactor}} \ [\frac{\text{g d.w.}}{\text{L}}] }{m_{\text{Yeast dry weight}} \ [\text{g d.w.}] } $$

With these two equations we could scale up the production of a single cell for each product.

$$\text{Yield}_{\text{Bioreactor}} \ [\frac{\text{mg}}{\text{L}}] = \frac{\text{N}_{\text{Product}}}{\text{cell}} \ [\text{mol}] \cdot \text{cells per Liter} \ [\frac{\text{1}}{\text{L}}] \cdot \text{M}_{\text{Product}} \ [\frac{\text{g}}{\text{mol}}] \cdot 1000$$

We used the following constants for the calculations above.

Parameter Value Source
$\rho_{Bioreactor}$ $200 \ \frac{\text{g d.w.}}{\text{L}}$ Biomedcentral
$m_{\text{Yeast dry weight}}$ $17.5E-12 \text{ g}$ Kirschner Lab
$V_{\text{Yeast}}$ $6E-14 \text{ L}$ Philips 2012
$M_{\text{FPP}}$ $382.33 \ \frac{\text{g}}{\text{mol}}$ Pubchem
$M_{\text{Valencene}}$ $204.36 \ \frac{\text{g}}{\text{mol}}$ Pubchem
$M_{\text{Nootkatol}}$ $220.35 \ \frac{\text{g}}{\text{mol}}$ Pubchem
$M_{\text{Nootkatone}}$ $218.34 \ \frac{\text{g}}{\text{mol}}$ Pubchem

Bioreactor simulation

Our model predicts a nootkatone Yield of $154.24 \ \frac{\text{mg}}{\text{L}}$ and a nootkatol Yield of $31.06 \ \frac{\text{mg}}{\text{L}}$. Wriessnegger produced $208 \ \frac{\text{mg}}{\text{L}}$ nootkatone and $44 \ \frac{\text{mg}}{\text{L}}$ nootkatol. This showed us that our assumption of a five-fold reduction in the backwards reaction of alcohol dehydrogenase is valid, as our $\frac{\text{nootkatone}}{\text{nootkatol}}$ ratio was 4.96, which is quite close to the 4.72 by Wriessnegger. We then took a look at how differently expressing the enzymes would have an influence on nootkatone production.

Expression analysis

The first figure shows the nootkatone yield based on a varied enzyme concentration of all enzymes, while the other enzyme concentrations were kept constant at $1 \text{ µM}$. The second plot shows varied enzyme concentrations for all enzymes at the same time. The smallest concentration with almost maximal nootkatone production is at about $2 \text{ µM}$ Valencene Synthase, when not over increasing the other enzymes. Therefore we chose to double the expression of Valencene Synthase to ensure that our pathway is saturated.

This increased our yield above the results by Wriessnegger. But our model still lacks the important factor of product toxicity at high concentration, which is why we did not fit the FPP import to this, but to the next model.

Toxicity

According to Carole Gavira 2013 both nootkatone and nootkatol exhibit toxicity at high levels. At $100 \ \frac{\text{mg}}{\text{L}}$ nootkatol the cell viability was decreased to 55%, at $100 \ \frac{\text{mg}}{\text{L}}$ nootkatone to 80%. For both substances all cells were dead around $1000 \ \frac{\text{mg}}{\text{L}}$. We used hill kinetics to fit this behaviour.

$$\frac{K_{Tox}^n}{K_{Tox}^n + [S]^n}$$

We fitted the data of Gavira using scipy.optimize.brent and multiple factors n. This is due to the fact that n is only valid in integer values and scipy does not support mixed-integer optimizations. We further chose to only implement nootkatone toxicity, even if it is the less toxic compound, as it is concentrated approximately five times higher than nootkatol in the cell. This also helped to keep our model simple.

$\text{n}$ $K_{\text{Toxic nootkatol}}$ Error
2 200 0.136
3 158.74 0.104
4 141.42 0.100
5 131.95 0.100
6 125.99 0.100

Even though the error produced by functions with a higher n was decreasing we chose to use n = 3 to prevent overfitting, since n = 3 already fit both points quite well.

We used this penalty function only on our FPP import. The idea behind that was that since the whole pathway depends linearly on the FPP influx it can act representative for the cell viability. This turned out to show some problems later in the model but we chose to keep this assumption, as the problems can be addressed by proper interpretation of the data and because we wanted to keep our model simple.

This changes our system in the following way.

$$\frac{dFPP}{dt} = v_{\text{FPP in}} \cdot \frac{K_{\text{Tox Nkn}}^3}{K_{\text{Tox Nkn}}^3 + [\text{Nkn}]^3} - \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} $$

Penalty model

Dynamics

This is the model where we actually fitted our import parameter to the data supplied by Wriessnegger, as we assumed it to be sufficiently close to the actual biological reality. We did this by using scipy.optimize.brent to minimize the error function $\text{abs}(208 - [S]_{\text{nootkatol}})$. This gave us an import rate of $6.55E-9 \frac{1}{\text{s}}$, which we then also used in all other models, including the ones shown previously.

The nootkatone yield is approximately at the results of Wriessnegger and we can see that the FPP import declines with increasing nootkatone production. The penalty function can be interpreted as the fraction of alive cells, which at the final point of the simulation is $52.16 \ \%$. This huge number already gives us an understanding that nootkatol and nootkatone production limit themselves in cytosolic production, thus showing us the first culprit of nootkatone production.

Expression

We wanted to check whether over- or underexpression of any of the enzymes could improve our nootkatone yield under penalty conditions.

Interestingly the peak nootkatone yield is now under submaximal Valencene Synthase expression. This is possibly due to the increased toxicity. In order to check this we further increased the FPP import tenfold over the fitted value.

Increased FPP import dynamics

The maximal yield under increased FPP import conditions is increased, but at the end of the simulation only around $11 \ \%$ of the cell population is alive. This is the problem of the model that we talked earlier about. In this case the early FPP import so fast compared to the enzymatic reactions so that FPP accumulates. Since only the import is penalized, but not the other reactions, all that follows is an simulation of dead cells still transforming an large FPP pool. This is obviously biologically wrong and an artifact of the way the penalty is set up. The effects of this error can be seen in the variation of single enzyme concentrations in the plots below.

Increased FPP import expression

Increased FPP import and enzyme concentration dynamics

Even with this submaximal production only $4 \ \%$ of cells are alive at the end of the simulation. So even if the results of the production with a tenfold increased FPP influx have to be interpreted carefully, the general takeaway of the simulation is that given a sufficiently high FPP influx, nootkatone toxicity is the main remaining culprit of nootkatone production. This is where our nootkatone subproject comes in. By transferring the enzymes needed for nootkatone production into the peroxisome we assume that the products cannot diffuse back into the cell and therefore do not impose any toxicity on the cells. This can be seen by the great increase in nootkatone production in the models below.

Peroxisome model

Since peroxisomes vary greatly in size we first assumed them to be as large as the yeast cells. While this assumption is clearly wrong, we later show the minimal size needed under specific conditions to outperform cytosolic production. Since we assume no nootkatone and nootkatol toxicity inside the peroxisome, the general reaction dynamics are equal to the simple bioreactor model, but with overexpressed Valencene Synthase. We first modeled the maximal nootkatone yield with varying enzyme concentrations.

Expression

What can be seen here as before is that the maximal nootkatone yield is determined by the FPP import and that Valencene Synthase is the velocity dictating enzyme. Even at a high expression of Valencene Synthase increasing either P450 BM3 or ADH over $1E-8 \ \frac{\text{mol}}{\text{L}}$ does not further increase the nootkatone yield, as the two enzymes are faster than Valencene Synthase. To further increase nootkatone yield the FPP import has to be increased. In this case the nootkatone yield can be increased linearly, as shown below.

Increased FPP import dynamics

Increased FPP import expression

Increased FPP increased enzyme concentration dynamics

Conclusion

Model Nootkatone Nootkatol
Bioreactor 154.24* 31.06*
Bioreactor ValS Up 302.87* 61.36*
Penalty 206.10 41.40
Penalty FPP Up 309.62** 62.73**
Penalty FPP + Enzymes Up 456.93** 91.43**
Peroxisome Enzymes Up 317.83 64.65
Peroxisome FPP Up 309.63 62.73
Peroxisome FPP + Enzymes Up 3082.86 624.14

As can be seen from our simulations, the two main culprits of nootkatone production are the toxicity of the products at high concentrations and the FPP influx. The toxicity can be avoided by transferring the pathway into the peroxisome, which is one of the projects of our team. To address the problem of FPP influx our team did an opt-knock FBA analysis to show how S. cerevisiae cells can be engineered to stably produce more FPP. Note that the values marked with an asterisk were produced by an incomplete model and values marked with two asterisks are assumed to be false due to the model setup as explained in the sections above.

Further thoughts

A false assumption in the peroxisomal models above is that the size of the peroxisome is equal to that of the yeast cell. This is obviously not correct. We wanted to get a feeling how large the peroxisome actually has to be in order for production to be superior to cytosolic production. We therefore took the the results of the cytosolic model with increased FPP intake and enzyme concentration and then calculated the yield of the corresponding peroxisomal model with varying peroxisome size.

We calculated the volume for equal production

$$V_{\text{Perox. Equal}} = \frac{\text{Yield}_{\text{Cyt.}} \cdot V_{\text{Yeast}}}{\text{Yield}_{\text{Perox.}}}$$

to be $1.24E-14 \ \text{L}$, so approximately a fifth of the cell volume. Since in methylotrophic yeasts such as Pichia pastoris peroxisomes can take up to 80% of the total cell volume (Gleeson ), a fifth of the cell volume is very achievable. To further increase the possible yield our team is working on a Pex11-knockout that aims to increase peroxisome size

Background

Constraint based modeling

Constraint based modeling is a mechanistically method to simulate complex metabolic networks under the critical assumption that the network is in a steady state. It requires a reconstructed metabolic network, in which all reactions have been characterized stoichiometrically. The network is then represented by the stoichiometric matrix $S$, in which each column corresponds to a reaction and each row to a metabolite. The reactions are further constrained only allowing positive fluxes $v_i \geq 0$ (elementary modes) and by putting upper and lower bounds on the flux (turnover rate). This reduces the solution space into a convex polyhedral cone, in which every point is a non-negative combination of elementary modes and every edge a unique elementary mode. As metabolic networks typically have more reactions than metabolites, the systems are underdetermined and therefore the flux distribution is not definitive. To find the actual biological solution additional constraints have to be added, for example an objective function that is to be optimized.

Flux Balance Analysis

A sensible objective function should in our case describe the main driver behind evolution - natural selection. This can be accomplished by defining a biomass production term $Z = c^Tv$, which consists of several biomass precursor reactions merged into one unit. Therefore the optimization finds the flux distribution with which maximal biomass production is accomplished, which is in accordance to natural selection.

In matrix formalism this can be written as $Sv = 0$, where $S$ is the stoichiometric matrix and $v$ the vector of fluxes that is to be solved.$c$ is the vector that defines the weights of each flux in the objective function. The canonical form of a Flux Balance Analysis thus can be written as

$$\text{maximize } c^Tv$$

$$\text{subject to } Sv = 0$$

$$\text{and lower bound } \leq v \leq \text{upper bound}$$

This is a linear optimization which due to the convex solution space can be calculated efficiently with linear programming.

OptKnock

Metabolic engineering faces two big problems. Firstly the precursor molecule for the wanted reaction can only be found in trace amounts in the cell, leading to minor yields of the wanted product. Secondly adding pathways to the metabolism of an organism increases the metabolic stress on that organism. Thus if the cell loses the ability to produce the desired compound it can overgrow the other cells in a large-scale bioreactor setting. OptKnock (Anthony P. Burgard 2003) is a two step optimization in which biomass production is coupled to the production of a desired product by calculating a set of gene knockouts, solving both problems above.In principle the algorithm works like this:

$$ \left[ \begin{array}{ll} \text{Maximize Product} \\ \text{(over knockouts)} \\ \text{Subject to} & \left[ \begin{array}{ll} \text{Maximize biomass} \\ \text{(over fluxes)} \\ \text{Subject to} & \left[ \begin{array}{l} \text{Fixed substrate uptake rate} \\ \text{Network Stoichiometry} \\ \text{Knockouts identified by outer problem} \\ \end{array} \right] \\ \end{array} \right] \\ \text{Minimum biomass yield} \\ \text{N}_{\text{Knockouts}} \leq \text{ limit} \end{array} \right] $$

We visualized the concept in the following two pictures. The important point here is to notice that the maximal biomass flux in the OptKnock model at the same time corresponds to a high product flux.

Results

We analyzed the FPP pool by using Geranyltranstransferase (GRTT) as the reaction to be optimized. GRTT takes geranyl diphosphate and isopentenyl diphosphate and converts them to farnesyl pyrophosphate and diphosphate. The two results below show the maximal GRTT production with a minimal biomass yield of 0.1 and 0.2 respectively.

Compared to the wild type FPP flux (0.0013) the maximal fluxes that could be achieved with four knockouts were 0.61 and 0.29, respective to the minimal biomass yield of 0.1 and 0.2. This roughly corresponds to a 480- and 230-fold increase in FPP flux. While we do not think that these results are close to the actual biological truth, as a 230- or 480-fold increase is rather extreme, we did notice an accumulation of knockouts in genes related to the pentose phosphate pathway (TKT2 = Transketolase, G6PDH2r = Glucose-6-phosphate dehydrogenase) or citric acid cycle (ALATA_L = L-alanine transaminase). Further reactions like ADK3 (Adentylate kinase (GTP)), which is indirectly involved in the TCA by supplying GDP or IPPSm (2 isopropylmalate synthase mitochondrial) that takes acetyl-CoA as a substrate lead us to the conclusion that the cellular FPP pool can be increased by shifting to a fatty acid metabolism. This is further solidified by the fact that the FPP precursor isopentenyl diphosphate ultimately is build from acetyl-CoA Sebastián Rubat 2017.

We then integrated the nootkatone pathway into the metabolic model and reran the optimization.

The general trend of the knockouts continued in this model. In this fashion reactions in the TCA (MDH = Malate dehydrogenase), glycolysis (G6PI3 = Glucose 6 phosphate isomerase) and fermentation (PYRDC = Pyruvate decarboxylase) were knocked-out. This further solidifies our hypothesis, that the analysis builds a cell metabolism that favors fatty acid breakdown.