-
Notifications
You must be signed in to change notification settings - Fork 1
/
Golgi_NaP.mod
103 lines (87 loc) · 1.78 KB
/
Golgi_NaP.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
TITLE Cerebellum Golgi Cell Model
COMMENT
Na persistent channel
Author: E.D Angelo, T.Nieus, A. Fontana
Last revised: 8.5.2000
ENDCOMMENT
NEURON {
SUFFIX Golgi_NaP
USEION na READ ena WRITE ina
RANGE gbar, ina, g
:RANGE Aalpha_m, Kalpha_m, V0alpha_m, alpha_m, beta_m
:RANGE Abeta_m, Kbeta_m, V0beta_m
:RANGE V0_minf, B_minf
RANGE m, m_inf, tau_m, tcorr
:GLOBAL i
}
UNITS {
(mA) = (milliamp)
(mV) = (millivolt)
}
PARAMETER {
gbar = 0.00019 (mho/cm2)
Aalpha_m = -0.91 (/mV-ms)
Kalpha_m = -5 (mV)
V0alpha_m = -40 (mV)
Abeta_m = 0.62 (/mV-ms)
Kbeta_m = 5 (mV)
V0beta_m = -40 (mV)
V0_minf = -43 (mV)
B_minf = 5 (mV)
v (mV)
ena (mV)
celsius (degC)
Q10 = 3 (1)
}
STATE {
m
}
ASSIGNED {
ina (mA/cm2)
m_inf
tau_m (ms)
g (mho/cm2)
alpha_m (/ms)
beta_m (/ms)
tcorr (1)
}
INITIAL {
rate(v)
m = m_inf
}
BREAKPOINT {
SOLVE states METHOD derivimplicit
g = gbar*m
ina = g*(v - ena)
alpha_m = alp_m(v)
beta_m = bet_m(v)
}
DERIVATIVE states {
rate(v)
m' =(m_inf - m)/tau_m
}
FUNCTION alp_m(v(mV))(/ms) {
tcorr = Q10^((celsius-30(degC))/10(degC))
alp_m = tcorr * Aalpha_m*linoid(v-V0alpha_m, Kalpha_m)
}
FUNCTION bet_m(v(mV))(/ms) {
tcorr = Q10^((celsius-30(degC))/10(degC))
bet_m = tcorr * Abeta_m*linoid(v-V0beta_m, Kbeta_m)
}
PROCEDURE rate(v (mV)) {LOCAL a_m, b_m
TABLE m_inf, tau_m
DEPEND Aalpha_m, Kalpha_m, V0alpha_m,
Abeta_m, Kbeta_m, V0beta_m, celsius FROM -100 TO 30 WITH 13000
a_m = alp_m(v)
b_m = bet_m(v)
: m_inf = a_m/(a_m + b_m)
m_inf = 1/(1+exp(-(v-V0_minf)/B_minf))
tau_m = 5/(a_m + b_m)
}
FUNCTION linoid(x (mV),y (mV)) (mV) {
if (fabs(x/y) < 1e-6) {
linoid = y*(1 - x/y/2)
}else{
linoid = x/(exp(x/y) - 1)
}
}