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

 
(67 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>Nootkatone Metabolic Model</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 behavior and dynamics. We start with an oversimplified luminar model to get 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 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. Then we show an opt-knock flux-balance analysis to show how the second culprit, the cellular FPP pool can be overcome.</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>
 +
</div>
 +
<button class="accordion">
 +
<h2 id=StructuralModel>Structural model</h2>
 +
</button>
 +
<div class="panel">
 +
<h3 id=h3-1>Infrastructure and modelling software</h3>
 +
<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.
 +
<br>
 +
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.
 +
<br>
 +
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>
 +
<figure>
 +
<img src="https://static.igem.org/mediawiki/2017/7/7f/Artico_mdwork.svg">
 +
<figcaption>
 +
Workflow for the molecular dynamics simulations
 +
</figcaption>
 +
</figure>
 +
<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>
 +
<h3 id=h3-2>Three dimensional structure of the yeast PEX5 receptor</h3>
 +
<p>
 +
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.
 +
<br>
 +
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.
 +
</p>
 +
<figure>
 +
<img src="https://static.igem.org/mediawiki/2017/d/d2/Artico_p5align.png">
 +
<figcaption>
 +
Alignment of the pdb file 1FCH (gray) to the predicted structure of the yeasts PEX5 (red).
 +
</figcaption>
 +
</figure>
 +
<h3 id=h3-3>PyMOLs 'mutagenesis wizard'</h3>
 +
<p>
 +
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.
 +
</p>
 +
<figure>
 +
<img src="https://static.igem.org/mediawiki/2017/c/c5/Artico_p5wt_polar.png">
 +
<figcaption>TPR domains of the yeasts PEX5 receptor with the PTS1. The yellow lines indicate interacting amino acids.</figcaption>
 +
</figure>
 +
<figure>
 +
<img src="https://static.igem.org/mediawiki/2017/f/f6/Artico_p5elector.png">
 +
<figcaption>
 +
<p>
 +
Calculated vacuum electrostatics of the PEX5 receptor with the PTS. Red indicates positive, blue negative polarity.
 +
</p>
 +
</figcaption>
 +
</figure>
 +
<br>
 +
<p>
 +
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.
 +
</p>
 +
<h3 id=h3-4>Equilibration and molecular dynamics simulation</h3>
 +
<p>
 +
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.
 +
</p>
 +
<h4 id=h4-1>Graphical visualization</h4>
 +
<p>
 +
<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.
 +
</p>
 +
<div class="center">
 +
<video controls="controls" width="800" height="600" name="Video Name" src="https://static.igem.org/mediawiki/2017/9/9e/Artico_R6WT.mov"></video>
 +
</div>
 +
<p>
 +
This already looked neat and gabe a rough hint on how promising the results are but for scientific evaluation we proceeded with numerical analysis.
 +
</p>
 +
<h4 id=h4-2>Diffusion</h4>
 +
<p>
 +
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.
 +
</p>
 +
<br>
 +
<ul>
 +
<li>our receptor &minus; our PT</li>
 +
<li>our receptor &minus; wild type PTS</li>
 +
<li>wt receptor &minus; our PTS</li>
 +
<li>wt receptor &minus; wild type PTS</li>
 +
</ul>
 +
<br>
 +
<p>The following plots show examplaric how our results look like.</p>
 +
<figure>
 +
<img src="https://static.igem.org/mediawiki/2017/e/eb/Artico_rec_003_ydsyd.svg">
 +
<figcaption>
 +
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*.
 +
</figcaption>
 +
</figure>
 +
<p>
 +
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.
 +
<br>
 +
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.
 +
</p>
 +
<figure>
 +
<img src="https://static.igem.org/mediawiki/2017/8/86/Artico_rec_008_ytnqe.svg">
 +
<figcaption>
 +
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.
 +
</figcaption>
 +
</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>
  
<h3>Basic System</h3>
+
<button class="accordion">
<p>The basic reactions of the Nootkatone pathway that are introduced by our team are the following.</p>
+
<h2 id=MetabolicModel>Nootkatone Metabolic Model</h2>
<img class="max-width" src="https://static.igem.org/mediawiki/2017/d/d2/T--Cologne-Duesseldorf--nkl-pathway-old.svg">
+
</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)
  
<p>However during research we found that using the p450-BM3 enzyme will simplify and enhance Nootkatone production, giving the following reaction pathway.</p>
+
def MichaelisMenten(
<img class="max-width" src="https://static.igem.org/mediawiki/2017/8/8f/T--Cologne-Duesseldorf--nkl-pathway.svg">
+
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)
 +
))
 +
</code>
 +
</pre>
 +
<h4>Model File</h4>
 +
<pre>
 +
<code>
 +
import kinetics as k
 +
import numpy as np
 +
import scipy.integrate
  
<p>We assumed Michaelis-Menten kinetics for each reaction, with the last step being reversible.</p>
+
class model(object):
<p>Michaelis-Menten kinetics</p>
+
def __init__(self):
<p>$$\frac{dP}{dt} = \frac{V_{Max} \cdot c_{S}}{K_{M} + c_{S}}$$</p>
+
self.c_ValS = 1E-6 #[M]
<p>Reversible Michaelist-Menten kinetics</p>
+
self.c_ADH = 1E-6 #[M]
<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>
+
self.c_P450 = 1E-6 #[M]
<p>We further assumed a permanent FPP production, which we fitted in the <a href="#PenaltyModel">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,p450\_BM3} \cdot c_{Valencene}}{K_{M, p450\_BM3} + c_{Valencene}}$$</p>
+
<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>
+
<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>
+
<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>
+
self.km_ValS = 1.04E-6  #[M]
  <thead>
+
self.km_P450 = 126E-6 #[M]
    <tr>
+
self.km_ADH = 161E-6 #[M]
      <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>
+
self.kcat_ValS = 0.0032*3600 #[1/s]
<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>
+
self.kcat_P450 = 6*3600 #[1/s]
 +
self.kcat_ADH = 2.619*3600 #[1/s]
 +
self.k_influxSpeed = 1.03562761862e-05 #[1/s]
  
<h4>Kinetics File</h4>
 
<pre>
 
  <code>
 
def ConstantInflux(substrate,speed):
 
    return(speed)
 
  
def MichaelisMenten(
+
def FPPInflux(self,FPP):
        substrate,enzymeConcentration,kcat,km):
+
return(
    return(
+
k.ConstantInflux(
            (enzymeConcentration*kcat*substrate)
+
FPP,
            /(km+substrate))
+
self.k_influxSpeed)
 +
)
  
def MichaelisMentenReversible(
+
def ValenceneSynthase(self,FPP):
        substrate,product,enzymeConcentration,
+
return(
        kcats,kcatp,kms,kmp):
+
k.MichaelisMenten(
    return (
+
FPP,
            (
+
self.c_ValS,
                    ((enzymeConcentration*kcats*substrate)/kms)
+
self.kcat_ValS,
                    -((enzymeConcentration*kcatp*product)/kmp)
+
self.km_ValS)
                    )
+
)
                    /(1+(substrate/kms)+(product/kmp)
+
def P450(self,Valencene):
                    ))
+
return(
  </code>
+
k.MichaelisMenten(
</pre>
+
Valencene,
<h4>Model File</h4>
+
self.c_P450,
<pre>
+
self.kcat_P450,
  <code>
+
self.km_P450)
import kinetics as k
+
)
import numpy as np
+
def ADH(self,nootkatol,nootkatone):
import scipy.integrate
+
return (
 +
k.MichaelisMentenReversible(
 +
nootkatol,
 +
nootkatone,
 +
self.c_ADH,
 +
self.kcat_ADH,
 +
self.kcat_ADHrev,
 +
self.km_ADH,
 +
self.km_ADH)
 +
)
  
class model(object):
+
def P450_Model(self,time,initvalues):
    def __init__(self):
+
FPP,Val,Nkl,Nkn = initvalues
        self.c_ValS = 1E-6 #[M]
+
dFPPdt = self.FPPInflux(FPP) - self.ValenceneSynthase(FPP)
        self.c_ADH = 1E-6 #[M]
+
dValdt = self.ValenceneSynthase(FPP) - self.P450(Val)
        self.c_p450 = 1E-6 #[M]
+
dNkldt = self.P450(Val) - self.ADH(Nkl,Nkn)
 +
dNtkdt = self.ADH(Nkl,Nkn)
 +
return [dFPPdt,dValdt,dNkldt,dNtkdt]
  
        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]
+
def Integration(self,time,initvalues,model):
        self.kcat_p450 = 6*3600 #[1/s]
+
Y = np.zeros([len(time),len(initvalues)])
        self.kcat_ADH = 2.619*3600 #[1/s]
+
Y[0] = np.transpose(initvalues)
        self.k_influxSpeed = 1.03562761862e-05 #[1/s]
+
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
 +
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&quot;FPP, $k_{FPP}$ = &quot;
 +
+&quot;{:.2e}&quot;.format(m.k_influxSpeed)
 +
+r&quot; $\frac{1}{h}$&quot;
 +
))
 +
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;
 +
))
 +
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;
 +
))
 +
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;
 +
))
 +
plt.yscale(&quot;log&quot;)
 +
plt.legend(loc=9, bbox_to_anchor=(0.5, -0.2), ncol=2)
 +
plt.title(&quot;First Simulation&quot;)
 +
plt.xlabel(r&quot;Time in $[h]$&quot;)
 +
plt.ylabel(r&quot;Yield in $\frac{mol}{cell}$&quot;)
 +
plt.show()
 +
</code>
 +
</pre>
 +
<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">
 +
<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>
 +
<h3>Bioreactor model</h3>
 +
<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 order to do this we first calculated the number of product molecules per cell.</p>
 +
<p>$$\frac{\text{N}_{\text{Product}}}{\text{cell}} \ [\text{mol}]= c_{Product} [\frac{\text{mol}}{\text{L}}]\cdot V_{\text{Yeast}} \ [\text{L}]$$</p>
 +
<p>Then we calculated the number of cells per Liter bioreactor.</p>
 +
<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>
 +
<p>With these two equations we could scale up the production of a single cell for each product.</p>
 +
<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>
 +
<p>We used the following constants for the calculations above.</p>
 +
<table>
 +
<thead>
 +
<tr>
 +
<th>Parameter</th>
 +
<th>Value</th>
 +
<th>Source</th>
 +
</tr>
 +
</thead>
 +
<tbody>
 +
<tr>
 +
<td>$\rho_{Bioreactor}$</td>
 +
<td>$200 \ \frac{\text{g d.w.}}{\text{L}}$</td>
 +
<td><a href="https://microbialcellfactories.biomedcentral.com/articles/10.1186/s12934-015-0295-4">Biomedcentral</a></td>
 +
</tr>
 +
<tr>
 +
<td>$m_{\text{Yeast dry weight}}$</td>
 +
<td>$17.5E-12 \text{ g}$</td>
 +
<td><a href="http://kirschner.med.harvard.edu/files/bionumbers/Size%20and%20composition%20of%20yeast%20cells.pdf">Kirschner Lab</a></td>
 +
</tr>
 +
<tr>
 +
<td>$V_{\text{Yeast}}$</td>
 +
<td>$6E-14 \text{ L}$</td>
 +
<td><abbr title="2012, Rob Phillips - Physical Biology of the Cell">Philips 2012</abbr></td>
 +
</tr>
 +
<tr>
 +
<td>$M_{\text{FPP}}$</td>
 +
<td>$382.33 \  \frac{\text{g}}{\text{mol}}$</td>
 +
<td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/445713">Pubchem</a></td>
 +
</tr>
 +
<tr>
 +
<td>$M_{\text{Valencene}}$</td>
 +
<td>$204.36 \  \frac{\text{g}}{\text{mol}}$</td>
 +
<td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/valencene">Pubchem</a></td>
 +
</tr>
 +
<tr>
 +
<td>$M_{\text{Nootkatol}}$</td>
 +
<td>$220.35 \ \frac{\text{g}}{\text{mol}}$</td>
 +
<td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/nootkatol">Pubchem</a></td>
 +
</tr>
 +
<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>
  
    def FPPInflux(self,FPP):
+
<button class="accordion">
        return(
+
<h2 id=OptKnock>OptKnock Analysis</h2>
                k.ConstantInflux(
+
</button>
                        FPP,
+
<div class="panel">
                        self.k_influxSpeed)
+
<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>
  
    def ValenceneSynthase(self,FPP):
+
<p>Compared to the wild type FPP flux (0.0013) the maximal fluxes that could be achieved with four knockouts were 0.61
        return(
+
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 <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>.
                k.MichaelisMenten(
+
</p>
                        FPP,
+
<p>We then integrated the nootkatone pathway into the metabolic model and reran the optimization.</p>
                        self.c_ValS,
+
<img class="max-width" src="https://static.igem.org/mediawiki/2017/d/d8/T--Cologne-Duesseldorf--OptKnock-Nootkatol.svg">
                        self.kcat_ValS,
+
<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>
                        self.km_ValS)
+
</div>
                )
+
</article>
    def p450(self,Valencene):
+
</body>
        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
+
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&quot;FPP, $k_{FPP}$ = &quot;
+
        +&quot;{:.2e}&quot;.format(m.k_influxSpeed)
+
        +r&quot; $\frac{1}{h}$&quot;
+
        ))
+
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;
+
        ))
+
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;
+
        ))
+
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;
+
        ))
+
plt.yscale(&quot;log&quot;)
+
plt.legend(loc=9, bbox_to_anchor=(0.5, -0.2), ncol=2)
+
plt.title(&quot;First Simulation&quot;)
+
plt.xlabel(r&quot;Time in $[h]$&quot;)
+
plt.ylabel(r&quot;Yield in $\frac{mol}{cell}$&quot;)
+
plt.show()
+
  </code>
+
</pre>
+
 
+
<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>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 h in a in-vitro production in <em>Pichia pastoris</em>. We therefore had to scale up our single cell model to a bioreactor simulation.</p>
+
<p>We first calculated the number of product molecules per cell</p>
+
<p>$$\frac{\text{N}_{\text{Product}}}{\text{cell}} \ [\text{mol}]= c_{Product} [\frac{\text{mol}}{\text{L}}]\cdot V_{\text{Yeast}} \ [\text{L}]$$</p>
+
<p>Then we calculated the number of cells per Liter bioreactor</p>
+
<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>
+
<p>With these two equations we could scale up the production of a single cell for each product.</p>
+
<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>
+
<p>We used the following constants for the calculations above.</p>
+
 
+
<table>
+
  <thead>
+
    <tr>
+
      <th>Parameter</th>
+
      <th>Value</th>
+
      <th>Source</th>
+
    </tr>
+
  </thead>
+
  <tbody>
+
    <tr>
+
      <td>$\rho_{Bioreactor}$</td>
+
      <td>$200 \ \frac{\text{g d.w.}}{\text{L}}$</td>
+
      <td><a href="https://microbialcellfactories.biomedcentral.com/articles/10.1186/s12934-015-0295-4">Biomedcentral</a></td>
+
    </tr>
+
    <tr>
+
      <td>$m_{\text{Yeast dry weight}}$</td>
+
      <td>$17.5E-12 \text{ g}$</td>
+
      <td><a href="http://kirschner.med.harvard.edu/files/bionumbers/Size%20and%20composition%20of%20yeast%20cells.pdf">Kirschner Lab</a></td>
+
    </tr>
+
    <tr>
+
      <td>$V_{\text{Yeast}}$</td>
+
      <td>$6E-14 \text{ L}$</td>
+
      <td><abbr title="2012, Rob Phillips - Physical Biology of the Cell">Philips 2012</abbr></td>
+
    </tr>
+
    <tr>
+
      <td>$M_{\text{FPP}}$</td>
+
      <td>$382.33 \ \frac{\text{g}}{\text{mol}}$</td>
+
      <td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/445713">Pubchem</a></td>
+
    </tr>
+
    <tr>
+
      <td>$M_{\text{Valencene}}$</td>
+
      <td>$204.36 \  \frac{\text{g}}{\text{mol}}$</td>
+
      <td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/valencene">Pubchem</a></td>
+
    </tr>
+
    <tr>
+
      <td>$M_{\text{Nootkatol}}$</td>
+
      <td>$220.35 \ \frac{\text{g}}{\text{mol}}$</td>
+
      <td><a href="https://pubchem.ncbi.nlm.nih.gov/compound/nootkatol">Pubchem</a></td>
+
    </tr>
+
    <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>
+
 
+
<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 $268.14 \ \frac{\text{mg}}{\text{L}}$ and a Nootkatol Yield of $54  \ \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 model is already quite accurate and that our assumption of a five-fold reduction in the backwards reaction of alcohol dehydrogenase is valid as well, as our $\frac{\text{Nootkatone}}{\text{Nootkatol}}$ ratio was 4.96, which is close to the 4.72 by Wriessnegger. But our model still lacks an important factor, which is why we did not fit the FPP import to this, but to the next model.</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 therefore used hill kinetics to fit this behaviour.</p>
+
<p>$$\frac{K_{Tox}^n}{K_{Tox}^n + [S]^n}$$</p>
+
<p>We fitted the data by Gavira using <code>scipy.optimize.minimize</code> and got the following results. Note that due to numerical reasons the factor <code>n</code> had to be calculated as a float but then was rounded to an integer.</p>
+
 
+
<img class="max-width" src="https://static.igem.org/mediawiki/2017/b/bf/T--Cologne-Duesseldorf--Toxicity.svg">
+
 
+
<table>
+
<thead>
+
  <tr>
+
    <th>Parameter</th>
+
    <th>Value</th>
+
  </tr>
+
</thead>
+
<tbody>
+
  <tr>
+
    <td>$K_{\text{Toxic Nootkatol}}$</td>
+
    <td>105.14</td>
+
  </tr>
+
  <tr>
+
    <td>$n_{\text{Toxic Nootkatol}}$</td>
+
    <td>4</td>
+
  </tr>
+
  <tr>
+
    <td>$K_{\text{Toxic Nootkatone}}$</td>
+
    <td>141.4</td>
+
  </tr>
+
  <tr>
+
    <td>$n_{\text{Toxic Nootkatone}}$</td>
+
    <td>4</td>
+
  </tr>
+
</tbody>
+
</table>
+
 
+
 
+
 
+
<p>Although Nootkatol is more toxic to the cell than Nootkatone the later is concentrated five times higher in our model. We therefore limited us to the Nootkatol penalty to keep the model simple.
+
  We used the arithmetic mean of the two functions as a penalty function for 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.</p>
+
<p>$$\frac{K_{\text{Tox Nkn}}^2}{K_{\text{Tox Nkn}}^2 + [\text{Nkn}]^2}$$</p>
+
<p>This changes our system in the following way.</p>
+
 
+
<img class="max-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}}^2}{K_{\text{Tox Nkn}}^2 + [\text{Nkn}]^2} - \frac{V_{Max,ValS} \cdot c_{FPP}}{K_{M, ValS} + c_{FPP}} $$</p>
+
 
+
<h3 id="PenaltyModel">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 is closest to the actual biological situation. 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 $4.18E-9 \frac{1}{\text{s}}$, which we then also used in all other models.</p>
+
<!-- img penalty -->
+
<img class="max-width" src="https://static.igem.org/mediawiki/2017/2/27/T--Cologne-Duesseldorf--Bioreactor-Penalty-Dynamics.svg">
+
 
+
 
+
<h4>Expression</h4>
+
<p>We wanted to check whether over- or underexpression of any of the enzymes could improve our Nootkatone yield. We therefore set up one analysis in which we held two of the three enzyme concentrations constant while varying the third one and a second one in which all enzyme concentrations were varied at the same time.</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>Since we fitted the FPP concentration an enzyme concentration of $1 \ \text{µM}$, a further increase in enzyme concentration did not result in a higher yield, as was to be expected. But interestingly down-regulating valencen synthase led to an increase in Nootkatone yield, which was probably due to a submaximal penalty. We further wanted to explore how the system reacts when the FPP import is increased by a factor of 10.</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>While the maximal yield is increased the penalty function of the model almost approaches $10E-2$, which means that at the end of the production almost all cells are dead. The increased yield will therefore most probably result as an artifact of a very high valencen production in the beginning. Since only the imoprt function is penalized, all further reactions can still take place.</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">
+
<p>The expression analysis further solidifies the interpretation that the overall yield is linearliy dependent on valencene synthase and FPP import and that the increased yield is an artifact of high early valencene production.
+
 
+
<h4>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">
+
<h3>Peroxisome model</h3>
+
<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">
+
 
+
<h4>Peroxisome 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>Peroxisome model 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>Peroxisome model 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>
+
<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 transfering 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 analyis</a> to show how S. cerevisiae cells can by engineered to stabily produce more FPP.</p>
+
<h2 id="optknock">Optknock Analysis</h2>
+
</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.