Go to the documentation of this file.
30 #define PP2NT(pp) (nrn_threads + (pp)->_tid)
31 #define PP2t(pp) (PP2NT(pp)->_t)
49 static int nrn_errno_check(
int type) {
50 printf(
"nrn_errno_check() was called on pid %d: errno=%d type=%d\n",
nrnmpi_myid, errno, type);
70 }
else if (sendtype == 2) {
91 sprintf(buf,
"net_send td-t = %g", td - nt->
_t);
97 if (flag == 1.0 &&
v >= nt->
_vdata) {
114 sprintf(buf,
"net_event time-t = %g", time - nt->
_t);
124 inter_thread_events_.reserve(1000);
134 std::lock_guard<OMP_Mutex> lock(
mut);
143 std::lock_guard<OMP_Mutex> lock(
mut);
151 eps_ = 100. * DBL_EPSILON;
194 for (
int i = 0;
i < n; ++
i)
195 p[
i].unreffed_event_cnt_ = 0;
202 db->
pr(
"binq send", td,
this);
209 db->
pr(
"send", td,
this);
219 db->
pr(
"send", td,
this);
249 for (
int ipre = 0; ipre < nt->
n_presyn; ++ipre) {
254 for (
int inetc = 0; inetc < nt->
n_netcon; ++inetc) {
264 for (
int j = 1; j <
cnt; ++j) {
284 de->
pr(
"deliver", tt,
this);
320 printf(
"NetCvode::move_event self event target %s t=%g, old=%g new=%g\n",
351 if (
value(nt) > 0.0) {
352 if (
flag_ ==
false) {
363 ns->
event(tt,
this, nt);
369 printf(
"%s DiscreteEvent %.15g\n", s, tt);
383 printf(
"NetCon::deliver nt=%d target=%d\n", nt->
id,
PP2NT(
target_)->
id);
390 std::string ss(
"net-receive-");
395 if (errno && nrn_errno_check(typ))
396 hoc_warning(
"errno set during NetCon deliver to NET_RECEIVE", (
char*) 0);
402 printf(
"%s NetCon target=%s[%d] %.15g\n",
468 call_net_receive(ns);
475 if (errno && nrn_errno_check(target_->_type))
476 hoc_warning(
"errno set during SelfEvent deliver to NET_RECEIVE", (
char*) 0);
485 printf(
" SelfEvent target=%s %.15g flag=%g\n",
pnt_name(target_), tt,
flag_);
489 int total_sim_steps =
static_cast<int>((tstop -
nrn_threads->
_t) /
dt + 1e-9);
509 static bool pscheck(
double var,
double thresh,
int* flag) {
511 if (*flag ==
false) {
530 int net_send_buf_count = 0;
547 double v = actual_v[thidx];
549 int* flag = &(psh->
flag_);
552 #ifndef CORENEURON_ENABLE_GPU
563 idx = net_send_buf_count++;
572 #ifdef CORENEURON_ENABLE_GPU
638 double tsav = nt->
_t;
639 double tm = nt->
_t + 0.5 * nt->
_dt;
653 while ((q = p[tid].tqe_->dequeue_bin()) != 0) {
668 deliver_events(tm, nt);
671 if (p[tid].tqe_->top()) {
674 p[tid].tqe_->shift_bin(tm);
683 std::string ss(
"net-buf-receive-");
686 (*net_buf_receive.first)(nt);
static bool pscheck(double var, double thresh, int *flag)
void net_event(Point_process *, double)
void nrn_multisend_send(PreSyn *, double t, NrnThread *)
TQItem * atomic_dq(double til)
void deliver_net_events(NrnThread *)
void nrn2ncs_outputevent(int netcon_output_index, double firetime)
bool nrn_use_bin_queue_
Flag to use the bin queue.
void enqueue(NetCvode *, NrnThread *)
std::vector< int > spikevec_gid
TQItem * enqueue_bin(double t, DiscreteEvent *data)
virtual bool check(NrnThread *)
char * pnt_name(Point_process *pnt)
void nrn_fixed_single_steps_minimal(int total_sim_steps, double tstop)
--> Coreneuron
std::vector< NetCon * > netcon_in_presyn_order_
InputPreSyn.nc_index_ to + InputPreSyn.nc_cnt_ give the NetCon*.
void check_thresh(NrnThread *)
auto & get_memb_func(size_t idx)
int _net_send_buffer_size
std::vector< InterThreadEvent > inter_thread_events_
PreSynHelper * presyns_helper
virtual void send(double sendtime, NetCvode *, NrnThread *) override
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...
union coreneuron::NetCon::@0 u
void net_move(void **, Point_process *, double)
void hoc_execerror(const char *s1, const char *s2)
TQItem * event(double tdeliver, DiscreteEvent *, NrnThread *)
void hoc_warning(const char *s1, const char *s2)
void call_net_receive(NetCvode *)
void interthread_send(double, DiscreteEvent *, NrnThread *)
If the PreSyn is on a different thread than the target, we have to lock the buffer.
void ncs2nrn_integrate(double tstop)
THIS FILE IS AUTO GENERATED DONT MODIFY IT.
TQItem * insert(double t, DiscreteEvent *data)
virtual double value(NrnThread *)
void update(NrnThread *_nt)
void shift_bin(double _t_)
virtual void send(double sendtime, NetCvode *, NrnThread *) override
std::vector< double > spikevec_time
--> Coreneuron as SpikeBuffer class
TQItem * bin_event(double tdeliver, DiscreteEvent *, NrnThread *)
virtual void deliver(double, NetCvode *, NrnThread *) override
auto & get_pnt_receive_init()
virtual double value(NrnThread *) override
virtual void deliver(double, NetCvode *ns, NrnThread *) override
virtual void send(double deliverytime, NetCvode *, NrnThread *)
void net_send(void **, int, Point_process *, double, double)
virtual int type() const override
auto & get_net_buf_receive()
void update_net_receive_buffer(NrnThread *nt)
void nrn_fixed_step_group_minimal(int total_sim_steps)
void move(TQItem *, double tnew)
void deliver_events(double til, NrnThread *)
void artcell_net_move(void **, Point_process *, double)
virtual void deliver(double, NetCvode *, NrnThread *) override
const char * nrn_get_mechname(int type)
void interthread_enqueue(NrnThread *nt)
NetCvode * net_cvode_instance
virtual void pr(const char *, double t, NetCvode *) override
void nrn_multisend_advance()
void nrn_outputevent(unsigned char, double)
bool deliver_event(double til, NrnThread *)
void * erealloc(void *ptr, size_t size)
virtual void pr(const char *, double t, NetCvode *)
bool nrn_have_gaps
variables defined in coreneuron library
virtual ~NetCvodeThreadData()
void artcell_net_send(void **, int, Point_process *, double, double)
nrn_pragma_acc(routine vector) static void triang_interleaved2(NrnThread *nt
void net_sem_from_gpu(int sendtype, int i_vdata, int, int ith, int ipnt, double, double)
virtual void pr(const char *, double t, NetCvode *) override
auto & get_pnttype2presyn()
#define nrn_assert(x)
assert()-like macro, independent of NDEBUG status
void move_event(TQItem *, double, NrnThread *)
auto & get_pnt_receive_size()
virtual void deliver(double t, NetCvode *, NrnThread *)