- Author:
- Leyla <noroozbabaee@gmail.com>
- Date:
- 2022-05-10 14:01:08+12:00
- Desc:
- Adding Tong_2011 to PMR
- Permanent Source URI:
- https://models.cellml.org/workspace/85c/rawfile/a03f680a69226c515cd789723c8036028406852b/Experiments/Figure_12/Fig12_sim.py
# with the following commands at the prompt in the OpenCOR Python console:
#
# In [1]: cd path/to/folder_this_file_is_in
# In [2]: run Fig1_sim.py
import opencor as oc
import matplotlib.pyplot as plt
import numpy as np
# The prefix of the saved output file name
prefilename = 'Fig11'
# Load the simulation file
sub =['A','B','C','D','E']
varName = np.array(["Time", "Force", "I_tot", "v", "cai"])
# # simulation.reset(True)
simfile = 'Tong_2011_newVersion.sedml'
simulation = oc.open_simulation(simfile)
data = simulation.data()
# Set constant values
start = 0
end = 20000
pointInterval = 1
# Reset states variables
data.set_starting_point(start)
data.set_ending_point(end)
data.set_point_interval(pointInterval)
I_st = [ -0.1, -0.4, -0.4, -1.2]
# ca = [0.000216]#, 0.001,0.0001,0.00001]
ca = [0.000116,0.000116,0.000116, 0.000156]
v_init =[-53, -55,-53,-53]
for i in range(len(ca)):
simulation.reset(True)
# if i==1:
# data.constants() [ 'interface/I_CaL/sf'] = 5.5
# else:
# data.constants() [ 'interface/I_CaL/sf' ] = 1
# # data.constants() [ 'interface/parameters/ko' ] = 5
# if i==2:
# data.constants() [ 'interface/parameters/ko' ] = 10
# else:
# data.constants() [ 'interface/parameters/ko' ] = 5
data.constants() [ 'interface/membrane_potential/v_var' ] = 1
data.constants() [ 'interface/I_test_swt' ] = 1
data.constants() [ 'interface/test_start'] = 1000
data.constants() [ 'interface/test_end'] = 10000
data.constants() [ 'interface/I_test'] = I_st[i]
data.constants() [ 'interface/Ca_Concentrations/cai_hold_swtch'] = 0
data.constants() [ 'interface/membrane_potential/v_var'] = 1
data.constants() [ 'interface/membrane_potential/a_correction'] = 1
data.constants() [ 'interface/Ca_Concentrations/cai_init'] = ca [i]#ca[i]
data.constants() [ 'interface/membrane_potential/v_init' ] = v_init[i]
simulation.run()
# Access simulation results
results = simulation.results()
# Data to save
rows = end * 1 + 1
vars = np.reshape(varName, (1, 5))
# Grab a some algebraic variable results
r = np.zeros((rows, len(varName)))
r [ :, 0 ] = results.voi().values()
r [ :, 1 ] = results.algebraic()['interface/Ca_dependent_Force/Force'].values()
r [ :, 2 ] = results.algebraic() [ 'interface/membrane_potential/I_tot'].values()
r [ :, 3 ] = results.algebraic() [ 'interface/membrane_potential/v'].values()
r [ :, 4 ] = results.algebraic() [ 'interface/Ca_Concentrations/cai'].values()
filename = '%s_%s.csv' % (prefilename, sub[i])
np.savetxt(filename, vars, fmt='%s', delimiter=",")
with open(filename, "ab") as f:
np.savetxt(f, r, delimiter=",")
f.close