|
|
Line 833: |
Line 833: |
| <h3>Code</h3> | | <h3>Code</h3> |
| <p> Provided below is the Python code that makes up our model:<br> | | <p> Provided below is the Python code that makes up our model:<br> |
− | (Note that we used the jupyter Notebook Editor for our work and we recommend using it as well if you want to try out our model!)<br> | + | (Note that; we used the jupyter Notebook Editor for our work and we recommend using it as well if you want to try out our model!)<br> |
− | <br> | + | <a src="https://static.igem.org/mediawiki/2018/6/63/T--Duesseldorf--Model_Code.txt" download> |
− | import matplotlib.pyplot as plt<br>
| + | |
− | import numpy as np<br>
| + | |
− | import scipy.integrate<br>
| + | |
− | <br>
| + | |
− | def get_itc():<br>
| + | |
− | global itc<br>
| + | |
− | return itc<br>
| + | |
− | def set_itc(new):<br>
| + | |
− | global itc<br>
| + | |
− | itc = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_itn():<br>
| + | |
− | global itn<br>
| + | |
− | return itn<br>
| + | |
− | def set_itn(new):<br>
| + | |
− | global itn<br>
| + | |
− | itn = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_itp():<br>
| + | |
− | global itp<br>
| + | |
− | return itp<br>
| + | |
− | def set_itp(new):<br>
| + | |
− | global itp<br>
| + | |
− | itp = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_itm():<br>
| + | |
− | global itm<br>
| + | |
− | return itm<br>
| + | |
− | def set_itm(new):<br>
| + | |
− | global itm<br>
| + | |
− | itm = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_itpa():<br>
| + | |
− | global itpa<br>
| + | |
− | return itpa<br>
| + | |
− | def set_itpa(new):<br>
| + | |
− | global itpa<br>
| + | |
− | itpa = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_c_e():<br>
| + | |
− | global i_c_e<br>
| + | |
− | return i_c_e<br>
| + | |
− | def set_i_c_e(new):<br>
| + | |
− | global i_c_e<br>
| + | |
− | i_c_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_c_s():<br>
| + | |
− | global i_c_s<br>
| + | |
− | return i_c_s<br>
| + | |
− | def set_i_c_s(new):<br>
| + | |
− | global i_c_s<br>
| + | |
− | i_c_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_c_se():<br>
| + | |
− | global i_c_se<br>
| + | |
− | return i_c_se<br>
| + | |
− | def set_i_c_se(new):<br>
| + | |
− | global i_c_se<br>
| + | |
− | i_c_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_n_e():<br>
| + | |
− | global i_n_e<br>
| + | |
− | return i_n_e<br>
| + | |
− | def set_i_n_e(new):<br>
| + | |
− | global i_n_e<br>
| + | |
− | i_n_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_n_s():<br>
| + | |
− | global i_n_s<br>
| + | |
− | return i_n_s<br>
| + | |
− | def set_i_n_s(new):<br>
| + | |
− | global i_n_s<br>
| + | |
− | i_n_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_n_se():<br>
| + | |
− | global i_n_se<br>
| + | |
− | return i_n_se<br>
| + | |
− | def set_i_n_se(new):<br>
| + | |
− | global i_n_se<br>
| + | |
− | i_n_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_p_e():<br>
| + | |
− | global i_p_e<br>
| + | |
− | return i_p_e<br>
| + | |
− | def set_i_p_e(new):<br>
| + | |
− | global i_p_e<br>
| + | |
− | i_p_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_p_s():<br>
| + | |
− | global i_p_s<br>
| + | |
− | return i_p_s<br>
| + | |
− | def set_i_p_s(new):<br>
| + | |
− | global i_p_s<br>
| + | |
− | i_p_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_p_se():<br>
| + | |
− | global i_p_se<br>
| + | |
− | return i_p_se<br>
| + | |
− | def set_i_p_se(new):<br>
| + | |
− | global i_p_se<br>
| + | |
− | i_p_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_m():<br>
| + | |
− | global i_m<br>
| + | |
− | return i_m<br>
| + | |
− | def set_i_m(new):<br>
| + | |
− | global i_m<br>
| + | |
− | i_m = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_i_pa():<br>
| + | |
− | global i_pa<br>
| + | |
− | return i_pa<br>
| + | |
− | def set_i_pa(new):<br>
| + | |
− | global i_pa<br>
| + | |
− | i_pa = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | <br>
| + | |
− | def get_m_c_e():<br>
| + | |
− | global m_c_e<br>
| + | |
− | return m_c_e<br>
| + | |
− | def set_m_c_e(new):<br>
| + | |
− | global m_c_e<br>
| + | |
− | m_c_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_c_s():<br>
| + | |
− | global m_c_s<br>
| + | |
− | return m_c_s<br>
| + | |
− | def set_m_c_s(new):<br>
| + | |
− | global m_c_s<br>
| + | |
− | m_c_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_c_se():<br>
| + | |
− | global m_c_se<br>
| + | |
− | return m_c_se<br>
| + | |
− | def set_m_c_se(new):<br>
| + | |
− | global m_c_se<br>
| + | |
− | m_c_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_n_e():<br>
| + | |
− | global m_n_e<br>
| + | |
− | return m_n_e<br>
| + | |
− | def set_m_n_e(new):<br>
| + | |
− | global m_n_e<br>
| + | |
− | m_n_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_n_s():<br>
| + | |
− | global m_n_s<br>
| + | |
− | return m_n_s<br>
| + | |
− | def set_m_n_s(new):<br>
| + | |
− | global m_n_s<br>
| + | |
− | m_n_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_n_se():<br>
| + | |
− | global m_n_se<br>
| + | |
− | return m_n_se<br>
| + | |
− | def set_m_n_se(new):<br>
| + | |
− | global m_n_se<br>
| + | |
− | m_n_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_p_e():<br>
| + | |
− | global m_p_e<br>
| + | |
− | return m_p_e<br>
| + | |
− | def set_m_p_e(new):<br>
| + | |
− | global m_p_e<br>
| + | |
− | m_p_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_p_s():<br>
| + | |
− | global m_p_s<br>
| + | |
− | return m_p_s<br>
| + | |
− | def set_m_p_s(new):<br>
| + | |
− | global m_p_s<br>
| + | |
− | m_p_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_p_se():<br>
| + | |
− | global m_p_se<br>
| + | |
− | return m_p_se<br>
| + | |
− | def set_m_p_se(new):<br>
| + | |
− | global m_p_se<br>
| + | |
− | m_p_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_m():<br>
| + | |
− | global m_m<br>
| + | |
− | return m_m<br>
| + | |
− | def set_m_m(new):<br>
| + | |
− | global m_m<br>
| + | |
− | m_m = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_m_pa():<br>
| + | |
− | global m_pa<br>
| + | |
− | return m_pa<br>
| + | |
− | def set_m_pa(new):<br>
| + | |
− | global m_pa<br>
| + | |
− | m_pa = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | <br>
| + | |
− | def get_sec():<br>
| + | |
− | global sec<br>
| + | |
− | return sec<br>
| + | |
− | def set_sec(new):<br>
| + | |
− | global sec<br>
| + | |
− | sec = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_ssc():<br>
| + | |
− | global ssc<br>
| + | |
− | return ssc<br>
| + | |
− | def set_ssc(new):
| + | |
− | global ssc<br>
| + | |
− | ssc = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_sel():<br>
| + | |
− | global sel<br>
| + | |
− | return sel<br>
| + | |
− | def set_sel(new):<br>
| + | |
− | global sel<br>
| + | |
− | sel = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_expsec():<br>
| + | |
− | global expsec<br>
| + | |
− | return expsec<br>
| + | |
− | def set_expsec(new):<br>
| + | |
− | global expsec<br>
| + | |
− | expsec = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_expssc():<br>
| + | |
− | global expssc<br>
| + | |
− | return expssc<br>
| + | |
− | def set_expssc(new):<br>
| + | |
− | global expssc<br>
| + | |
− | expssc = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_expsel():<br>
| + | |
− | global expsel<br>
| + | |
− | return expsel<br>
| + | |
− | def set_expsel(new):<br>
| + | |
− | global expsel<br>
| + | |
− | expsel = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | <br>
| + | |
− | def get_alpha_c_e():<br>
| + | |
− | global alpha_c_e<br>
| + | |
− | return alpha_c_e<br>
| + | |
− | def set_alpha_c_e(new):<br>
| + | |
− | global alpha_c_e<br>
| + | |
− | alpha_c_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_c_s():<br>
| + | |
− | global alpha_c_s<br>
| + | |
− | return alpha_c_s<br>
| + | |
− | def set_alpha_c_s(new):<br>
| + | |
− | global alpha_c_s<br>
| + | |
− | alpha_c_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_c_se():<br>
| + | |
− | global alpha_c_se<br>
| + | |
− | return alpha_c_se<br>
| + | |
− | def set_alpha_c_se(new):<br>
| + | |
− | global alpha_c_se<br>
| + | |
− | alpha_c_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_n_e():<br>
| + | |
− | global alpha_n_e<br>
| + | |
− | return alpha_n_e<br>
| + | |
− | def set_alpha_n_e(new):<br>
| + | |
− | global alpha_n_e<br>
| + | |
− | alpha_n_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_n_s():<br>
| + | |
− | global alpha_n_s<br>
| + | |
− | return alpha_n_s<br>
| + | |
− | def set_alpha_n_s(new):<br>
| + | |
− | global alpha_n_s<br>
| + | |
− | alpha_n_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_n_se():<br>
| + | |
− | global alpha_n_se<br>
| + | |
− | return alpha_n_se<br>
| + | |
− | def set_alpha_n_se(new):<br>
| + | |
− | global alpha_n_se<br>
| + | |
− | alpha_n_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_p_e():<br>
| + | |
− | global alpha_p_e<br>
| + | |
− | return alpha_p_e<br>
| + | |
− | def set_alpha_p_e(new):<br>
| + | |
− | global alpha_p_e<br>
| + | |
− | alpha_p_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_p_s():<br>
| + | |
− | global alpha_p_s<br>
| + | |
− | return alpha_p_s<br>
| + | |
− | def set_alpha_p_s(new):<br>
| + | |
− | global alpha_p_s<br>
| + | |
− | alpha_p_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_p_se():<br>
| + | |
− | global alpha_p_se<br>
| + | |
− | return alpha_p_se<br>
| + | |
− | def set_alpha_p_se(new):<br>
| + | |
− | global alpha_p_se<br>
| + | |
− | alpha_p_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_m():<br>
| + | |
− | global alpha_m<br>
| + | |
− | return alpha_m<br>
| + | |
− | def set_alpha_m(new):<br>
| + | |
− | global alpha_m<br>
| + | |
− | alpha_m = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_alpha_pa():<br>
| + | |
− | global alpha_pa<br>
| + | |
− | return alpha_pa<br>
| + | |
− | def set_alpha_pa(new):<br>
| + | |
− | global alpha_pa<br>
| + | |
− | alpha_pa = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | <br>
| + | |
− | def get_use_c_e():<br>
| + | |
− | global use_c_e<br>
| + | |
− | return use_c_e<br>
| + | |
− | def set_use_c_e(new):<br>
| + | |
− | global use_c_e<br>
| + | |
− | use_c_e = new<br>
| + | |
− | return<br><br>
| + | |
− | <br>
| + | |
− | def get_use_c_s():<br>
| + | |
− | global use_c_s<br>
| + | |
− | return use_c_s<br>
| + | |
− | def set_use_c_s(new):<br>
| + | |
− | global use_c_s<br>
| + | |
− | use_c_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_use_c_se():<br>
| + | |
− | global use_c_se<br>
| + | |
− | return use_c_se<br>
| + | |
− | def set_use_c_se(new):<br>
| + | |
− | global use_c_se<br>
| + | |
− | use_c_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_use_n_e():<br>
| + | |
− | global use_n_e<br>
| + | |
− | return use_n_e<br>
| + | |
− | def set_use_n_e(new):<br>
| + | |
− | global use_n_e<br>
| + | |
− | use_n_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_use_n_s():<br>
| + | |
− | global use_n_s<br>
| + | |
− | return use_n_s<br>
| + | |
− | def set_use_n_s(new):<br>
| + | |
− | global use_n_s<br>
| + | |
− | use_n_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_use_n_se():<br>
| + | |
− | global use_n_se<br>
| + | |
− | return use_n_se<br>
| + | |
− | def set_use_n_se(new):<br>
| + | |
− | global use_n_se<br>
| + | |
− | use_n_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_use_p_e():<br>
| + | |
− | global use_p_e<br>
| + | |
− | return use_p_e<br>
| + | |
− | def set_use_p_e(new):<br>
| + | |
− | global use_p_e<br>
| + | |
− | use_p_e = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_use_p_s():<br>
| + | |
− | global use_p_s<br>
| + | |
− | return use_p_s<br>
| + | |
− | def set_use_p_s(new):<br>
| + | |
− | global use_p_s<br>
| + | |
− | use_p_s = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | <br>
| + | |
− | def get_use_p_se():<br>
| + | |
− | global use_p_se<br>
| + | |
− | return use_p_se<br>
| + | |
− | def set_use_p_se(new):<br>
| + | |
− | global use_p_se<br>
| + | |
− | use_p_se = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_use_m():<br>
| + | |
− | global use_m<br>
| + | |
− | return use_m<br>
| + | |
− | def set_use_m(new):<br>
| + | |
− | global use_m<br>
| + | |
− | use_m = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_use_pa():<br>
| + | |
− | global use_pa<br>
| + | |
− | return use_pa<br>
| + | |
− | def set_use_pa(new):<br>
| + | |
− | global use_pa<br>
| + | |
− | use_pa = new<br>
| + | |
− | return<br>
| + | |
− | <br>
| + | |
− | def get_ye0():<br>
| + | |
− | global ye0<br>
| + | |
− | return ye0<br>
| + | |
− | def get_ys0():<br>
| + | |
− | global ys0<br>
| + | |
− | return ys0<br>
| + | |
− | def get_yse0():<br>
| + | |
− | global yse0<br>
| + | |
− | return yse0<br>
| + | |
− | <br>
| + | |
− | def get_capacity_e():<br>
| + | |
− | global capacity_e<br>
| + | |
− | return capacity_e<br>
| + | |
− | def get_capacity_s():<br>
| + | |
− | global capacity_s<br>
| + | |
− | return capacity_s<br>
| + | |
− | def get_capacity_se():<br>
| + | |
− | global capacity_se<br>
| + | |
− | return capacity_se<br>
| + | |
− | <br>
| + | |
− | def get_t():<br>
| + | |
− | global t<br>
| + | |
− | return t<br>
| + | |
− | <br>
| + | |
− | <br>
| + | |
− | def trinity():<br>
| + | |
− | #übergebe Zeit<br>
| + | |
− | t = get_t()<br>
| + | |
− | <br>
| + | |
− | #Übergibt Initiale Organismen-Konzentrationen<br>
| + | |
− | e_coli = get_ye0()<br>
| + | |
− | s_cerevisiae = get_ys0()<br>
| + | |
− | s_elongatus = get_yse0()<br>
| + | |
− | <br>
| + | |
− | #Übergibt Initiale Stoff-Konzentrationen (extern)<br>
| + | |
− | c = get_itc() #kohlenstoff/zucker<br>
| + | |
− | n = get_itn() #Stickstoff<br>
| + | |
− | p = get_itp() #Phosphor<br>
| + | |
− | m = get_itm() #Melanin<br>
| + | |
− | pa = get_itpa() #Phosphit<br>
| + | |
− | <br>
| + | |
− | #Übergibt Initiale Stoff-Konzentrationen (intern)<br>
| + | |
− | i_c_e = get_i_c_e() #kohlenstoff/zucker, e.coli<br>
| + | |
− | i_c_s = get_i_c_s() #kohlenstoff/zucker, s.cervisae<br>
| + | |
− | i_c_se = get_i_c_se() #kohlenstoff/zucker, s.elongatus<br>
| + | |
− | i_n_e = get_i_n_e() #Stickstoff, e.coli<br>
| + | |
− | i_n_s = get_i_n_s() #Stickstoff, s.cervisae<br>
| + | |
− | i_n_se = get_i_n_se() #Stickstoff, s.elongatus<br>
| + | |
− | i_p_e = get_i_p_e() #Phosphor, e.coli<br>
| + | |
− | i_p_s = get_i_p_s() #Phosphor, s.cervisae<br>
| + | |
− | i_p_se = get_i_p_se() #Phosphor, s.elongatus<br>
| + | |
− | i_m = get_i_m() #Melanin<br>
| + | |
− | i_pa = get_i_pa() #Phosphit<br>
| + | |
− | <br>
| + | |
− | #Übergibt Maximale Stoffkonzentrationen (intern)<br>
| + | |
− | m_c_e = get_m_c_e()<br>
| + | |
− | m_c_s = get_m_c_s()<br>
| + | |
− | m_c_se = get_m_c_se()<br>
| + | |
− | m_n_e = get_m_n_e()<br>
| + | |
− | m_n_s = get_m_n_s()<br>
| + | |
− | m_n_se = get_m_n_se()<br>
| + | |
− | m_p_e = get_m_p_e()<br>
| + | |
− | m_p_e = get_m_p_e()<br>
| + | |
− | m_p_se = get_m_p_se()<br>
| + | |
− | m_m = get_m_m()<br>
| + | |
− | m_pa = get_m_pa()<br>
| + | |
− | <br>
| + | |
− | #Übergibt Metaboliten Geschwindigkeiten<br>
| + | |
− | sec = get_sec()<br>
| + | |
− | ssc = get_ssc()<br>
| + | |
− | sel = get_sel()<br>
| + | |
− | expsec = get_expsec()<br>
| + | |
− | expssc = get_expssc()<br>
| + | |
− | expsel = get_expsel()<br>
| + | |
− | <br>
| + | |
− | #Übergibt Absorbationsgeschwindingikeiten<br>
| + | |
− | alpha_c_e = get_alpha_c_e()<br>
| + | |
− | alpha_c_s = get_alpha_c_s()<br>
| + | |
− | alpha_c_se = get_alpha_c_se()<br>
| + | |
− | alpha_n_e = get_alpha_n_e()<br>
| + | |
− | alpha_n_s = get_alpha_n_s()<br>
| + | |
− | alpha_n_se = get_alpha_n_se()<br>
| + | |
− | alpha_p_e = get_alpha_p_e()<br>
| + | |
− | alpha_p_s = get_alpha_p_s()<br>
| + | |
− | alpha_p_se = get_alpha_p_se()<br>
| + | |
− | alpha_m = get_alpha_m()<br>
| + | |
− | alpha_pa = get_alpha_pa()<br>
| + | |
− | <br>
| + | |
− | #Übergibt Metaboliten Nutzung<br>
| + | |
− | use_c_e = get_use_c_e()<br>
| + | |
− | use_c_s = get_use_c_s()<br>
| + | |
− | use_c_se = get_use_c_se()<br>
| + | |
− | use_n_e = get_use_n_e()<br>
| + | |
− | use_n_s = get_use_n_s()<br>
| + | |
− | use_n_se = get_use_n_se()<br>
| + | |
− | use_p_e = get_use_p_e()<br>
| + | |
− | use_p_s = get_use_p_s()<br>
| + | |
− | use_p_se = get_use_p_se()<br>
| + | |
− | <br>
| + | |
− | <br>
| + | |
− | i = 0<br>
| + | |
− | Y_e = [e_coli]<br>
| + | |
− | Y_s = [s_cerevisiae]<br>
| + | |
− | Y_se = [s_elongatus]<br>
| + | |
− | <br>
| + | |
− | capacity_e = get_capacity_e()<br>
| + | |
− | capacity_s = get_capacity_s()<br>
| + | |
− | capacity_se = get_capacity_se()<br>
| + | |
− | <br>
| + | |
− | for j in t:<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_m * ((m_m*(Y_e[i]/Y_e[0]) - i_m)/m_m), m)<br>
| + | |
− | i_m = i_m+add<br>
| + | |
− | m = m - add<br>
| + | |
− | ret = min(i_m, sec*(Y_e[i]/Y_e[0]))<br>
| + | |
− | n = n + ret<br>
| + | |
− | i_m = i_m - ret<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_pa * ((m_pa*(Y_s[i]/Y_s[0])-i_pa)/m_pa), pa)<br>
| + | |
− | i_pa = i_pa+add<br>
| + | |
− | pa = pa - add<br>
| + | |
− | ret = min(i_pa, ssc*(Y_s[i]/Y_s[0]))<br>
| + | |
− | p = p + ret<br>
| + | |
− | i_pa = i_pa - ret<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_c_e * ((m_c_e*(Y_e[i]/Y_e[0]) - i_c_e)/m_c_e), c)<br>
| + | |
− | i_c_e = i_c_e+add<br>
| + | |
− | growthf_c_e = min(i_c_e/(use_c_e*(Y_e[i]/Y_e[0])), 1)<br>
| + | |
− | i_c_e = i_c_e-growthf_c_e*use_c_e*(Y_e[i]/Y_e[0])<br>
| + | |
− | c = c-add<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_c_s * ((m_c_s*(Y_s[i]/Y_s[0]) - i_c_s)/m_c_s), c)<br>
| + | |
− | i_c_s = i_c_s+add<br>
| + | |
− | growthf_c_s = min(i_c_s/(use_c_s*(Y_s[i]/Y_s[0])), 1)<br>
| + | |
− | i_c_s = i_c_s - growthf_c_s*use_c_s*(Y_s[i]/Y_s[0])<br>
| + | |
− | c = c-add<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_c_se * ((m_c_se*(Y_se[i]/Y_se[0]) - i_c_se)/m_c_se), c)<br>
| + | |
− | i_c_se = i_c_se+add + sel - sel*expsel<br>
| + | |
− | growthf_c_se = min(i_c_se/(use_c_se*(Y_se[i]/Y_se[0])), 1)<br>
| + | |
− | i_c_se=i_c_se- growthf_c_se*use_c_se*(Y_se[i]/Y_se[0])<br>
| + | |
− | c = c-add + sel*expsel*(Y_se[i]/Y_se[0]) <br>
| + | |
− | <br>
| + | |
− | add = min(alpha_n_e * ((m_n_e*(Y_e[i]/Y_e[0]) - i_n_e)/m_n_e), n)<br>
| + | |
− | i_n_e = i_n_e+add<br>
| + | |
− | growthf_n_e = min(i_n_e/(use_n_e*(Y_e[i]/Y_e[0])), 1)<br>
| + | |
− | i_n_e = i_n_e-growthf_n_e*use_n_e*(Y_e[i]/Y_e[0])<br>
| + | |
− | n = n-add<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_n_s * ((m_n_s*(Y_s[i]/Y_s[0]) - i_n_s)/m_n_s), n)<br>
| + | |
− | i_n_s = i_n_s+add<br>
| + | |
− | growthf_n_s = min(i_n_s/(use_n_s*(Y_s[i]/Y_s[0])), 1)<br>
| + | |
− | i_n_s=i_n_s-growthf_n_s*use_n_s*(Y_s[i]/Y_s[0])<br>
| + | |
− | n = n-add<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_n_se * ((m_n_se*(Y_se[i]/Y_se[0]) - i_n_se)/m_n_se), n)<br>
| + | |
− | i_n_se = i_n_se+add<br>
| + | |
− | growthf_n_se = min(i_n_se/(use_n_se*(Y_se[i]/Y_se[0])), 1)<br>
| + | |
− | i_n_se = i_n_se-growthf_n_se*use_n_se*(Y_se[i]/Y_se[0])<br>
| + | |
− | n = n-add<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_p_e * ((m_p_e*(Y_e[i]/Y_e[0]) - i_p_e)/m_p_e), p)<br>
| + | |
− | i_p_e = i_p_e+add<br>
| + | |
− | growthf_p_e = min(i_p_e/(use_p_e*(Y_e[i]/Y_e[0])), 1)<br>
| + | |
− | i_p_e=i_p_e-growthf_p_e*use_p_e*(Y_e[i]/Y_e[0])<br>
| + | |
− | p = p-add<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_p_s * ((m_p_s*(Y_s[i]/Y_s[0]) - i_p_s)/m_p_s), p)<br>
| + | |
− | i_p_s = i_p_s+add<br>
| + | |
− | growthf_p_s = min(i_p_s/(use_p_s*(Y_s[i]/Y_s[0])), 1)<br>
| + | |
− | i_p_s=i_p_s-growthf_p_s*use_p_s*(Y_s[i]/Y_s[0])<br>
| + | |
− | p = p-add<br>
| + | |
− | <br>
| + | |
− | add = min(alpha_p_se * ((m_p_se*(Y_se[i]/Y_se[0]) - i_p_se)/m_p_se), p)<br>
| + | |
− | i_p_se = i_p_se+add<br>
| + | |
− | growthf_p_se = min(i_p_se/(use_p_se*(Y_se[i]/Y_se[0])), 1)<br>
| + | |
− | i_p_se=i_p_se-growthf_p_se*use_p_se*(Y_se[i]/Y_se[0])<br>
| + | |
− | p = p-add<br>
| + | |
− | <br>
| + | |
− | if (growthf_c_e == 0 or growthf_n_e == 0 or growthf_p_e == 0):<br>
| + | |
− | growth_e = -0.1<br>
| + | |
− | else:<br>
| + | |
− | growth_e = min(growthf_c_e, growthf_n_e, growthf_p_e)<br>
| + | |
− | <br>
| + | |
− | if (growthf_c_s == 0 or growthf_n_s == 0 or growthf_p_s == 0):<br>
| + | |
− | growth_s = -0.1<br>
| + | |
− | else:<br>
| + | |
− | growth_s = min(growthf_c_s, growthf_n_s, growthf_p_s)<br>
| + | |
− | <br>
| + | |
− | if (growthf_c_se == 0 or growthf_n_se == 0 or growthf_p_se == 0):<br>
| + | |
− | growth_se = -0.1<br>
| + | |
− | else:<br>
| + | |
− | growth_se = min(growthf_c_se, growthf_n_se, growthf_p_se)<br>
| + | |
− | <br>
| + | |
− | Y_e = Y_e + [Y_e[i]+growth_e * ((capacity_e - e_coli) / capacity_e)]<br>
| + | |
− | Y_s = Y_s + [Y_s[i]+growth_s * ((capacity_s - s_cerevisiae) / capacity_s)*(1/8)]<br>
| + | |
− | Y_se = Y_se + [Y_se[i]+growth_se * ((capacity_se - s_elongatus) / capacity_se)*(1/24)]<br>
| + | |
− | <br>
| + | |
− | e_coli = Y_e[i]<br>
| + | |
− | s_cerevisiae = Y_s[i]<br>
| + | |
− | s_elongatus = Y_se[i]<br>
| + | |
− | | + | |
− | i = i+1<br>
| + | |
− | <br>
| + | |
− | Y_e.pop();<br>
| + | |
− | Y_s.pop();<br>
| + | |
− | Y_se.pop();<br>
| + | |
− | return Y_e, Y_s, Y_se;<br>
| + | |
− | <br>
| + | |
− | fig = plt.figure()<br>
| + | |
− | ax = plt.axes()<br>
| + | |
− | <br>
| + | |
− | Y = trinity();<br>
| + | |
− | for i, species in enumerate(["$\t{E. coli}$", "$\t{S. cerevisiae}$", "$\t{S. elongatus}$"]):<br>
| + | |
− | plt.plot(t, Y[i], label=species)<br>
| + | |
− | plt.legend(frameon=False, loc='upper right', ncol=1, labelspacing=1)<br>
| + | |
− | plt.xlabel("Time in Hours")<br>
| + | |
− | plt.ylabel("Dryweight in Mol")<br>
| + | |
− | plt.show()<br>
| + | |
− | </p>
| + | |
− | </div>
| + | |
| </article> | | </article> |
| </body> | | </body> |
Model
As the aim of our project is to construct a modular toolkit using co-cultures with three organism, we would have to conduct many experimental iterations to reach conclusive and reliable results. To avoid this tedious process, we, as many other scientists working in this field, turned our attention to computer based biological modeling to predict the behavior of our system.
In the realm of mathematical and computer based biology, scientists use algorithms, data structure and data visualization to create approximations of existing biological systems. This serves two important goals; One, to check wether the theoretical understanding of a process is correct. Of course, this can be done by constructing a model and checking if the cultures behave within reasonable correctness as the observations in the lab indicate.
The other goal of such modeling approach is to predict wether the behavior of the system are changed or other external influences are applied. This latter role is why we are using modeling in our project.
However, many of our team members lacked experience in this field. As such, we approached the Institute of Quantitative and Theoretical Biology at our university (Headed by Professor Dr. Oliver Ebenhöh) to discuss our approach.
The behavior of a coculture is complex. Modeling in it’s entirety would be far too complex. As such we had to find a way to reduce this complexity. To achieve this, we began our work with laying out a few assumptions that would reduce the complexity of our system and give us a clear indicator of what went wrong if a prediction turned out to be incorrect.
In our model we assumed that:
- The consumption of metabolites, especially for growth, occurs in discreet units.
- All organisms have equal access to the metabolites.
- There are no organism specific limits to metabolite uptake or release.
- Every metabolite are constant and optimal except the ones we control with.
- Growth as well as metabolic reactions are limited by low avalability as well as the slowest enzyme reaction, respectively.
- There is no change in the speed of reactions.
- The capacity of the system for each organism is set and not calculated dynamically.
- While phosphate and nitrogen are important for growth, only a complete lack of carbon (as a stand-in for sugar in our model) will result in starvation of the organisms.
Assumption 1 is a consequence of the way our model is calculated, the others are there to reduce complexity. As stated above, this reduced complexity also reflects a reduction in realism, however, our model has produced results that in our mind, make a more complex approach unnecessary for now.
Our model is iterative and goes though the following equations for each organism and metabolite each iteration:
Here, add represents the additional metabolite influx per iteration. &alpha is the organism and metabolite specific uptake speed, mc is the maximum possible concentration of the specific metabolite in the organism, Ye[i] is the current dry weight (in mol) of the organism and Ye[0] is the initial dry weight. ic is the current metabolite mass inside the organism (in mol) and C is the mass of metabolite (in mol) inside the medium. usec is the specific metabolite mass the organisms the organism uses each iteration in it’s growth, whereas growthfc, growthfn, and growthfp are the metabolite specific growth factors. The lowest of these is chosen as the overall growth factor growth and then used in the calculation of the new population size Ye[i+1].
As stated above, these calculation are performed for each organism and each metabolite. the resulting populations lists are then plotted via the Python package Matplotlib (as you can see in the code we provided at the end of the page).
This produces a graph that shows what the growth and population sizes of our system look like within a predetermined time frame. This tells us which ratio of metabolite concentration to population sizes is necessary for the system to remain stable over a given period of time. This gives us a range of concentrations that we can then verify in the lab. This reduces the amount of experiments we have to conduct to reach our goal of establishing a stable, purpose-engineered three organism coculture.
Of course observation in the lab take precedent over our model. And data that is in conflict with the prediction of our model will always be given priority. Until now however, our model has been correct. Thus far, it has revealed that the same problem is the supplying the system with sugar, as S. elongatus is has the lowest doubling time and appears to be the main bottleneck. Below a few example models are supplied, with varying amounts of metabolite supplied at the beginning.
Here are a few examples where we used our three model organisms E. coli, S. cerevisae and S. elongatus and plotted their growth over the course of 48 hours. Changed are the concentrations of the metabolites we control with, in our example this is carbon, nitrogen and phosphor, in the medium, but everything else was kept at the same value;
- Every metabolite is set at 10 Mol initially:
- Every metabolite is set at 50 Mol initially:
- Every metabolite is set at 100 Mol initially:
As stated above, each of our assumption attempts to reduce complexity also limits realism. If given more time we could further refine our model and start working without our assumptions. This would increase the accuracy of our predictions and would further our understanding of cocultures and microbe interaction.
It would however also necessitate more experiments to verify our predictions, which was something we didn’t have the time for.
Another possibility we could not pursue was interactivity and the option to include other organisms in our model. We hoped that we could construct a model that would receive a selection of organisms, metabolites that bind the organisms together and a time frame and from that calculate the optimal medium composition as well as initial population sizes to keep the coculture stable.
We believe that such a thing is possible with our model and if we would have had more time to verify our modeling of our lab work, we could have realized this idea.
Code
Provided below is the Python code that makes up our model:
(Note that; we used the jupyter Notebook Editor for our work and we recommend using it as well if you want to try out our model!)