-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathpregencv.mod
127 lines (110 loc) · 2.84 KB
/
pregencv.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
: $Id: pregencv.mod,v 1.5 1998/10/18 19:02:05 billl Exp $
: Id: pregen.mod,v 1.1 1998/07/01 21:11:23 hines Exp
: comments at end
INDEPENDENT {t FROM 0 TO 1 WITH 1 (ms)}
NEURON {
POINT_PROCESS SpikeGenerator
RANGE x,num
RANGE fast_invl, slow_invl, burst_len, start, end
RANGE noise
GLOBAL dummy : prevent vectorization for use with CVODE
}
PARAMETER {
fast_invl = 1 : time between spikes in a burst (msec)
slow_invl = 50 : burst period (msec)
: actually, above is interburst period in conformity with original version
: see
burst_len = 10 : burst length (# spikes)
start = 50 : start of first interburst interval
end = 1e10 : time to stop bursting
noise = 0 : amount of randomness (0.0 - 1.0)
}
ASSIGNED {
x
num
burst
event
burst_off
burst_on
toff
dummy
}
PROCEDURE seed(x) {
set_seed(x)
}
INITIAL {
num = 0 : currently not used -- for callback
toff = 1e9
x = -90
burst = 0
event = start-slow_invl
event_time()
while (event < 0) { event_time() }
generate()
}
BREAKPOINT {
SOLVE generate METHOD cvode_t
}
FUNCTION interval(mean (ms)) (ms) {
if (mean <= 0.) {
mean = .01 : I would worry if it were 0.
}
if (noise == 0) {
interval = mean
}else{
interval = (1. - noise)*mean + noise*exprand(mean)
}
}
PROCEDURE event_time() {
if (burst != 0.) {
event = event + interval(fast_invl)
if (event > burst_on + burst_off) {
burst = 0.
}
}else{
burst = 1.
: if slow_invl from beginning of burst to beginning of burst
: event = event + interval(slow_invl - (burst_len-1)*fast_invl)
: use following if slow_invl is interburst interval
event = event + interval(slow_invl)
burst_on = event
burst_off = interval((burst_len - 1)*fast_invl)-1e-6
}
if (event > end) {
event = -1e5
}
}
PROCEDURE generate() {
if (at_time(event)) {
VERBATIM
{char func[] = "pregencv_c";
Symbol* s = hoc_lookup(func);
if (s) {
hoc_pushx(num);
hoc_call_func(s, 1);
}}
ENDVERBATIM
x = 20
toff = event + .1
event_time()
}
if (at_time(toff)) {
x = -90
}
}
COMMENT
Presynaptic spike generator
---------------------------
This mechanism has been written to be able to use synapses in a single
neuron receiving various types of presynaptic trains. This is a "fake"
presynaptic compartment containing a fast spike generator. The trains
of spikes can be either periodic or noisy (Poisson-distributed), and
either tonic or bursting.
Parameters;
noise: between 0 (no noise-periodic) and 1 (fully noisy)
fast_invl: fast interval, mean time between spikes (ms)
slow_invl: slow interval, mean burst silent period (ms), 0=tonic train
burst_len: mean burst length (nb. spikes)
Written by Z. Mainen, modified by A. Destexhe, The Salk Institute
Modified by Michael Hines for use with CVode
ENDCOMMENT