本文整理汇总了C++中NODEV函数的典型用法代码示例。如果您正苦于以下问题:C++ NODEV函数的具体用法?C++ NODEV怎么用?C++ NODEV使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了NODEV函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: NODED
void Cvode::nocap_v_part1(NrnThread* _nt){
int i;
CvodeThreadData& z = ctd_[_nt->id];
for (i = 0; i < z.no_cap_count_; ++i) { // initialize storage
Node* nd = z.no_cap_node_[i];
NODED(nd) = 0;
NODERHS(nd) = 0;
}
// compute the i(vmold) and di/dv
rhs_memb(z.no_cap_memb_, _nt);
lhs_memb(z.no_cap_memb_, _nt);
for (i = 0; i < z.no_cap_count_; ++i) {// parent axial current
Node* nd = z.no_cap_node_[i];
// following from global v_parent
NODERHS(nd) += NODED(nd) * NODEV(nd);
Node* pnd = _nt->_v_parent[nd->v_node_index];
if (pnd) {
NODERHS(nd) -= NODEB(nd) * NODEV(pnd);
NODED(nd) -= NODEB(nd);
}
}
for (i = 0; i < z.no_cap_child_count_; ++i) {// child axial current
Node* nd = z.no_cap_child_[i];
// following from global v_parent
Node* pnd = _nt->_v_parent[nd->v_node_index];
NODERHS(pnd) -= NODEA(nd) * NODEV(nd);
NODED(pnd) -= NODEA(nd);
}
nrn_multisplit_nocap_v_part1(_nt);
}
示例2: lmfree
void LinearMechanism::create()
{
int i;
lmfree();
i = 0;
Object* o = *hoc_objgetarg(++i);
if (strcmp(o->ctemplate->sym->name, "PythonObject") == 0) {
f_callable_ = o;
hoc_obj_ref(o);
c_ = matrix_arg(++i);
} else {
f_callable_ = NULL;
c_ = matrix_arg(1);
}
g_ = matrix_arg(++i);
y_ = vector_arg(++i);
if (ifarg(i + 2) && hoc_is_object_arg(i + 2) && is_vector_arg(i + 2)) {
y0_ = vector_arg(++i);
}
b_ = vector_arg(++i);
if (ifarg(++i)) {
#if HAVE_IV
Oc oc;
#endif
if (hoc_is_double_arg(i)) {
nnode_ = 1;
nodes_ = new Node*[1];
double x = chkarg(i, 0., 1.);
Section* sec = chk_access();
nodes_[0] = node_exact(sec, x);
nrn_notify_when_double_freed(&NODEV(nodes_[0]), this);
}else{
Object* o = *hoc_objgetarg(i);
check_obj_type(o, "SectionList");
SectionList* sl = new SectionList(o);
sl->ref();
Vect* x = vector_arg(i+1);
Section* sec;
nnode_ = 0;
nodes_ = new Node*[x->capacity()];
for (sec = sl->begin(); sec; sec = sl->next()) {
nodes_[nnode_] = node_exact(sec, x->elem(nnode_));
nrn_notify_when_double_freed(&NODEV(nodes_[nnode_]), this);
++nnode_;
}
if (ifarg(i+2)) {
elayer_ = vector_arg(i+2);
}
sl->unref();
}
}
model_ = new LinearModelAddition(c_, g_, y_, y0_, b_,
nnode_, nodes_, elayer_, f_callable_);
}
示例3: NODEV
void NonLinImpRep::dsdv() {
int ieq, i, in, is, iis;
NrnThread* nt = nrn_threads;
ieq = neq_ - n_ode_;
for (NrnThreadMembList* tml = nt->tml; tml; tml = tml->next) {
Memb_list* ml = tml->ml;
i = tml->index;
if (memb_func[i].ode_count && ml->nodecount) {
int nc = ml->nodecount;
Pfridot s = (Pfridot)memb_func[i].ode_count;
int cnt = (*s)(i);
if (memb_func[i].current) {
double* x1 = rv_; // use as temporary storage
double* x2 = jv_;
// zero rhs, save v
for (in = 0; in < ml->nodecount; ++in) { Node* nd = ml->nodelist[in];
for (is = ieq + in*cnt, iis = 0; iis < cnt; ++iis, ++is) {
*pvdot_[is] = 0.;
}
x1[in] = NODEV(nd);
}
// increment v only once in case there are multiple
// point processes at the same location
for (in = 0; in < ml->nodecount; ++in) { Node* nd = ml->nodelist[in];
if (x1[in] == NODEV(nd)) {
NODEV(nd) += delta_;
}
}
// compute rhs. this is the rhs(v+dv)
ode(i, ml);
// save rhs, restore v, and zero rhs
for (in = 0; in < ml->nodecount; ++in) { Node* nd = ml->nodelist[in];
for (is = ieq + in*cnt, iis = 0; iis < cnt; ++iis, ++is) {
x2[is] = *pvdot_[is];
*pvdot_[is] = 0;
}
NODEV(nd) = x1[in];
}
// compute the rhs(v)
ode(i, ml);
// fill the ds/dv elements
for (in = 0; in < ml->nodecount; ++in) { Node* nd = ml->nodelist[in];
for (is = ieq + in*cnt, iis = 0; iis < cnt; ++iis, ++is) {
double ds = (x2[is] - *pvdot_[is])/delta_;
if (ds != 0.) {
double* elm = cmplx_spGetElement(m_, is+1, v_index_[nd->v_node_index]);
elm[0] = -ds;
}
}
}
}
ieq += cnt*nc;
}
}
}
示例4: nrn_notify_pointer_disconnect
void LinearMechanism::update_ptrs() {
if (nodes_) {
nrn_notify_pointer_disconnect(this);
for (int i=0; i < nnode_; ++i) {
double* pd = nrn_recalc_ptr(&(NODEV(nodes_[i])));
if (pd != &(NODEV(nodes_[i]))) {
nrn_notify_when_double_freed(pd, this);
}
}
}
}
示例5: update
static void update(NrnThread* _nt)
{
int i, i1, i2;
i1 = 0;
i2 = _nt->end;
#if CACHEVEC
if (use_cachevec) {
/* do not need to worry about linmod or extracellular*/
if (secondorder) {
for (i=i1; i < i2; ++i) {
VEC_V(i) += 2.*VEC_RHS(i);
}
}else{
for (i=i1; i < i2; ++i) {
VEC_V(i) += VEC_RHS(i);
}
}
}else
#endif
{ /* use original non-vectorized update */
if (secondorder) {
#if _CRAY
#pragma _CRI ivdep
#endif
for (i=i1; i < i2; ++i) {
NODEV(_nt->_v_node[i]) += 2.*NODERHS(_nt->_v_node[i]);
}
}else{
#if _CRAY
#pragma _CRI ivdep
#endif
for (i=i1; i < i2; ++i) {
NODEV(_nt->_v_node[i]) += NODERHS(_nt->_v_node[i]);
}
if (use_sparse13) {
nrndae_update();
}
}
} /* end of non-vectorized update */
#if EXTRACELLULAR
nrn_update_2d(_nt);
#endif
#if I_MEMBRANE
if (_nt->tml) {
assert(_nt->tml->index == CAP);
nrn_capacity_current(_nt, _nt->tml->ml);
}
#endif
}
示例6: rate
double KSSingleTrans::rate(Point_process* pnt) {
if (kst_->type_ < 2) {
return rate(NODEV(pnt->node));
}else{
return rate(pnt->prop->dparam);
}
}
示例7: nrn_state
static void nrn_state(_NrnThread* _nt, _Memb_list* _ml, int _type) {
double _break, _save;
double* _p; Datum* _ppvar; Datum* _thread;
Node *_nd; double _v; int* _ni; int _iml, _cntml;
#if CACHEVEC
_ni = _ml->_nodeindices;
#endif
_cntml = _ml->_nodecount;
_thread = _ml->_thread;
for (_iml = 0; _iml < _cntml; ++_iml) {
_p = _ml->_data[_iml]; _ppvar = _ml->_pdata[_iml];
_nd = _ml->_nodelist[_iml];
#if CACHEVEC
if (use_cachevec) {
_v = VEC_V(_ni[_iml]);
}else
#endif
{
_nd = _ml->_nodelist[_iml];
_v = NODEV(_nd);
}
_break = t + .5*dt; _save = t;
v=_v;
{
ek = _ion_ek;
{ {
for (; t < _break; t += dt) {
states(_p, _ppvar, _thread, _nt);
}}
t = _save;
} }}
}
示例8: nrn_state
static void nrn_state(_NrnThread* _nt, _Memb_list* _ml, int _type) {
double* _p; Datum* _ppvar; Datum* _thread;
Node *_nd; double _v = 0.0; int* _ni; int _iml, _cntml;
#if CACHEVEC
_ni = _ml->_nodeindices;
#endif
_cntml = _ml->_nodecount;
_thread = _ml->_thread;
for (_iml = 0; _iml < _cntml; ++_iml) {
_p = _ml->_data[_iml]; _ppvar = _ml->_pdata[_iml];
_nd = _ml->_nodelist[_iml];
#if CACHEVEC
if (use_cachevec) {
_v = VEC_V(_ni[_iml]);
}else
#endif
{
_nd = _ml->_nodelist[_iml];
_v = NODEV(_nd);
}
v=_v;
{
cai = _ion_cai;
{ _deriv1_advance = 1;
derivimplicit_thread(2, _slist1, _dlist1, _p, states, _ppvar, _thread, _nt);
_deriv1_advance = 0;
} }}
}
示例9: nrn_cur
static void nrn_cur(_NrnThread* _nt, _Memb_list* _ml, int _type) {
double* _p; Datum* _ppvar; Datum* _thread;
Node *_nd; int* _ni; double _rhs, _v; int _iml, _cntml;
#if CACHEVEC
_ni = _ml->_nodeindices;
#endif
_cntml = _ml->_nodecount;
_thread = _ml->_thread;
for (_iml = 0; _iml < _cntml; ++_iml) {
_p = _ml->_data[_iml]; _ppvar = _ml->_pdata[_iml];
#if CACHEVEC
if (use_cachevec) {
_v = VEC_V(_ni[_iml]);
}else
#endif
{
_nd = _ml->_nodelist[_iml];
_v = NODEV(_nd);
}
_g = _nrn_current(_p, _ppvar, _thread, _nt, _v + .001);
{ _rhs = _nrn_current(_p, _ppvar, _thread, _nt, _v);
}
_g = (_g - _rhs)/.001;
#if CACHEVEC
if (use_cachevec) {
VEC_RHS(_ni[_iml]) -= _rhs;
}else
#endif
{
NODERHS(_nd) -= _rhs;
}
}}
示例10: nrn_state
static void nrn_state(_NrnThread* _nt, _Memb_list* _ml, int _type){
double _break, _save;
Node *_nd; double _v; int* _ni; int _iml, _cntml;
#if CACHEVEC
_ni = _ml->_nodeindices;
#endif
_cntml = _ml->_nodecount;
for (_iml = 0; _iml < _cntml; ++_iml) {
_p = _ml->_data[_iml]; _ppvar = _ml->_pdata[_iml];
_nd = _ml->_nodelist[_iml];
#if CACHEVEC
if (use_cachevec) {
_v = VEC_V(_ni[_iml]);
}else
#endif
{
_nd = _ml->_nodelist[_iml];
_v = NODEV(_nd);
}
_break = t + .5*dt; _save = t;
v=_v;
{
ek = _ion_ek;
{ {
for (; t < _break; t += dt) {
error = states();
if(error){fprintf(stderr,"at line 64 in file KA_i1.mod:\n SOLVE states METHOD cnexp\n"); nrn_complain(_p); abort_run(error);}
}}
t = _save;
} }}
}
示例11: nrn_init
static void nrn_init(_NrnThread* _nt, _Memb_list* _ml, int _type){
Node *_nd; double _v; int* _ni; int _iml, _cntml;
#if CACHEVEC
_ni = _ml->_nodeindices;
#endif
_cntml = _ml->_nodecount;
for (_iml = 0; _iml < _cntml; ++_iml) {
_p = _ml->_data[_iml]; _ppvar = _ml->_pdata[_iml];
#if CACHEVEC
if (use_cachevec) {
_v = VEC_V(_ni[_iml]);
}else
#endif
{
_nd = _ml->_nodelist[_iml];
_v = NODEV(_nd);
}
v = _v;
cai = _ion_cai;
cao = _ion_cao;
cai = _ion_cai;
ki = _ion_ki;
ko = _ion_ko;
nai = _ion_nai;
nao = _ion_nao;
initmodel();
_ion_cai = cai;
nrn_wrote_conc(_ca_sym, (&(_ion_cai)) - 1, _style_ca);
}}
示例12: nrn_init
static void nrn_init(_NrnThread* _nt, _Memb_list* _ml, int _type){
double* _p; Datum* _ppvar; Datum* _thread;
Node *_nd; double _v; int* _ni; int _iml, _cntml;
#if CACHEVEC
_ni = _ml->_nodeindices;
#endif
_cntml = _ml->_nodecount;
_thread = _ml->_thread;
for (_iml = 0; _iml < _cntml; ++_iml) {
_p = _ml->_data[_iml]; _ppvar = _ml->_pdata[_iml];
#if 0
_check_rates(_p, _ppvar, _thread, _nt);
#endif
#if CACHEVEC
if (use_cachevec) {
_v = VEC_V(_ni[_iml]);
}else
#endif
{
_nd = _ml->_nodelist[_iml];
_v = NODEV(_nd);
}
v = _v;
ena = _ion_ena;
initmodel(_p, _ppvar, _thread, _nt);
}}
示例13: nrn_init
static void nrn_init(_NrnThread* _nt, _Memb_list* _ml, int _type){
double* _p; Datum* _ppvar; Datum* _thread;
Node *_nd; double _v; int* _ni; int _iml, _cntml;
#if CACHEVEC
_ni = _ml->_nodeindices;
#endif
_cntml = _ml->_nodecount;
_thread = _ml->_thread;
for (_iml = 0; _iml < _cntml; ++_iml) {
_p = _ml->_data[_iml]; _ppvar = _ml->_pdata[_iml];
#if CACHEVEC
if (use_cachevec) {
_v = VEC_V(_ni[_iml]);
}else
#endif
{
_nd = _ml->_nodelist[_iml];
_v = NODEV(_nd);
}
v = _v;
iCa = _ion_iCa;
Cai = _ion_Cai;
Cai = _ion_Cai;
initmodel(_p, _ppvar, _thread, _nt);
_ion_Cai = Cai;
nrn_wrote_conc(_Ca_sym, (&(_ion_Cai)) - 1, _style_Ca);
}}
示例14: CTD
void Cvode::nocap_v(NrnThread* _nt){
int i;
CvodeThreadData& z = CTD(_nt->id);
for (i = 0; i < z.no_cap_count_; ++i) { // initialize storage
Node* nd = z.no_cap_node_[i];
NODED(nd) = 0;
NODERHS(nd) = 0;
}
// compute the i(vmold) and di/dv
rhs_memb(z.no_cap_memb_, _nt);
lhs_memb(z.no_cap_memb_, _nt);
for (i = 0; i < z.no_cap_count_; ++i) {// parent axial current
Node* nd = z.no_cap_node_[i];
// following from global v_parent
NODERHS(nd) += NODED(nd) * NODEV(nd);
Node* pnd = _nt->_v_parent[nd->v_node_index];
if (pnd) {
NODERHS(nd) -= NODEB(nd) * NODEV(pnd);
NODED(nd) -= NODEB(nd);
}
}
for (i = 0; i < z.no_cap_child_count_; ++i) {// child axial current
Node* nd = z.no_cap_child_[i];
// following from global v_parent
Node* pnd = _nt->_v_parent[nd->v_node_index];
NODERHS(pnd) -= NODEA(nd) * NODEV(nd);
NODED(pnd) -= NODEA(nd);
}
#if PARANEURON
if (nrn_multisplit_solve_) { // add up the multisplit equations
nrn_multisplit_nocap_v();
}
#endif
for (i = 0; i < z.no_cap_count_; ++i) {
Node* nd = z.no_cap_node_[i];
NODEV(nd) = NODERHS(nd) / NODED(nd);
// printf("%d %d %g v=%g\n", nrnmpi_myid, i, _nt->_t, NODEV(nd));
}
// no_cap v's are now consistent with adjacent v's
}
示例15: CTD
void Cvode::rhs(NrnThread* _nt) {
int i;
CvodeThreadData& z = CTD(_nt->id);
if (diam_changed) {
recalc_diam();
}
if (z.v_node_count_ == 0) { return; }
for (i = 0; i < z.v_node_count_; ++i) {
NODERHS(z.v_node_[i]) = 0.;
}
if (_nt->_nrn_fast_imem) {
double* p = _nt->_nrn_fast_imem->_nrn_sav_rhs;
for (i = 0; i < z.v_node_count_; ++i) {
Node* nd = z.v_node_[i];
p[nd->v_node_index] = 0;
}
}
rhs_memb(z.cv_memb_list_, _nt);
nrn_nonvint_block_current(_nt->end, _nt->_actual_rhs, _nt->id);
if (_nt->_nrn_fast_imem) {
double* p = _nt->_nrn_fast_imem->_nrn_sav_rhs;
for (i = 0; i < z.v_node_count_; ++i) {
Node* nd = z.v_node_[i];
p[nd->v_node_index] -= NODERHS(nd);
}
}
/* at this point d contains all the membrane conductances */
/* now the internal axial currents.
rhs += ai_j*(vi_j - vi)
*/
for (i = z.rootnodecount_; i < z.v_node_count_; ++i) {
Node* nd = z.v_node_[i];
Node* pnd = z.v_parent_[i];
double dv = NODEV(pnd) - NODEV(nd);
/* our connection coefficients are negative so */
NODERHS(nd) -= NODEB(nd)*dv;
NODERHS(pnd) += NODEA(nd)*dv;
}
}