-
Notifications
You must be signed in to change notification settings - Fork 1
/
Na.mod
132 lines (100 loc) · 2.73 KB
/
Na.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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
COMMENT
This file is based on na16.mod of Hu et al. (nn, 2009)
******************************************************
Sodium channel, Hodgkin-Huxley style kinetics.
Kinetics were fit to data from Huguenard et al. (1988) and Hamill et al. (1991)
qi is not well constrained by the data, since there are no points between -80 and -55. So this was fixed at 5
while the thi1, thi2, Rg, Rd were optimized using a simplex least square proc
voltage dependencies are shifted approximately from the best fit to give higher threshold
Author: Zach Mainen, Salk Institute, 1994, [email protected]
******************************************************
SHL modified as follows:
1-1) qa: 6 -> 8
1-2) qinf: 6.2 -> 8 mV, since qa and qinf = 8 mV (Kim Jonas nn 12).
cf. qa and qinf = 5.8 and 7.1 in Hu Shu nn 09
2) tha, -43 -> -38 (Kim Jonas nn 12)
3) use cnexp as an integration mtd
SHL End
ENDCOMMENT
INDEPENDENT {t FROM 0 TO 1 WITH 1 (ms)}
NEURON {
SUFFIX Na
USEION na READ ena WRITE ina
RANGE m, h, gna, gbar
GLOBAL tha, thi1, thi2, qa, qi, qinf, thinf
RANGE minf, hinf, mtau, htau
GLOBAL Ra, Rb, Rd, Rg
GLOBAL q10, temp, tadj, vmin, vmax, vshift
}
PARAMETER {
gbar = 0.01 (mS/cm2)
vshift = 0 (mV) : voltage shift (affects all)
tha = -38 (mV) : v 1/2 for act curve
qa = 8 (mV) : act slope
Ra = 0.182 (/ms) : prop const of alpha_m (/ms)
Rb = 0.124 (/ms) : prop const of beta_m (/ms)
thi1 = -50 (mV) : v shift of alpha_h
thi2 = -75 (mV) : v shift of beta_h
qi = 5 (mV) : inact tau slope
thinf = -73 (mV) : v1/2 of inact curve
qinf = 8 (mV) : Slope of inact curve; 6.2 -> 8
Rg = 0.0091 (/ms) : prop const of beta_h(v)
Rd = 0.024 (/ms) : prop const of alpha_h(v)
temp = 30 (degC) : original temp
q10 = 2.3 : temperature sensitivity
v (mV)
dt (ms)
celsius (degC)
vmin = -120 (mV)
vmax = 100 (mV)
}
UNITS {
(mA) = (milliamp)
(mV) = (millivolt)
(pS) = (picosiemens)
(um) = (micron)
}
ASSIGNED {
ina (mA/cm2)
gna (pS/um2)
ena (mV)
minf hinf
mtau (ms) htau (ms)
tadj
}
STATE { m h }
INITIAL {
rates(v+vshift)
m = minf
h = hinf
tadj = q10^((celsius - temp)/10)
}
BREAKPOINT {
SOLVE states METHOD cnexp
gna = tadj*gbar*m*m*m*h
ina = gna * (v - ena)
}
DERIVATIVE states {
rates(v+vshift) : at the current v and dt.
m' = (minf-m)*tadj/mtau
h' = (hinf-h)*tadj/htau
}
PROCEDURE rates(vm) {
LOCAL a, b
a = trap0(vm,tha,Ra,qa)
b = trap0(-vm,-tha,Rb,qa)
mtau = 1/(a+b)
minf = a*mtau
:"h" inactivation
a = trap0(vm,thi1,Rd,qi)
b = trap0(-vm,-thi2,Rg,qi)
htau = 1/(a+b)
hinf = 1/(1+exp((vm-thinf)/qinf))
}
FUNCTION trap0(v,th,a,q) {
if (fabs(v-th) > 1e-6) {
trap0 = a * (v - th) / (1 - exp(-(v - th)/q))
} else {
trap0 = a * q
}
}