COMMENT
hzclamp is een aanpassing op:
Periodic SEClamp
Based on $NEURONHOME/src/nrnoc/svclmp.mod
3/27/2000
Alleen is dit een periodieke currentclamp met een trillingstijd
van 2*dt. Per dt verandert de te injecteren stroom van 0*amp.i
naar 2*amp.i zodat de total geinjecteerde stroom niet verschilt
van de reguliere current clamp, 1*amp.i.
Wij gebruikten de hzclamp om de invloed van de currentclamp en de
celrespons op het extracellulaire veld te scheiden. waarschijnlijk
werkt deze stimulator in 'CVODE'-mode, m.a.w. de variabele tijdstap
integrator maar is in deze mode nog niet getest.
veel succes,
Hans Kager, 20-6-2000
netto geen stroom injectie, geen problemen meer met electroneutraliteit
SEClamp:
Although this model appears to work properly, we cannot guarantee
the absence of bugs, subtle or otherwise. It is provided as a
convenience to NEURON users who may wish to try or modify it for
their own applications.
--Ted Carnevale
ENDCOMMENT
NEURON {
POINT_PROCESS Hzclampna
USEION na WRITE ina
RANGE del, dur, amp, freq, width, ina, telpulse, stand
}
UNITS {
(nA) = (nanoamp)
(uS) = (micromho)
}
PARAMETER {
del (ms)
dur (ms) <0,1e9>
amp (nA)
dt (ms)
freq (1/s)
width (ms)
}
ASSIGNED {
ina (nA)
i_amp (nA)
telpulse
:stand
notify
}
INITIAL {
i_amp = 0
stand = 0
telpulse = 0
notify=del
}
BREAKPOINT {
SOLVE state METHOD after_cvode
at_time(notify)
ina = i_amp
}
STATE { stand }
PROCEDURE state() {
if (t <= del + dur && t >= del) {
if (telpulse/(freq/1000) < t-del && t-del <= telpulse/(freq/1000)+width ) {
notify = del + telpulse/(freq/1000)+width
i_amp=amp
stand=1
} else if (stand == 1 ) {
stand = 0
telpulse = telpulse + 1
i_amp = 0
notify = del + telpulse/(freq/1000)
} else {
i_amp = 0
}
}else{
i_amp = 0
}
}