-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathbounds.py
91 lines (73 loc) · 3.06 KB
/
bounds.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
'''
Defines the parameter value bounds. Only used in 'parsimonious' perturbation.
See optimize.py for the 'naive' bounds.
TODO: move 'naive' bounds to this file or another file
'''
from __future__ import division
import numpy as np
import constants
import structure
'''
The bounds of our new, transformed system (parsimonious perturbations). Bounds
the lower and upper values of:
- maximum forward and reverse rates of reaction
- saturation ratios
- concentrations of dynamic species
'''
BOUNDS_MATRIX = structure.activity_matrix
INVERSE_BOUNDS_MATRIX = np.linalg.pinv(BOUNDS_MATRIX)
RESOLUTION = np.finfo(np.float64).resolution # "resolution" of 64-bit floating point number, = 1e-15
'''
Choosing upper and lower v_max values is difficult, however we know from
fluxomics that an active pathway (like glycolysis) operates around a net
flux of 0.1 mM/s. These bounds are centered about an average of about 3 uM/s,
and with a range consistent with the RESOLUTION. The hope is that this average
is low enough to be representative of the average flux, and far enough from
our target glycolysis flux to not bias initialization. At the same time, a
flux that is too small could be tough for the system to escape.
Note that this is just v_max, not a total constraint on v. Assuming enzymes
that are at least somewhat unsaturated, the real "average" v's should be even
smaller.
'''
LOWER_VMAX = 1e-12 # one molecule per E. coli cell (1 nM) diluting at doubling time of 1 hour ~1e-13 M/s
UPPER_VMAX = 1e-3 # 20000 ribosomes translating at 16 AA/s ~0.3 mM/s
LOWER_VMAX = 1e-9
BOUNDS_SATURATED_REACTION_POTENTIAL = (
-constants.RT * np.log(UPPER_VMAX/constants.K_STAR),
-constants.RT * np.log(LOWER_VMAX/constants.K_STAR),
)
'''
The upper and lower bounds on binding ratios were selected with the
knowledge that all binding ratios are relative to the "unbound" ratio, which
in our generalized kinetic model is 1. Thus, for numerical significance, the
minimum saturation ratio is RESOLUTION and the maximum is 1/RESOLUTION. The
range here is quite wide but that was needed to accomadate the range in the
training data.
'''
BOUNDS_BINDING_POTENTIAL = (
-constants.RT * np.log(1/RESOLUTION),
-constants.RT * np.log(RESOLUTION),
)
'''
Concentration are bounded from 1 fM to 1 MM. Both are more permissive than
expected values. A concentration of one molecule per E. coli cell is roughly
1 nM, while water, the most abundant species, has a concentration of about
50 M. The range is consistent with the RESOLUTION.
'''
LOWER_CONC = 1e-10
UPPER_CONC = 1e2
BOUNDS_GIBBS_LOG_CONC = (
constants.RT * np.log(LOWER_CONC),
constants.RT * np.log(UPPER_CONC),
)
(LOWERBOUNDS, UPPERBOUNDS) = np.column_stack(
[BOUNDS_SATURATED_REACTION_POTENTIAL] * (
structure.forward_saturated_reaction_potential_matrix.shape[0]
+ structure.reverse_saturated_reaction_potential_matrix.shape[0]
)
+ [BOUNDS_BINDING_POTENTIAL] * (
structure.solo_forward_binding_potential_matrix.shape[0]
+ structure.solo_reverse_binding_potential_matrix.shape[0]
)
+ [BOUNDS_GIBBS_LOG_CONC] * structure.glc_association_matrix.shape[0]
)