Go to the documentation of this file.
20 #define _STRIDE _cntml_padded + _iml
44 static int na_ion, k_ion, ca_ion;
55 #define global_conci(type) nrn_ion_global_map[type][0]
56 #define global_conco(type) nrn_ion_global_map[type][1]
57 #define global_charge(type) nrn_ion_global_map[type][2]
59 double nrn_ion_charge(
int type) {
63 void ion_reg(
const char* name,
double valence) {
65 #define VAL_SENTINAL -10000.
67 sprintf(buf[0],
"%s_ion", name);
68 sprintf(buf[1],
"e%s", name);
69 sprintf(buf[2],
"%si", name);
70 sprintf(buf[3],
"%so", name);
71 sprintf(buf[5],
"i%s", name);
72 sprintf(buf[6],
"di%s_dv_", name);
73 for (
int i = 0;
i < 7;
i++) {
83 int size = mechtype + 1;
114 std::string
const old_buf_0{buf[0]};
115 sprintf(buf[0],
"%si0_%s", name, old_buf_0.c_str());
117 sprintf(buf[1],
"%so0_%s", name, buf[0]);
118 if (strcmp(
"na", name) == 0) {
123 }
else if (strcmp(
"k", name) == 0) {
128 }
else if (strcmp(
"ca", name) == 0) {
142 "%s ion valence defined differently in\n\
143 two USEION statements (%g and %g)\n",
150 "%s ion valence must be defined in\n\
151 the USEION statement of any model using this ion\n",
160 #define erev pd[0 * _STRIDE]
161 #define conci pd[1 * _STRIDE]
162 #define conco pd[2 * _STRIDE]
163 #define cur pd[3 * _STRIDE]
164 #define dcurdv pd[4 * _STRIDE]
181 #define iontype ppd[_iml]
192 #define charge global_charge(type)
193 #define conci0 global_conci(type)
194 #define conco0 global_conco(type)
196 double nrn_nernst_coef(
int type) {
202 void nrn_cur_ion(NrnThread* nt, Memb_list* ml,
int type) {
203 int _cntml_actual = ml->nodecount;
208 int _cntml_padded = ml->_nodecount_padded;
213 ppd[0:_cntml_actual],
217 async(nt->stream_id))
219 nrn_pragma_omp(target teams distribute parallel
for simd
if(nt->compute_gpu))
220 for (
int _iml = 0; _iml < _cntml_actual; ++_iml) {
223 if (iontype & 0100) {
232 void nrn_init_ion(NrnThread* nt, Memb_list* ml,
int type) {
233 int _cntml_actual = ml->nodecount;
244 int _cntml_padded = ml->_nodecount_padded;
253 ppd[0:_cntml_actual],
256 if (nt->compute_gpu))
258 nrn_pragma_omp(target teams distribute parallel
for simd
if(nt->compute_gpu))
259 for (
int _iml = 0; _iml < _cntml_actual; ++_iml) {
278 double* _vec_rhs = _nt->_actual_rhs;
281 for (NrnThreadMembList* tml = _nt->tml; tml; tml = tml->next)
283 Memb_list* ml = tml->ml;
284 int _cntml_actual = ml->nodecount;
285 int* ni = ml->nodeindices;
286 _cntml_padded = ml->_nodecount_padded;
289 ni [0:_cntml_actual],
290 _vec_rhs [0:_nt->end])
if (_nt->compute_gpu)
291 async(_nt->stream_id))
292 nrn_pragma_omp(target teams distribute parallel
for simd
if(_nt->compute_gpu))
293 for (
int _iml = 0; _iml < _cntml_actual; ++_iml) {
294 cur += dcurdv * (_vec_rhs[ni[_iml]]);
int nrn_get_mechtype(const char *name)
Get mechanism type by the mechanism name.
void nrn_cur_ion(NrnThread *_nt, Memb_list *ml, int type)
constexpr double nrn_nernst(double ci, double co, double z, double celsius)
const int ion_global_map_member_size
void nrn_init_ion(NrnThread *, Memb_list *, int)
#define global_conci(type)
void ion_reg(const char *, double)
#define global_conco(type)
nrn_pragma_acc(routine seq) nrn_pragma_omp(declare target) philox4x32_ctr_t coreneuron_random123_philox4x32_helper(coreneuron nrn_pragma_omp(end declare target) namespace coreneuron
Provide a helper function in global namespace that is declared target for OpenMP offloading to functi...
int register_mech(const char **m, mod_alloc_t alloc, mod_f_t cur, mod_f_t jacob, mod_f_t stat, mod_f_t initialize, mod_f_t private_constructor, mod_f_t private_destructor, int nrnpointerindex, int vectorized)
static const char * mechanism[]
THIS FILE IS AUTO GENERATED DONT MODIFY IT.
void _nrn_layout_reg(int, int)
double ** nrn_ion_global_map
int nrn_ion_global_map_size
void nrn_writes_conc(int, int)
void second_order_cur(NrnThread *_nt, int secondorder)
#define global_charge(type)
void hoc_register_dparam_semantics(int type, int, const char *name)
static void * emalloc(size_t size)
constexpr double ktf(double celsius)
void * erealloc(void *ptr, size_t size)
void nrn_alloc_ion(double *data, Datum *pdata, int type)
nrn_pragma_acc(routine vector) static void triang_interleaved2(NrnThread *nt
void hoc_register_prop_size(int, int, int)