/*-------------------------------------------------------------------------- Author: Thomas Nowotny Institute: Institute for Nonlinear Dynamics University of California San Diego La Jolla, CA 92093-0402 email to: tnowotny@ucsd.edu initial version: 2002-01-25 --------------------------------------------------------------------------*/ #ifndef LPRNEURON_CC #define LPRNEURON_CC #include "CN_neuron.cc" #define efunc(X,Y,Z) (1.0/(1.0+exp(((X)-(Y))/(Z)))) #define Eaxon x[idx] #define Esoma x[idx+15] LPRneuron::LPRneuron(int inlabel, double *the_p= LPR_p): neuron(inlabel, LPR_IVARNO, LPRNEURON, the_p, LPR_PNO) { } LPRneuron::LPRneuron(int inlabel, vector<int> inpos, double *the_p= LPR_p): neuron(inlabel, LPR_IVARNO, LPRNEURON, inpos, the_p, LPR_PNO) { } inline double LPRneuron::E(double *x) { using namespace LPR5; return x[idx+15]+p[V_shift]; } void LPRneuron::currents(ostream &os, double *x) { using namespace LPR5; static double INa, ICa, IoCa, Id, IA, Ih, Il, IM, IVV, tmp; // differential eqn for the axon membrane potential INa= pw3(x[idx+1])*x[idx+2]*p[g_Na]*(Eaxon-p[V_Na]); Id= pw4(x[idx+8])*p[g_Kd]*(Esoma-p[V_K]); IM= p[g_M]*x[idx+14]*(Eaxon-p[V_M]); Il= p[g_leak]*(Eaxon-p[V_leak]); IVV= p[g_VV]*(Esoma-Eaxon); os << INa << " "; os << Id << " "; os << IM << " "; os << Il << " "; os << IVV << " "; tmp= exp(Esoma/p[RTF]); ICa= (x[idx+3]*x[idx+4]*p[g_CaT]+x[idx+5]*p[g_CaS])* p[P_Ca]*Esoma*(x[idx+13]*tmp-p[Ca_out])/(tmp-1.0); IoCa= x[idx+6]*x[idx+7]*p[g_KCa]*(Esoma-p[V_K]); tmp= efunc(Esoma,p[V_aA],p[s_aA]); IA= pw3(x[idx+9])*p[g_A]*(Esoma-p[V_K])*(tmp*x[idx+10]+(1.0-tmp)*x[idx+11]); Ih= x[idx+12]*p[g_h]*(Esoma-p[V_h]); Il= p[g_leaks]*(Esoma-p[V_leak]); os << ICa << " "; os << IoCa << " "; os << IA << " "; os << Ih << " "; os << Il << endl; } void LPRneuron::derivative(double *x, double *dx) { using namespace LPR5; static double a, b, hinf, kh, minf, km; static double INa, Id, ICa, IoCa, IA, Ih, Il, IM, IVV; static double Isyn; Isyn= 0.0; forall(den, den_it) { Isyn+= (*den_it)->Isyn(x); } // differential eqn for the axon membrane potential INa= pw3(x[idx+1])*x[idx+2]*p[g_Na]*(Eaxon-p[V_Na]); Id= pw4(x[idx+8])*p[g_Kd]*(Eaxon-p[V_K]); IM= p[g_M]*x[idx+14]*(Eaxon-p[V_M]); Il= p[g_leak]*(Eaxon-p[V_leak]); IVV= p[g_VV]*(Esoma-Eaxon); dx[idx]= (-INa - Id - IM - Il + IVV)/p[C_a]; // soma compartment a= exp(Esoma/p[RTF]); ICa= (x[idx+3]*x[idx+4]*p[g_CaT]+x[idx+5]*p[g_CaS]) *p[P_Ca]*Esoma*(x[idx+13]*a-p[Ca_out])/(a-1.0); IoCa= x[idx+6]*x[idx+7]*p[g_KCa]*(Esoma-p[V_K]); a= efunc(Esoma,p[V_aA],p[s_aA]); IA= pw3(x[idx+9])*p[g_A]*(Esoma-p[V_K])*(a*x[idx+10]+(1.0-a)*x[idx+11]); Ih= x[idx+12]*p[g_h]*(Esoma-p[V_h]); Il= p[g_leaks]*(Esoma-p[V_leak]); dx[idx+15]= (-ICa - IoCa - IA - Ih - Il - IVV + (p[I_DC]+Isyn)*p[I_scale])/p[C_s]; // differential eqn for mNa a= (3.5+0.1*x[idx]) / (1.0-exp(-3.5-0.1*x[idx])); b= 4.0*exp(-(x[idx]+60.0)/18.0); dx[idx+1]= (a*(1.0-x[idx+1])-b*x[idx+1])*p[k_slow]*p[k_fast]; // differential eqn for hNa a= 0.07*exp(-x[idx]/20.0-3.0); b= 1.0 / (exp(-3.0-0.1*x[idx])+1.0); dx[idx+2]= (a*(1.0-x[idx+2])-b*x[idx+2])*p[k_slow]*p[k_fast]; // differential eqn for md a= (-0.5-0.01*x[idx]) / (exp(-5.0-0.1*x[idx])-1.0); b= 0.125*exp(-(x[idx]+60.0)/80.0); dx[idx+8]= (a*(1.0-x[idx+8])-b*x[idx+8])*p[k_slow]*p[k_fast]; // differential eqn for mCaT minf= efunc(Esoma,p[V_mCaT],p[s_mCaT]); km= p[k_mCaT]*p[k_slow]; dx[idx+3]= (minf-x[idx+3])*km; // differential eqn for hCaT hinf= efunc(Esoma,p[V_hCaT],p[s_hCaT]); kh= p[k_hCaT]*efunc(Esoma,p[V_khCaT],p[s_khCaT])*p[k_slow]; dx[idx+4]= (hinf-x[idx+4])*kh; // differential eqn for mCaS minf= efunc(Esoma,p[V_mCaS],p[s_mCaS]); km= p[k_mCaS]*p[k_slow]; dx[idx+5]= (minf-x[idx+5])*km; // differential eqn for mKCa a= p[V_mKCa1]-p[f]*x[idx+13]; b= p[V_mKca2]-p[f]*x[idx+13]; minf= efunc(Esoma,a,p[s_mKCa1]) *efunc(Esoma,b,p[s_mKca2])*(x[idx+13]/(p[c_mKCa]+x[idx+13])); km= p[k_mKCa]*p[k_slow]; dx[idx+6]= (minf-x[idx+6])*km; // differential eqn for hKCa hinf= p[c_hKCa1]/(p[c_hKCa2]+x[idx+13]); kh= p[k_hKCa]*p[k_slow]; dx[idx+7]= (hinf-x[idx+7])*kh; // differential eqn for mA minf= efunc(Esoma,p[V_mA],p[s_mA]); km= p[k_mA]*p[k_slow]; dx[idx+9]= (minf-x[idx+9])*km; // differential eqn for hA1 hinf= efunc(Esoma,p[V_hA],p[s_hA]); kh= p[k_hA1]*p[k_slow]; dx[idx+10]= (hinf-x[idx+10])*kh; // differential eqn for hA2 kh= p[k_hA2]*efunc(Esoma,p[V_khA2],p[s_khA2])*p[k_slow]; dx[idx+11]= (hinf-x[idx+11])*kh; // differential eqn for mh minf= efunc(Esoma,p[V_mh],p[s_mh]); km= p[k_mh]/efunc(Esoma,p[V_kmh],p[s_kmh])*p[k_slow]; dx[idx+12]= (minf-x[idx+12])*km; // differential eqn for Ca concentration dx[idx+13]= -p[c_ICa]*ICa - p[k_Ca]*(x[idx+13]-p[Ca_0]); // differential equn for M current activation var minf= efunc(Eaxon,p[V_mM],p[s_mM]); km= p[k_mM]*efunc(Eaxon,p[V_kmM],p[s_kmM])*p[k_slow]; dx[idx+14]= (minf-x[idx+14])*km; } #undef efunc #undef Eaxon #undef Esoma #endif