Go to the documentation of this file.
122 std::vector<double>
td;
139 for (std::size_t type = 0; type < n_memb_func; ++type) {
143 for (
int psz = 0; psz < dparam_size; ++psz) {
162 for (
size_t i = 0;
i < ncte->
type.size(); ++
i) {
163 switch (ncte->
type[
i]) {
169 int ncindex = ncte->
intdata[idat++];
171 #ifndef CORENRN_DEBUG_QUEUE
172 #define CORENRN_DEBUG_QUEUE 0
174 #if CORENRN_DEBUG_QUEUE
175 printf(
"nrn2core_tqueue tid=%d i=%zd type=%d tdeliver=%g NetCon %d\n",
191 int target_type = ncte->
intdata[idat++];
192 int target_instance = ncte->
intdata[idat++];
197 assert(pnt->
_type == target_type);
200 target_instance = ml->
_permute[target_instance];
203 assert(pnt->
_tid == tid);
206 int netcon_index = ncte->
intdata[idat++];
207 int weight_index = -1;
208 if (netcon_index >= 0) {
212 double flag = ncte->
dbldata[idbldat++];
213 int is_movable = ncte->
intdata[idat++];
224 void** movable_arg = nt.
_vdata + ml->
pdata[movable_index];
226 #if CORENRN_DEBUG_QUEUE
227 printf(
"nrn2core_tqueue tid=%d i=%zd type=%d tdeliver=%g SelfEvent\n",
233 " target_type=%d pnt data index=%d flag=%g is_movable=%d netcon index "
241 net_send(movable_arg, weight_index, pnt, ncte->
td[
i], flag);
243 *movable_arg = (
void*) old_movable_arg;
248 int type = ncte->
intdata[idat++];
250 int ps_index = ncte->
intdata[idat++];
251 #if CORENRN_DEBUG_QUEUE
252 printf(
"nrn2core_tqueue tid=%d i=%zd type=%d tdeliver=%g PreSyn %d\n",
266 int gid = ncte->
intdata[idat++];
277 #if CORENRN_DEBUG_QUEUE
278 printf(
"nrn2core_tqueue tid=%d i=%zd type=%d tdeliver=%g NetParEvent\n",
287 std::stringstream qetype;
288 qetype << ncte->
type[
i];
290 qetype.str().c_str());
308 for (
int i = 0;
i < dparam_size; ++
i) {
309 if (semantics[
i] == -8) {
334 int type = tml->index;
345 for (
int iml = 0; iml <
nodecount; ++iml) {
346 for (
int i = first;
i <= last; ++
i) {
365 assert(pnt->
_type == pnttype);
371 assert(pnt->
_tid == tid);
408 ThreadDatum* _thread,
430 double* _p = ml->
data;
434 _ppvar += _iml * psz;
442 (*nrn2core_patternstim_)(info);
static void setup_type2semantics()
auto & get_mech_data_layout()
int nrn_get_mechtype(const char *name)
Get mechanism type by the mechanism name.
static std::unordered_map< int, int > type2movable
static void watch_activate_clear()
void(* nrn2core_transfer_watch_)(void(*cb)(int, int, int, int, int))
Pointer to function in NEURON that iterates over activated WATCH statements, sending each item to ....
static void nrn2core_tqueue()
Copy each thread's queue from NEURON.
void dt2thread(double adt)
auto & get_memb_func(size_t idx)
virtual void send(double sendtime, NetCvode *, NrnThread *) override
void nrn2core_PreSyn_flag_receive(int tid)
union coreneuron::NetCon::@0 u
void hoc_execerror(const char *s1, const char *s2)
std::size_t ubound_index_
void direct_mode_initialize()
All state from NEURON necessary to continue a run.
std::vector< int > _pnt_offset
THIS FILE IS AUTO GENERATED DONT MODIFY IT.
static void nrn2core_transfer_watch_condition(int, int, int, int, int)
#define VecPlayContinuousType
auto & get_prop_dparam_size()
virtual void send(double sendtime, NetCvode *, NrnThread *) override
std::map< int, InputPreSyn * > gid2in
static void nrn2core_patstim_share_info()
void(* nrn2core_patternstim_)(void **info)
int nrn_i_layout(int icnt, int cnt, int isz, int sz, int layout)
This function return the index in a flat array of a matrix coordinate (icnt, isz).
virtual void send(double deliverytime, NetCvode *, NrnThread *)
void net_send(void **, int, Point_process *, double, double)
void nrn_spike_exchange_init()
void ** pattern_stim_info_ref(int icnt, int cnt, double *_p, Datum *_ppvar, ThreadDatum *_thread, NrnThread *_nt, Memb_list *ml, double v)
std::vector< int > intdata
NetCvode * net_cvode_instance
void watch_datum_indices(int type, int &first, int &last)
return first and last datum indices of WATCH statements
auto & get_prop_param_size()
IvocVect * discon_indices_
void nrn_thread_table_check()
static void vec_play_activate()
std::vector< double > dbldata