COMMENT
ENDCOMMENT
NEURON {
SUFFIX cdp5StCmod
USEION ca READ cao, cai, ica WRITE cai
USEION nrvc READ nrvci VALENCE 1
RANGE ica_pmp
RANGE Nannuli, Buffnull2, rf3, rf4, vrat
RANGE CAM0, CAM1C, CAM2C, CAM1N2C, CAM1N, CAM2N, CAM2N1C, CAM1C1N, CAM4, icazz
RANGE TotalPump
}
UNITS {
(mol) = (1)
(molar) = (1/liter)
(mM) = (millimolar)
(um) = (micron)
(mA) = (milliamp)
FARADAY = (faraday) (10000 coulomb)
PI = (pi) (1)
}
PARAMETER {
Nannuli = 10.9495 (1)
celsius (degC)
cainull = 45e-6 (mM)
mginull =.59 (mM)
Buffnull1 = 0 (mM)
rf1 = 0.0134329 (/ms mM)
rf2 = 0.0397469 (/ms)
Buffnull2 = 60.9091 (mM)
rf3 = 0.1435 (/ms mM)
rf4 = 0.0014 (/ms)
BTCnull = 0 (mM)
b1 = 5.33 (/ms mM)
b2 = 0.08 (/ms)
DMNPEnull = 0 (mM)
c1 = 5.63 (/ms mM)
c2 = 0.107e-3 (/ms)
PVnull = .08 (mM)
m1 = 1.07e2 (/ms mM)
m2 = 9.5e-4 (/ms)
p1 = 0.8 (/ms mM)
p2 = 2.5e-2 (/ms)
CAM_start = 0.03 (mM)
Kd1C = 0.00965 (mM) K1Coff = 0.04 (/ms) K1Con = 5.4 (/mM ms) Kd2C = 0.00105 (mM) K2Coff = 0.00925 (/ms) K2Con = 15 (/mM ms)
Kd1N = 0.0275 (uM) K1Noff = 2.5 (/ms) K1Non = 142.5 (/mM ms) Kd2N = 0.00615 (mM) K2Noff = 0.75 (/ms) K2Non = 175 (/mM ms)
kpmp1 = 3e-3 (/mM-ms)
kpmp2 = 1.75e-5 (/ms)
kpmp3 = 7.255e-5 (/ms)
TotalPump = 1e-9 (mol/cm2)
nrvci (nA)
}
ASSIGNED {
diam (um)
ica (mA/cm2)
ica_pmp (mA/cm2)
parea (um) parea2 (um)
cai (mM)
mgi (mM)
vrat (1)
icazz (nA)
}
CONSTANT { cao = 2 (mM) }
STATE {
ca (mM) <1e-3>
mg (mM) <1e-6>
Buff1 (mM)
Buff1_ca (mM)
Buff2 (mM)
Buff2_ca (mM)
BTC (mM)
BTC_ca (mM)
DMNPE (mM)
DMNPE_ca (mM)
PV (mM)
PV_ca (mM)
PV_mg (mM)
CAM0 (mM)
CAM1C (mM)
CAM2C (mM)
CAM1N2C (mM)
CAM1N (mM)
CAM2N (mM)
CAM2N1C (mM)
CAM1C1N (mM)
CAM4 (mM)
pump (mol/cm2) <1e-15>
pumpca (mol/cm2) <1e-15>
}
BREAKPOINT {
SOLVE state METHOD sparse
}
LOCAL factors_done
INITIAL {
factors()
ca = cainull
mg = mginull
Buff1 = ssBuff1()
Buff1_ca = ssBuff1ca()
Buff2 = ssBuff2()
Buff2_ca = ssBuff2ca()
BTC = ssBTC()
BTC_ca = ssBTCca()
DMNPE = ssDMNPE()
DMNPE_ca = ssDMNPEca()
PV = ssPV( kdc(), kdm())
PV_ca = ssPVca(kdc(), kdm())
PV_mg = ssPVmg(kdc(), kdm())
CAM0 = CAM_start
CAM1C = 0
CAM2C = 0
CAM1N2C = 0
CAM1N = 0
CAM2N = 0
CAM2N1C = 0
CAM1C1N = 0
CAM4 = 0
parea = PI*diam
parea2 = PI*(diam-0.2)
ica = 0
ica_pmp = 0
pump = TotalPump
pumpca = 0
cai = ca
}
PROCEDURE factors() {
LOCAL r, dr2
r = 1/2 dr2 = r/(Nannuli-1)/2 vrat = PI*(r-dr2/2)*2*dr2 r = r - dr2
}
LOCAL dsq, dsqvol
KINETIC state {
COMPARTMENT diam*diam*vrat {ca mg Buff1 Buff1_ca Buff2 Buff2_ca BTC BTC_ca DMNPE DMNPE_ca PV PV_ca PV_mg}
COMPARTMENT (1e10)*parea {pump pumpca}
~ ca + pump <-> pumpca (kpmp1*parea*(1e10), kpmp2*parea*(1e10))
~ pumpca <-> pump (kpmp3*parea*(1e10), 0)
CONSERVE pump + pumpca = TotalPump * parea * (1e10)
ica_pmp = 2*FARADAY*(f_flux - b_flux)/parea
~ ca << (-ica*PI*diam/(2*FARADAY))
dsq = diam*diam
dsqvol = dsq*vrat
~ ca + Buff1 <-> Buff1_ca (rf1*dsqvol, rf2*dsqvol)
~ ca + Buff2 <-> Buff2_ca (rf3*dsqvol, rf4*dsqvol)
~ ca + BTC <-> BTC_ca (b1*dsqvol, b2*dsqvol)
~ ca + DMNPE <-> DMNPE_ca (c1*dsqvol, c2*dsqvol)
~ ca + PV <-> PV_ca (m1*dsqvol, m2*dsqvol)
~ mg + PV <-> PV_mg (p1*dsqvol, p2*dsqvol)
~ ca + CAM0 <-> CAM1C (K1Con*dsqvol, K1Coff*dsqvol)
~ ca + CAM1C <-> CAM2C (K2Con*dsqvol, K2Coff*dsqvol)
~ ca + CAM2C <-> CAM1N2C (K1Non*dsqvol, K1Noff*dsqvol)
~ ca + CAM1N2C <-> CAM4 (K2Non*dsqvol, K2Noff*dsqvol)
~ ca + CAM0 <-> CAM1N (K1Non*dsqvol, K1Noff*dsqvol)
~ ca + CAM1N <-> CAM2N (K2Non*dsqvol, K2Noff*dsqvol)
~ ca + CAM2N <-> CAM2N1C (K1Con*dsqvol, K1Coff*dsqvol)
~ ca + CAM2N1C <-> CAM4 (K2Con*dsqvol, K2Coff*dsqvol)
~ ca + CAM1C <-> CAM1C1N (K1Non*dsqvol, K1Noff*dsqvol)
~ ca + CAM1N <-> CAM1C1N (K1Con*dsqvol, K1Coff*dsqvol)
~ ca + CAM1C1N <-> CAM1N2C (K2Con*dsqvol, K2Coff*dsqvol)
~ ca + CAM1C1N <-> CAM2N1C (K2Non*dsqvol, K2Noff*dsqvol)
cai = ca
mgi = mg
icazz = nrvci
}
FUNCTION ssBuff1() (mM) {
ssBuff1 = Buffnull1/(1+((rf1/rf2)*cainull))
}
FUNCTION ssBuff1ca() (mM) {
ssBuff1ca = Buffnull1/(1+(rf2/(rf1*cainull)))
}
FUNCTION ssBuff2() (mM) {
ssBuff2 = Buffnull2/(1+((rf3/rf4)*cainull))
}
FUNCTION ssBuff2ca() (mM) {
ssBuff2ca = Buffnull2/(1+(rf4/(rf3*cainull)))
}
FUNCTION ssBTC() (mM) {
ssBTC = BTCnull/(1+((b1/b2)*cainull))
}
FUNCTION ssBTCca() (mM) {
ssBTCca = BTCnull/(1+(b2/(b1*cainull)))
}
FUNCTION ssDMNPE() (mM) {
ssDMNPE = DMNPEnull/(1+((c1/c2)*cainull))
}
FUNCTION ssDMNPEca() (mM) {
ssDMNPEca = DMNPEnull/(1+(c2/(c1*cainull)))
}
FUNCTION kdc() (1) {
kdc = (cainull*m1)/m2
}
FUNCTION kdm() (1) {
kdm = (mginull*p1)/p2
}
FUNCTION ssPV( kdc(), kdm()) (mM) {
ssPV = PVnull/(1+kdc()+kdm())
}
FUNCTION ssPVca( kdc(), kdm()) (mM) {
ssPVca = (PVnull*kdc())/(1+kdc()+kdm())
}
FUNCTION ssPVmg( kdc(), kdm()) (mM) {
ssPVmg = (PVnull*kdm())/(1+kdc()+kdm())
}