Location: BG_HaiMurphy @ a67177c16af1 / parameter_finder / Yang_R_mlcp_fitting / Rmlcp_fitting.py

Author:
Shelley Fong <sfon036@UoA.auckland.ac.nz>
Date:
2022-05-20 10:22:46+12:00
Desc:
Adding exposure files
Permanent Source URI:
https://models.physiomeproject.org/workspace/818/rawfile/a67177c16af102ea8ec4d69929c771407a9803c7/parameter_finder/Yang_R_mlcp_fitting/Rmlcp_fitting.py

# Fit a lienar function to R_mlcp, which is a sigmoid dependent on cGMP concentration

import numpy as np
import matplotlib.pyplot as plt
import scipy.optimize

def linearFn(c, m):
    return m * c

# time = np.linspace(0,60,2000)
cGMP = np.linspace(0,15,500) # [=] uM?

Km = 5.5 # [=] uM
R_OG = [pow(t,2)/(pow(Km,2) + pow(t,2)) for t in cGMP]

p0 = (1) # start with values near those we expect
m, cv = scipy.optimize.curve_fit(linearFn, cGMP, R_OG, p0, maxfev=2000, ftol=1e-4) # (function, xdata, ydata, p_IC)
# m, q = params
k_opt = linearFn(cGMP, m)
print(f"kfit = {m} * c)")

# manual plots
# k_test = linearFn(cGMP, 1.66, 0.09995)

plt.figure
plt.plot(cGMP, R_OG)
plt.plot(cGMP, k_opt)
# plt.plot(cGMP, k_test)
plt.legend(['original','fit'])
plt.show()