25 int i2 = i1 + _nt->
ncell;
28 double* vec_rhs = &(
VEC_RHS(0));
29 double* vec_d = &(
VEC_D(0));
30 double* vec_a = &(
VEC_A(0));
31 double* vec_b = &(
VEC_B(0));
32 double* vec_v = &(
VEC_V(0));
38 for (
int i = i1;
i < i3; ++
i) {
47 parallel loop present(fast_imem_d [i1:i3], fast_imem_rhs [i1:i3])
if (_nt->
compute_gpu)
50 for (
int i = i1;
i < i3; ++
i) {
52 fast_imem_rhs[
i] = 0.;
58 for (
auto tml = _nt->
tml; tml; tml = tml->
next)
61 std::string ss(
"cur-");
64 (*s)(_nt, tml->ml, tml->index);
67 hoc_warning(
"errno set during calculation of currents",
nullptr);
80 for (
int i = i1;
i < i3; ++
i) {
97 for (
int i = i2;
i < i3; ++
i) {
98 double dv = vec_v[parent_index[
i]] - vec_v[
i];
102 vec_rhs[
i] -= vec_b[
i] * dv;
105 vec_rhs[parent_index[
i]] += vec_a[
i] * dv;
119 int i2 = i1 + _nt->
ncell;
123 for (
auto tml = _nt->
tml; tml; tml = tml->
next)
126 std::string ss(
"cur-");
129 (*s)(_nt, tml->ml, tml->index);
132 hoc_warning(
"errno set during calculation of jacobian", (
char*) 0);
140 if (_nt->
end && _nt->
tml) {
145 double* vec_d = &(
VEC_D(0));
146 double* vec_a = &(
VEC_A(0));
147 double* vec_b = &(
VEC_B(0));
157 for (
int i = i1;
i < i3; ++
i) {
164 vec_d [0:i3], vec_a [0:i3], vec_b [0:i3], parent_index [0:i3])
if (_nt->
compute_gpu)
167 for (
int i = i2;
i < i3; ++
i) {
170 vec_d[
i] -= vec_b[
i];
173 vec_d[parent_index[
i]] -= vec_a[
i];