Go to the documentation of this file.
56 return CORENEURON_USE_LEGACY_UNITS;
71 if (!getenv(
"OMP_NUM_THREADS")) {
72 omp_set_num_threads(nthread);
81 char*
prepare_args(
int& argc,
char**& argv,
int use_mpi,
const char* mpi_lib,
const char* arg) {
83 std::string args(arg);
84 args.insert(0,
" coreneuron ");
85 args.append(
" --skip-mpi-finalize ");
87 args.append(
" --mpi ");
91 std::string corenrn_mpi_lib{mpi_lib};
92 if (!corenrn_mpi_lib.empty()) {
93 args.append(
" --mpi-lib ");
94 corenrn_mpi_lib +=
" ";
95 args.append(corenrn_mpi_lib);
99 char* first = strdup(args.c_str());
100 const char* sep =
" ";
103 char* token = strtok(first, sep);
106 token = strtok(
nullptr, sep);
112 argv =
new char*[argc];
113 first = strdup(args.c_str());
114 token = strtok(first, sep);
115 for (
int i = 0; token;
i++) {
117 token = strtok(
nullptr, sep);
144 (*nrn2core_get_trajectory_requests_)(
145 tid, bsize, n_pr, vpr, n_trajec, types, indices, pvars, varrays);
155 tr->
gather =
new double*[n_trajec];
158 for (
int i = 0;
i < n_trajec; ++
i) {
171 bool is_mapping_needed,
172 bool run_setup_cleanup) {
173 #if defined(NRN_FEEXCEPT)
174 nrn_feenableexcept();
192 #if CORENEURON_ENABLE_GPU
195 "compiled with CORENEURON_ENABLE_GPU does not allow the combination of "
196 "--cell-permute=2 and "
202 "compiled with OpenACC/CUDA does not allow the combination of --cuda-interface and "
228 }
else if (
dt == -1000.) {
238 }
else if (
celsius == -1000.) {
265 " WARNING : GPU execution requires --cell-permute type 1 or 2. Setting it to 1.\n");
305 std::cout <<
" Start time (t) = " <<
t << std::endl << std::endl;
333 (*nrn2core_part2_clean_)();
359 char prcellname[1024];
361 const char* prprefix =
"cu";
363 const char* prprefix =
"acc";
366 if (prcellgid >= 0) {
369 sprintf(prcellname,
"%s_gpu_init", prprefix);
371 sprintf(prcellname,
"%s_gpu_t%f", prprefix,
t);
374 strcpy(prcellname,
"cpu_init");
376 sprintf(prcellname,
"cpu_t%f",
t);
388 dt = forwardskip * 0.1;
392 for (
int step = 0; step < 10; ++step) {
396 if (prcellgid >= 0) {
427 std::unique_ptr<ReportHandler> report_handler;
428 if (config.
format ==
"Bin") {
429 report_handler = std::make_unique<BinaryReportHandler>();
430 }
else if (config.
format ==
"SONATA") {
431 report_handler = std::make_unique<SonataReportHandler>(spikes_info);
434 printf(
" WARNING : Report name '%s' has unknown format: '%s'.\n",
440 return report_handler;
453 #if NRNMPI && defined(CORENEURON_ENABLE_MPI_DYNAMIC)
454 static void* load_dynamic_mpi(
const std::string& libname) {
456 void* handle = dlopen(libname.c_str(), RTLD_NOW | RTLD_GLOBAL);
457 const char* error = dlerror();
459 std::string err_msg = std::string(
"Could not open dynamic MPI library: ") + error +
"\n";
460 throw std::runtime_error(err_msg);
475 #ifdef CORENEURON_ENABLE_MPI_DYNAMIC
480 throw std::runtime_error(
481 "For dynamic MPI support you must pass '--mpi-lib "
482 "/path/libcorenrnmpi_<name>.<suffix>` argument!\n");
487 static bool mpi_lib_loaded =
false;
488 if (!mpi_lib_loaded) {
491 mpi_lib_loaded =
true;
500 #ifdef CORENEURON_ENABLE_GPU
523 std::vector<ReportConfiguration> configs;
524 std::vector<std::unique_ptr<ReportHandler>> report_handlers;
526 bool reports_needs_finalize =
false;
541 reports_needs_finalize = !configs.empty();
573 printf(
"Error: Stop time (%lf) < Start time (%lf), restoring from checkpoint? \n",
591 double min_report_dt = INT_MAX;
592 for (
size_t i = 0;
i < configs.size();
i++) {
595 if (report_handler) {
597 report_handlers.push_back(std::move(report_handler));
599 if (configs[
i].report_dt < min_report_dt) {
600 min_report_dt = configs[
i].report_dt;
609 if (!configs.empty()) {
665 (*nrn2core_all_weights_return_)(
weights);
676 if (reports_needs_finalize) {
void report_cell_stats()
Reports global cell statistics of the simulation.
std::string outpath
Directory path where .dat files.
void handle_forward_skip(double forwardskip, int prcellgid)
void delete_trajectory_requests(NrnThread &nt)
bool skip_mpi_finalize
Enable MPI flag.
std::string datpath
Apply patternstim using the specified spike file.
mpi_manager_t & mpi_manager()
unsigned ms_phases
Gid of cell for prcellstate.
void setup_nrnthreads_on_device(NrnThread *threads, int nthreads)
unsigned nwarp
Cell interleaving permutation.
double celsius
I/O timestep to use in msec for reports.
char * prepare_args(int &argc, char **&argv, int use_mpi, const char *mpi_lib, const char *arg)
Convert char* containing arguments from neuron to char* argv[] for coreneuron command line argument p...
bool nrn_use_bin_queue_
Flag to use the bin queue.
unsigned cell_interleave_permute
Spike Compression.
std::string writeParametersFilepath
Enable checkpoint and specify directory to store related files.
void parse(int argc, char *argv[])
Destructor defined in .cpp where CLI11 types are complete.
void delete_nrnthreads_on_device(NrnThread *threads, int nthreads)
Cleanup device memory that is being tracked by the OpenACC runtime.
mpi_function< cnrn_make_integral_constant_t(nrnmpi_finalize_impl)> nrnmpi_finalize
mpi_function< cnrn_make_integral_constant_t(nrnmpi_barrier_impl)> nrnmpi_barrier
void dt2thread(double adt)
static constexpr int report_buff_size_default
static void stop_profile()
void resolve_symbols(void *dlsym_handle)
void update_nrnthreads_on_host(NrnThread *threads, int nthreads)
void copy_gap_indices_to_device()
bool threading
Use Multisend spike exchange instead of Allgather.
static void start_profile()
void nrnran123_destroy_global_state_on_device()
void BBS_netpar_solve(double tstop)
void set_openmp_threads(int nthread)
If "export OMP_NUM_THREADS=n" is not set then omp by default sets the number of threads equal to the ...
int prcellgid
Internal buffer used on every rank for spikes.
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...
void cnrn_target_delete(std::string_view file, int line, T *h_ptr, std::size_t len=1)
Function declarations for the cell statistics.
void call_prcellstate_for_prcellgid(int prcellgid, int compute_gpu, int is_init)
double * stdindex2ptr(int mtype, int index, NrnThread &nt)
void reset()
Runs the CLI11_PARSE macro.
static void phase_begin(const char *name)
unsigned report_buff_size
Number of gpus to use per node.
bool gpu
Enable pthread/openmp.
int interleave_permute_type
static void trajectory_return()
void update_weights_from_gpu(NrnThread *threads, int nthreads)
Copy weights from GPU to CPU.
void direct_mode_initialize()
All state from NEURON necessary to continue a run.
int nrn_set_timeout(int timeout)
double restore_time() const
todo : need to broadcast this rather than all reading a double
void nrn_set_extra_thread0_vdata()
bool binqueue
Enable CUDA interface (default is the OpenACC interface). Branch of the code is executed through CUDA...
THIS FILE IS AUTO GENERATED DONT MODIFY IT.
double voltage
Temperature in degC.
TrajectoryRequests * trajec_requests
void nrn_fixed_step_minimal()
double forwardskip
Initial voltage used for nrn_finitialize(1, v_init).
std::string reportfilepath
Restore simulation from provided checkpoint directory.
mpi_function< cnrn_make_integral_constant_t(nrnmpi_check_threading_support_impl)> nrnmpi_check_threading_support
void core2nrn_data_return()
copy data back to NEURON.
int mkdir_p(const char *path)
Creates directory if doesn't exisit (similar to mkdir -p)
std::string patternstim
Maximum integration interval (likely reduced by minimum NetCon delay).
void nrn_setup(const char *filesdat, bool is_mapping_needed, CheckPoints &checkPoints, bool run_setup_cleanup, const char *datpath, const char *restore_path, double *mindelay)
double tstop
Verbosity-level.
T * cnrn_target_copyin(std::string_view file, int line, const T *h_ptr, std::size_t len=1)
void update(NrnThread *_nt)
void setup_report_engine(double dt_report, double mindelay)
in the current implementation, we call flush during every spike exchange interval.
void mk_mech_init(int argc, char **argv)
initialize standard mechanisms from coreneuron
void clear_spike_vectors()
int nrnmpi_spike_compress(int nspike, bool gid_compress, int xchng_meth)
std::string filesdat
Directory where spikes will be written.
std::vector< ReportConfiguration > create_report_configurations(const std::string &filename, const std::string &output_dir, SpikesInfo &spikes_info)
void set_report_buffer_size(int n)
std::string restorepath
Name of file containing list of gids dat files read in.
const char * bbcore_write_version
void nrn_init_and_load_data(int argc, char *argv[], CheckPoints &checkPoints, bool is_mapping_needed, bool run_setup_cleanup)
bool cuda_interface
Enable GPU computation.
corenrn_parameters corenrn_param
Printing method.
void get_nrn_trajectory_requests(int bsize)
bool multisend
Skip MPI finalization.
std::string get_restore_path() const
int run_solve_core(int argc, char **argv)
std::string checkpointpath
Reports configuration file.
void(* nrn2core_part2_clean_)()
void(* nrn2core_trajectory_return_)(int tid, int n_pr, int bsize, int vecsz, void **vpr, double t)
void allocate_data_in_mechanism_nrn_init()
void nrnran123_initialise_global_state_on_device()
int prcellstate(int gid, const char *suffix)
int seed
Size in MB of the report buffer.
mpi_function< cnrn_make_integral_constant_t(nrnmpi_init_impl)> nrnmpi_init
void nrn_mkPatternStim(const char *fname, double tstop)
unsigned spkcompress
Number of multisend interval. 1 or 2.
bool use_solve_interleave
bool corenrn_embedded
--> Coreneuron
static std::string to_string()
return version string (version + git id) as a string
bool mpi_enable
Initialization seed for random number generator (int)
double dt
Stop time of simulation in msec.
void set_globals(const char *path, bool cli_global_seed, int cli_global_seed_value)
virtual void create_report(ReportConfiguration &config, double dt, double tstop, double delay)
bool nrn_have_gaps
variables defined in coreneuron library
std::string config_to_str(bool default_also=false, bool write_description=false) const
Return a string summarising the current parameter values.
Function prototypes for the functions providing information about simulator memory usage.
void output_spikes(const char *outpath, const SpikesInfo &spikes_info)
unsigned ms_subint
Number of multisend phases, 1 or 2.
std::string mpi_lib
Write parameters to this file.
nrn_pragma_acc(routine vector) static void triang_interleaved2(NrnThread *nt
void(* nrn2core_all_weights_return_)(std::vector< double * > &weights)
void(* nrn2core_get_trajectory_requests_)(int tid, int &bsize, int &n_pr, void **&vpr, int &n_trajec, int *&types, int *&indices, double **&pvars, double **&varrays)
std::unique_ptr< ReportHandler > create_report_handler(const ReportConfiguration &config, const SpikesInfo &spikes_info)
void mk_spikevec_buffer(int sz)
bool corenrn_units_use_legacy()
static void phase_end(const char *name)
const char * corenrn_version()
std::string cnrn_version()
void delete_gap_indices_from_device()
void report_mem_usage(const char *message, bool all_ranks)
Reports current memory usage of the simulator to stdout.
void nrn_finitialize(int setv, double v)
double mindelay
Forward skip to TIME.