Go to the documentation of this file.
34 class ProgressBar final {
41 ProgressBar(
int nsteps)
49 void update(
int step,
double time) {
56 void step(
double time) {
113 #if defined(ENABLE_BIN_REPORTS) || defined(ENABLE_SONATA_REPORTS)
129 ProgressBar progress_bar(total_sim_steps);
131 double updated_tstop = tstop -
dt;
136 double updated_tstop = tstop - .5 *
dt;
151 int step_group_n = total_sim_steps;
152 int step_group_begin = 0;
153 int step_group_end = 0;
155 ProgressBar progress_bar(step_group_n);
156 while (step_group_end < step_group_n) {
165 #if defined(ENABLE_BIN_REPORTS) || defined(ENABLE_SONATA_REPORTS)
174 step_group_begin = step_group_end;
175 progress_bar.update(step_group_end,
nrn_threads[0]._t);
182 int step_group_begin,
183 int& step_group_end) {
185 for (
int i = step_group_begin;
i < step_group_max; ++
i) {
190 step_group_end =
i + 1;
197 step_group_end = step_group_max;
202 double* vec_v = &(
VEC_V(0));
203 double* vec_rhs = &(
VEC_RHS(0));
211 for (
int i = 0;
i < i2; ++
i) {
212 vec_v[
i] += 2. * vec_rhs[
i];
218 for (
int i = 0;
i < i2; ++
i) {
219 vec_v[
i] += vec_rhs[
i];
240 for (
auto tml = _nt->
tml; tml; tml = tml->
next)
243 std::string ss(
"state-");
247 (*s)(_nt, tml->ml, tml->index);
251 hoc_warning(
"errno set during calculation of states",
nullptr);
259 for (
auto tbl = nt->
tbl[bat]; tbl; tbl = tbl->
next) {
261 int type = tbl->bam->type;
275 (*nrn2core_trajectory_values_)(-1, 0,
nullptr, 0.0);
293 int vs = tr->
vsize++;
295 assert(vs < tr->bsize);
317 double* gather_i = tr->
gather[
i];
318 static_cast<void>(gather_i);
327 (*nrn2core_trajectory_values_)(nth->
id, tr->
n_pr, tr->
vpr, nth->
_t);
340 nth->
_t += .5 * nth->
_dt;
377 nth->
_t += .5 * nth->
_dt;
void nrn_calc_fast_imem(NrnThread *nt)
static void * nrn_fixed_step_thread(NrnThread *)
void nrn_spike_exchange(NrnThread *nt)
void nrncore2nrn_send_init()
void nrn_fixed_single_steps_minimal(int total_sim_steps, double tstop)
--> Coreneuron
void progressbar_finish(progressbar *bar)
Finish a progressbar, indicating 100% completion, and free it.
void dt2thread(double adt)
auto & get_memb_func(size_t idx)
void progressbar_update(progressbar *bar, unsigned long value, double t)
Increment an existing progressbar by value steps.
void nrn_ba(NrnThread *nt, int bat)
void * setup_tree_matrix_minimal(NrnThread *)
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...
Progressbar data structure (do not modify or create directly)
void nrn_solve_minimal(NrnThread *)
static void phase_begin(const char *name)
void hoc_warning(const char *s1, const char *s2)
THIS FILE IS AUTO GENERATED DONT MODIFY IT.
TrajectoryRequests * trajec_requests
void nrn_fixed_step_minimal()
NrnThreadBAList * tbl[BEFORE_AFTER_SIZE]
void update(NrnThread *_nt)
void nrn_multithread_job(F &&job, Args &&... args)
void(* nrn2core_trajectory_values_)(int tid, int n_pr, void **vpr, double t)
progressbar * progressbar_new(const char *label, unsigned long max)
Create a new progress bar with the specified label and max number of steps.
void(*)(NrnThread *, Memb_list *, int) mod_f_t
constexpr static int progressbar_update_steps
void nrn_flush_reports(double t)
void nrncore2nrn_send_values(NrnThread *nth)
corenrn_parameters corenrn_param
Printing method.
void deliver_net_events(NrnThread *nt)
void second_order_cur(NrnThread *_nt, int secondorder)
void nrn_fixed_step_group_minimal(int total_sim_steps)
void nrn_cur_capacitance(NrnThread *_nt, Memb_list *ml, int type)
static void nrn_fixed_step_group_thread(NrnThread *, int, int, int &)
const char * nrn_get_mechname(int type)
void nrnthread_v_transfer(NrnThread *_nt)
void nonvint(NrnThread *_nt)
void * nrn_fixed_step_lastpart(NrnThread *nth)
bool nrn_have_gaps
variables defined in coreneuron library
nrn_pragma_acc(routine vector) static void triang_interleaved2(NrnThread *nt
void nrn_thread_table_check()
#define nrn_assert(x)
assert()-like macro, independent of NDEBUG status
void nrn_deliver_events(NrnThread *nt)
static void phase_end(const char *name)
void fixed_play_continuous(NrnThread *nt)