-
Notifications
You must be signed in to change notification settings - Fork 1
/
ican_nov.mod
105 lines (90 loc) · 2.55 KB
/
ican_nov.mod
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
TITLE Slow Ca-dependent cation current
:
: We've moved to the Model described by Nillus in 2004, while keeping the description of the nanodomain
: modified by Canavier too include separate pool for ICan calcium microdomain
: at this point ican doesn't activate other pools of calcium need to declare a new ion species
: because at this point the code requires pools for SK+BK+T inactivation and ICAN that decay at different rates
INDEPENDENT {
t FROM 0 TO 1 WITH 1 (ms)
}
NEURON {
SUFFIX icannov
USEION ca READ cai, ica
RANGE depth,taur,erev
RANGE gbar,itrpm4, concrelease
RANGE beta,taumin
POINTER jip3p
NONSPECIFIC_CURRENT itrpm4
}
UNITS {
(mA)=(milliamp)
(mV)=(millivolt)
(molar)=(1/liter)
(mM)=(millimolar)
(um)=(micron)
(msM)=(ms mM)
FARADAY=(faraday) (coulomb)
PI = (pi) (1)
}
PARAMETER {
v (mV)
depth=0.0125 (um) : depth of shell 0.0125 for pc1a
taur=80 (ms) : rate of calcium removal 100
erev=0 (mV) : reversal potential
cai (mM) : will now decay to bulk cai
ica (mA/cm2)
gbar=0.0001 (mho/cm2)
: middle point of activation fct, for ip3 as somacar, for current injection
taumin=0.1 (ms) : minimal value of time constant
concrelease=500
Kd = 87e-3 (mM) :87e-3
}
STATE {
can (mM)
Po
}
ASSIGNED {
jip3p (mM/ms)
ican (mA/cm2)
drive_channel (mM/ms)
itrpm4 (mA/cm2)
Po_inf
Tau (ms)
diam (um)
:cai (mM)
}
BREAKPOINT {
SOLVE states METHOD derivimplicit
itrpm4=gbar*Po*(v-erev)
}
DERIVATIVE states {
evaluate_fct(v,can)
Po'=(Po_inf-Po)/(Tau)
drive_channel = - (concrelease) * ica / (2 * FARADAY * depth)
if (drive_channel<=0.0) {drive_channel=0.0} : cannot pump inward
can'=drive_channel+(cai-can)/(taur)
}
FUNCTION MyExp(x) {
if (x<-50) {MyExp=0}
else if (x>50) {MyExp=exp(50)}
else {MyExp=exp(x)}
}
UNITSOFF
INITIAL {
: activation kinetics are assumed to be at 22 deg. C
: Q10 is assumed to be 3
can=cai
evaluate_fct(v,can)
}
PROCEDURE evaluate_fct(v(mV),cai(mM)) {
LOCAL alpha, alpha2, beta
:alpha=0.0057*MyExp(0.0060*v)
:beta=0.033*MyExp(-0.019*v)
alpha=0.0057*MyExp(0.0060*-60)
beta=0.033*MyExp(-0.019*-60)
alpha2=alpha/(1+(Kd/cai))
Po_inf=alpha2/(alpha2+beta)
Tau=1/(alpha2+beta)
if (Tau<taumin) {Tau=taumin} : min value of time cst
}
UNITSON