-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathhill_functions.py
77 lines (54 loc) · 2.05 KB
/
hill_functions.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
import numpy as np
# 1 input inhibition --> NOT gate
def repress_1(R, Kd, n):
return 1/(1 + pow(R/Kd, n))
# 2 input inhibition --> NOR gate
def repress_2(R1, R2, Kd1, n1, Kd2=0, n2=0, comp = 0):
if not Kd2:
Kd2 = Kd1
if not n2:
n2 = n1
if comp:
return 1/(1 + pow(R1/Kd1, n1) + pow(R2/Kd2, n2))
else:
return 1/(1 + pow(R1/Kd1, n1) + pow(R2/Kd2, n2) + pow(R1/Kd1, n1) * pow(R2/Kd2, n2))
# 1 input activation: YES gate
def activate_1(A, Kd, n):
return pow(A/Kd, n)/(1 + pow(A/Kd, n))
# 2 input activation: AND gate
def activate_2(A1, A2, Kd1, n1, Kd2=0, n2=0):
if not Kd2:
Kd2 = Kd1
if not n2:
n2 = n1
return pow(A1/Kd1, n1) * pow(A2/Kd2, n2)/(1 + pow(A1/Kd1, n1) + pow(A2/Kd2, n2) + pow(A1/Kd1, n1) * pow(A2/Kd2, n2))
# 3 input activation: AND gate
def activate_3(A1, A2, A3, Kd, n):
return activate_1(A1, Kd, n) * activate_1(A2, Kd, n) * activate_1(A3, Kd, n)
# activation + inhibition
def hybrid(A, R, Kd_A, n_A, Kd_R, n_R):
return activate_1(A, Kd_A, n_A) * repress_1(R, Kd_R, n_R)
# activation + activation + inhibition
def hybrid_AAR(A1, A2, A3, Kd_A, n_A, Kd_R=0, n_R=0):
if not Kd_R:
Kd_R = Kd_A
if not n_R:
n_R = n_A
return activate_1(A1, Kd_A, n_A) * activate_1(A2, Kd_A, n_A) * repress_1(A3, Kd_R, n_R)
def induction(x, i, Kd, n=1):
# Michelis-Menten equation - using NumPy for numerical stability
numerator = x * np.power(i, n)
denominator = np.power(i, n) + np.power(Kd, n)
return numerator / denominator
def inhibition(x, i, Kd, n):
if i == 0:
return x # Avoid division by zero
else:
denominator = 1 + np.power(i / Kd, n)
return x / denominator
# CLOCK GENERATOR
def get_clock(t, amp=100, per=24, phase = 0):
return amp*(np.sin(2*np.pi*(t)/per + phase) + 1)/2
def modulated_clock(t, inhibitor, Kd, n, amp=100, per=24, phase=0):
clock_signal = get_clock(t, amp, per, phase)
return inhibition(clock_signal, inhibitor, Kd, n)