forked from mbezaire/ca1
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ch_KvGroup.mod
129 lines (102 loc) · 2.61 KB
/
ch_KvGroup.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
TITLE Slower potassium channels (voltage dependent)
COMMENT
Slower potassium channels (voltage dependent)
Ions: k
Style: quasi-ohmic
From: Modified from Yuen and Durand, 1991 (squid axon) by Aradi and Holmes (2002)
Updates:
2014 December (Marianne Bezaire): documented
2014 February (Marianne Bezaire): modified to fit the experimental data from Lu and Jonas
? ? ?: shifted by 65 mV as compared to the Aradi & Holmes paper, unsure why
ENDCOMMENT
VERBATIM
#include <stdlib.h> /* Include this library so that the following
(innocuous) warning does not appear:
In function '_thread_cleanup':
warning: incompatible implicit declaration of
built-in function 'free' */
ENDVERBATIM
UNITS {
(mA) =(milliamp)
(mV) =(millivolt)
(uF) = (microfarad)
(molar) = (1/liter)
(nA) = (nanoamp)
(mM) = (millimolar)
(um) = (micron)
FARADAY = 96520 (coul)
R = 8.3134 (joule/degC)
}
NEURON {
SUFFIX ch_KvGroup
USEION k READ ek WRITE ik VALENCE 1
RANGE g, gmax, ninf, ntau, ik
RANGE myi
THREADSAFE
}
PARAMETER {
v (mV)
celsius (degC) : temperature - set in hoc; default is 6.3
dt (ms)
ek (mV)
gmax (mho/cm2)
}
STATE {
n
}
ASSIGNED {
g (mho/cm2)
ik (mA/cm2)
ninf
ntau (ms)
nexp
myi (mA/cm2)
}
BREAKPOINT {
SOLVE states
g = gmax*n
ik = g*(v-ek)
myi = ik
}
UNITSOFF
INITIAL {
trates(v)
n = ninf
}
PROCEDURE states() { :Computes state variables m, h, and n
trates(v) : at the current v and dt.
n = n + nexp*(ninf-n)
}
LOCAL q10
PROCEDURE rates(v) { :Computes rate and other constants at current v.
:Call once from HOC to initialize inf at resting v.
LOCAL alpha, beta, sum
q10 = 3^((celsius - 34)/10)
:"nf" fKDR activation system
:alpha = a*(-(v+b))/(exp(-(v+b)/c)-1) : Lien and Jonas, 2003
alpha = 0.0189324*vtrap(-(v-4.18371),6.42606) : Lien and Jonas, 2003
beta = 0.015857*exp(-v/25.4834) : Lien and Jonas, 2003
sum = alpha+beta
ntau = 1/sum
ninf = alpha/sum
}
PROCEDURE trates(v) { :Computes rate and other constants at current v.
:Call once from HOC to initialize inf at resting v.
LOCAL tinc
TABLE ninf, nexp, ntau
DEPEND dt, celsius
FROM -100 TO 100 WITH 200
rates(v) : not consistently executed from here if usetable_hh == 1
: so don't expect the tau values to be tracking along with
: the inf values in hoc
tinc = -dt * q10
nexp = 1 - exp(tinc/ntau)
}
FUNCTION vtrap(x,y) { :Traps for 0 in denominator of rate eqns.
if (fabs(x/y) < 1e-6) {
vtrap = y*(1 - x/y/2)
}else{
vtrap = x/(exp(x/y) - 1)
}
}
UNITSON