INFO: No output directory specified (--dir) INFO: Using directory: "Vout_test_20251212_075159" INFO: Regenerating c-file: Vout_test.c WARNING: Full-path code-generator "/u/data/pkwi/McStas/mcstas/3.x-dev/bin/mcstas-antlr -I$MCSTAS" not found!! WARNING: Attempting replacement by "mcstas-antlr -I$MCSTAS" DEBUG: CMD: mcstas-antlr -I$MCSTAS -t -o ./Vout_test.c Vout_test.instr 2025-12-12 07:52:16.180 | DEBUG | mccode_antlr.translators.c:sort_include_hierarchy:41 - sort includes :Virtual_output(0):monitor_nd-lib 2025-12-12 07:52:16.180 | DEBUG | mccode_antlr.translators.c:sort_include_hierarchy:66 - sorted to monitor_nd-lib No initialization present? ----------------------------------------------------------- Generating single GPU kernel or single CPU section layout: ----------------------------------------------------------- Generating GPU/CPU -DFUNNEL layout: -> GPU kernel from component Origin -> GPU kernel from component Src Component Vout is NOACC, CPUONLY=True ->FUNNEL mode enabled, SPLIT within buffer. ----------------------------------------------------------- CFLAGS= -DFUNNEL DEBUG: CMD: mcstas-antlr -I$MCSTAS finished INFO: Recompiling: ./Vout_test.out DEBUG: CMD: nvc -o ./Vout_test.out ./Vout_test.c -lm -Wl,-O2 -Wl,--sort-common -Wl,--as-needed -Wl,-z,relro -Wl,-z,now -Wl,--disable-new-dtags -Wl,--gc-sections -Wl,--allow-shlib-undefined -Wl,-rpath,/u/data/pkwi/McStas/mcstas/3.x-dev/miniconda3/lib -Wl,-rpath-link,/u/data/pkwi/McStas/mcstas/3.x-dev/miniconda3/lib -L/u/data/pkwi/McStas/mcstas/3.x-dev/miniconda3/lib -mtune=haswell -fPIC -O2 -isystem /u/data/pkwi/McStas/mcstas/3.x-dev/miniconda3/include -DUSE_MPI -lmpi -Wl,-rpath,/opt/nvidia/hpc_sdk/Linux_x86_64/25.9/comm_libs/12.9/openmpi4/openmpi-4.1.5/lib -L,/opt/nvidia/hpc_sdk/Linux_x86_64/25.9/comm_libs/12.9/openmpi4/openmpi-4.1.5/lib -I/opt/nvidia/hpc_sdk/Linux_x86_64/25.9/comm_libs/12.9/openmpi4/openmpi-4.1.5/include -fast -Minfo=accel -acc=gpu -gpu=mem:managed -DOPENACC -DFUNNEL "./Vout_test.c", line 93: warning: Routine "mcgenstate" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_particle mcgenstate(void); ^ Remark: individual warnings can be suppressed with "--diag_suppress " "./Vout_test.c", line 95: warning: Routine "mcsetstate" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_particle mcsetstate(double x, double y, double z, double vx, double vy, double vz, double t, double sx, double sy, double sz, double p, int mcgravitation, void * mcMagnet, int allow_backprop); ^ "./Vout_test.c", line 97: warning: Routine "mcgetstate" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_particle mcgetstate(_class_particle mcparticle, double * x, double * y, double * z, double * vx, double * vy, double * vz, double * t, double * sx, double * sy, double * sz, double * p); ^ "./Vout_test.c", line 111: warning: Routine "particle_getvar" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double particle_getvar(_class_particle *p, char *name, int *suc); ^ "./Vout_test.c", line 115: warning: Routine "str_comp" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int str_comp(char *str1, char *str2); ^ "./Vout_test.c", line 143: warning: Routine "particle_getvar_void" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] void* particle_getvar_void(_class_particle *p, char *name, int *suc); ^ "./Vout_test.c", line 115: warning: Routine "str_comp" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int str_comp(char *str1, char *str2); ^ "./Vout_test.c", line 175: warning: Routine "particle_setvar_void" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int particle_setvar_void(_class_particle *, char *, void*); ^ "./Vout_test.c", line 200: warning: Routine "particle_setvar_void_array" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int particle_setvar_void_array(_class_particle *, char *, void*, int); ^ "./Vout_test.c", line 213: warning: Routine "particle_restore" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] void particle_restore(_class_particle *p, _class_particle *p0); ^ "./Vout_test.c", line 230: warning: Routine "particle_getuservar_byid" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double particle_getuservar_byid(_class_particle *p, int id, int *suc){ ^ "./Vout_test.c", line 241: warning: Routine "particle_uservar_init" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] void particle_uservar_init(_class_particle *p){ ^ "./Vout_test.c", line 308: warning: Routine "noprintf" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int noprintf(); ^ "./Vout_test.c", line 310: warning: Routine "str_len" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] size_t str_len(const char *s); ^ "./Vout_test.c", line 661: warning: Routine "mcget_ncount" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] unsigned long long int mcget_ncount(void); /* wrapper to set mcncount */ ^ "./Vout_test.c", line 882: warning: Routine "_randnorm2" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _randnorm2(randstate_t* state); ^ "./Vout_test.c", line 899: warning: Routine "kiss_srandom" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] uint64_t *kiss_srandom(uint64_t state[7], uint64_t seed); ^ "./Vout_test.c", line 901: warning: Routine "kiss_random" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] uint64_t kiss_random(uint64_t state[7]); ^ "./Vout_test.c", line 909: warning: Routine "_rand01" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _rand01(randstate_t* state); ^ "./Vout_test.c", line 911: warning: Routine "_randpm1" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _randpm1(randstate_t* state); ^ "./Vout_test.c", line 913: warning: Routine "_rand0max" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _rand0max(double max, randstate_t* state); ^ "./Vout_test.c", line 915: warning: Routine "_randminmax" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _randminmax(double min, double max, randstate_t* state); ^ "./Vout_test.c", line 917: warning: Routine "_randtriangle" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _randtriangle(randstate_t* state); ^ "./Vout_test.c", line 1013: warning: Routine "coords_set" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_set(MCNUM x, MCNUM y, MCNUM z); ^ "./Vout_test.c", line 1015: warning: Routine "coords_get" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_get(Coords a, MCNUM *x, MCNUM *y, MCNUM *z); ^ "./Vout_test.c", line 1017: warning: Routine "coords_add" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_add(Coords a, Coords b); ^ "./Vout_test.c", line 1019: warning: Routine "coords_sub" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_sub(Coords a, Coords b); ^ "./Vout_test.c", line 1021: warning: Routine "coords_neg" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_neg(Coords a); ^ "./Vout_test.c", line 1023: warning: Routine "coords_scale" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_scale(Coords b, double scale); ^ "./Vout_test.c", line 1025: warning: Routine "coords_sp" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double coords_sp(Coords a, Coords b); ^ "./Vout_test.c", line 1027: warning: Routine "coords_xp" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_xp(Coords b, Coords c); ^ "./Vout_test.c", line 1029: warning: Routine "coords_len" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double coords_len(Coords a); ^ "./Vout_test.c", line 4640: warning: variable "num" was declared but never referenced [declared_but_not_referenced] int num = 3; ^ "./Vout_test.c", line 5095: warning: variable "randstate" was declared but never referenced [declared_but_not_referenced] randstate_t randstate[7]; ^ "./Vout_test.c", line 5014: warning: variable "newlen" was declared but never referenced [declared_but_not_referenced] long newlen = 0; ^ "./Vout_test.c", line 6341: warning: variable "status" was set but never used [set_but_not_used] int status; ^ "./Vout_test.c", line 7141: warning: Routine "Monitor_nD_Trace" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int Monitor_nD_Trace(MonitornD_Defines_type *, MonitornD_Variables_type *, _class_particle* _particle); ^ "./Vout_test.c", line 9415: warning: variable "dt" was set but never used [set_but_not_used] double dt, dy; ^ "./Vout_test.c", line 9415: warning: variable "dy" was set but never used [set_but_not_used] double dt, dy; ^ "./Vout_test.c", line 9442: warning: variable "dx" was set but never used [set_but_not_used] double dx, dy; ^ "./Vout_test.c", line 9442: warning: variable "dy" was set but never used [set_but_not_used] double dx, dy; ^ "./Vout_test.c", line 9536: warning: variable "tc2" was set but never used [set_but_not_used] Coords tc1, tc2; ^ "./Vout_test.c", line 10044: warning: incompatible redefinition of macro "exit" (declared at line 640) [bad_macro_redef] #define exit(...) noprintf() ^ "./Vout_test.c", line 10056: warning: Routine "class_Progress_bar_trace" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_Progress_bar *class_Progress_bar_trace(_class_Progress_bar *_comp, _class_particle *_particle) { ^ "./Vout_test.c", line 10146: warning: Routine "class_Source_simple_trace" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_Source_simple *class_Source_simple_trace(_class_Source_simple *_comp, _class_particle *_particle) { ^ "./Vout_test.c", line 10249: warning: Routine "class_Virtual_output_trace" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_Virtual_output *class_Virtual_output_trace(_class_Virtual_output *_comp, _class_particle *_particle) { ^ "./Vout_test.c", line 10257: warning: variable "pp" was set but never used [set_but_not_used] double pp=0; ^ "./Vout_test.c", line 10299: warning: Routine "class_PSD_monitor_trace" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_PSD_monitor *class_PSD_monitor_trace(_class_PSD_monitor *_comp, _class_particle *_particle) { ^ "./Vout_test.c", line 11366: warning: variable "t" was declared but never referenced [declared_but_not_referenced] time_t t; ^ "./Vout_test.c", line 11367: warning: variable "ct" was set but never used [set_but_not_used] clock_t ct; ^ "./Vout_test.c", line 1517: warning: variable "mcstartdate" was set but never used [set_but_not_used] static long mcstartdate = 0; /* start simulation time */ ^ "./Vout_test.c", line 2986: warning: function "strcpy_valid" was declared but never referenced [declared_but_not_referenced] static char *strcpy_valid(char *valid, char *original) ^ mcgenstate: 104, Generating acc routine seq Generating NVIDIA GPU code particle_getvar: 118, Generating acc routine seq Generating NVIDIA GPU code particle_getvar_void: 150, Generating acc routine seq Generating NVIDIA GPU code particle_setvar_void: 177, Generating acc routine seq Generating NVIDIA GPU code particle_setvar_void_array: 202, Generating acc routine seq Generating NVIDIA GPU code particle_restore: 214, Generating acc routine seq Generating NVIDIA GPU code particle_getuservar_byid: 230, Generating acc routine seq Generating NVIDIA GPU code particle_uservar_init: 241, Generating acc routine seq Generating NVIDIA GPU code noprintf: 1565, Generating acc routine seq Generating NVIDIA GPU code str_comp: 1569, Generating acc routine seq Generating NVIDIA GPU code str_len: 1578, Generating acc routine seq Generating NVIDIA GPU code mcget_ncount: 4258, Generating acc routine seq Generating NVIDIA GPU code coords_set: 4692, Generating acc routine seq Generating NVIDIA GPU code coords_get: 4703, Generating acc routine seq Generating NVIDIA GPU code coords_add: 4712, Generating acc routine seq Generating NVIDIA GPU code coords_sub: 4724, Generating acc routine seq Generating NVIDIA GPU code coords_neg: 4736, Generating acc routine seq Generating NVIDIA GPU code coords_scale: 4746, Generating acc routine seq Generating NVIDIA GPU code coords_sp: 4756, Generating acc routine seq Generating NVIDIA GPU code coords_xp: 4764, Generating acc routine seq Generating NVIDIA GPU code coords_len: 4774, Generating acc routine seq Generating NVIDIA GPU code coords_print: 4796, Generating acc routine seq Generating NVIDIA GPU code coords_norm: 4803, Generating acc routine seq Generating NVIDIA GPU code rot_set_rotation: 4849, Generating acc routine seq Generating NVIDIA GPU code rot_test_identity: 4884, Generating acc routine seq Generating NVIDIA GPU code rot_mul: 4895, Generating acc routine seq Generating NVIDIA GPU code rot_copy: 4912, Generating acc routine seq Generating NVIDIA GPU code rot_transpose: 4923, Generating acc routine seq Generating NVIDIA GPU code rot_apply: 4939, Generating acc routine seq Generating NVIDIA GPU code vec_prod_func: 4968, Generating acc routine seq Generating NVIDIA GPU code scalar_prod: 4979, Generating acc routine seq Generating NVIDIA GPU code norm_func: 4983, Generating acc routine seq Generating NVIDIA GPU code sort_absorb_last: 5018, Generating present(particles[:buffer_len],pbuffer[:buffer_len]) Generating implicit firstprivate(tidx) Generating NVIDIA GPU code 5025, #pragma acc loop gang, vector(128) /* blockIdx.x threadIdx.x */ 5034, #pragma acc loop seq 5018, Generating implicit copy(lens[:]) [if not already present] 5025, Generating implicit firstprivate(ll,l) 5036, Accelerator restriction: induction variable live-out from loop: i 5037, Accelerator restriction: induction variable live-out from loop: i 5038, Accelerator restriction: induction variable live-out from loop: i 5039, Accelerator restriction: induction variable live-out from loop: i 5041, Accelerator restriction: induction variable live-out from loop: j 5042, Accelerator restriction: induction variable live-out from loop: j 5043, Accelerator restriction: induction variable live-out from loop: j 5044, Accelerator restriction: induction variable live-out from loop: j 5066, Generating present(pbuffer[:buffer_len]) Generating implicit firstprivate(tidx) Generating NVIDIA GPU code 5070, #pragma acc loop gang, vector(128) /* blockIdx.x threadIdx.x */ 5073, #pragma acc loop seq 5066, Generating implicit copyin(lens[:]) [if not already present] Generating implicit copy(particles[:]) [if not already present] Generating implicit copyin(los[:]) [if not already present] 5073, Generating implicit firstprivate(l) 5090, Generating present(particles[:buffer_len]) Generating implicit firstprivate(accumlen,tidx,mult) Generating NVIDIA GPU code 5094, #pragma acc loop gang, vector(128) /* blockIdx.x threadIdx.x */ 5101, #pragma acc loop seq 5090, Local memory used for targetbuffer,sourcebuffer mccoordschange: 5160, Generating acc routine seq Generating NVIDIA GPU code mccoordschange_polarisation: 5191, Generating acc routine seq Generating NVIDIA GPU code normal_vec: 5208, Generating acc routine seq Generating NVIDIA GPU code solve_2nd_order: 5307, Generating acc routine seq Generating NVIDIA GPU code _randvec_target_circle: 5391, Generating acc routine seq Generating NVIDIA GPU code _randvec_target_rect_angular: 5457, Generating acc routine seq Generating NVIDIA GPU code _randvec_target_rect_real: 5534, Generating acc routine seq Generating NVIDIA GPU code kiss_srandom: 5806, Generating acc routine seq Generating NVIDIA GPU code kiss_random: 5818, Generating acc routine seq Generating NVIDIA GPU code _hash: 5850, Generating acc routine seq Generating NVIDIA GPU code _randnorm2: 5891, Generating acc routine seq Generating NVIDIA GPU code _randtriangle: 5902, Generating acc routine seq Generating NVIDIA GPU code _rand01: 5907, Generating acc routine seq Generating NVIDIA GPU code _randpm1: 5915, Generating acc routine seq Generating NVIDIA GPU code _rand0max: 5923, Generating acc routine seq Generating NVIDIA GPU code _randminmax: 5930, Generating acc routine seq Generating NVIDIA GPU code mcsetstate: 6608, Generating acc routine seq Generating NVIDIA GPU code mcgetstate: 6648, Generating acc routine seq Generating NVIDIA GPU code inside_rectangle: 6708, Generating acc routine seq Generating NVIDIA GPU code box_intersect: 6725, Generating acc routine seq Generating NVIDIA GPU code cylinder_intersect: 6840, Generating acc routine seq Generating NVIDIA GPU code sphere_intersect: 6895, Generating acc routine seq Generating NVIDIA GPU code Monitor_nD_Trace: 8405, Generating acc routine seq Generating NVIDIA GPU code init: 10015, Generating update device(_PSD_var,_Src_var,_Origin_var,_instrument_var,_Vout_var) class_Progress_bar_trace: 10056, Generating acc routine seq Generating NVIDIA GPU code class_Source_simple_trace: 10146, Generating acc routine seq Generating NVIDIA GPU code class_Virtual_output_trace: 10249, Generating acc routine seq Generating NVIDIA GPU code class_PSD_monitor_trace: 10299, Generating acc routine seq Generating NVIDIA GPU code raytrace_all_funnel: 10603, Generating present(particles[:livebatchsize]) Generating implicit firstprivate(livebatchsize) Generating NVIDIA GPU code 10607, #pragma acc loop gang, vector(128) /* blockIdx.x threadIdx.x */ 10607, Generating implicit firstprivate(mpi_node_rank,_particle,seed,ncount) 10617, Generating present(particles[:livebatchsize]) Generating implicit firstprivate(livebatchsize) Generating NVIDIA GPU code 10622, #pragma acc loop gang, vector(128) /* blockIdx.x threadIdx.x */ 10617, Local memory used for .inl_.inl_c_1989_8562,.inl_.inl_.inl_b_1963_1995_8567,.inl_.inl_.inl_.X2253_1962_1994_8566,.inl_.inl_b_1985_8561,.inl_.inl_c_1978_8551,.inl_.inl_.inl_b_1963_1984_8556,.inl_.inl_.inl_.X2253_1962_1983_8555,.inl_.inl_b_1974_8550,.inl_.inl_.X2237_1973_8545,.inl_.inl_c_1970_8544,.inl_c_8577,.inl_.inl_b_1969_8542,.inl_.inl_.X2253_1968_8541,.inl_b_8534,.inl_.X2236_8533,.inl_.X2237_8528,.inl_c_8536,.inl_.X2235_8524,.inl_a_8520,.inl_c_8588,_particle_save,.inl_.inl_c_1978_8603,.inl_.inl_.inl_b_1963_1984_8608,.inl_.inl_.inl_.X2253_1962_1983_8607,.inl_.inl_b_1974_8602,.inl_.inl_c_1970_8596,.inl_.inl_.inl_.X2253_1962_1994_8618,.inl_.inl_.X2253_1968_8593,.inl_.inl_b_1969_8594,.inl_.X2237_8580,.inl_.inl_b_1985_8613,.inl_c_8525,.inl_.inl_.inl_b_1963_1995_8619,.inl_.inl_.X2237_1973_8597,.inl_a_8572,.inl_.X2235_8576,.inl_.X2236_8585,.inl_b_8586,.inl_.inl_c_1989_8614 10679, Generating present(particles[:livebatchsize]) Generating implicit firstprivate(livebatchsize) Generating NVIDIA GPU code 10682, #pragma acc loop gang, vector(128) /* blockIdx.x threadIdx.x */ 10679, Local memory used for _particle_save,.inl_c_8691,.inl_.inl_c_1978_8706,.inl_.inl_.inl_b_1963_1984_8711,.inl_.inl_.inl_.X2253_1962_1983_8710,.inl_.inl_b_1974_8705,.inl_.inl_c_1970_8699,.inl_.inl_.inl_.X2253_1962_1994_8721,.inl_.inl_.X2253_1968_8696,.inl_.inl_b_1969_8697,.inl_.X2237_8683,.inl_.inl_b_1985_8716,.inl_c_8680,.inl_.inl_.inl_b_1963_1995_8722,.inl_.inl_.X2237_1973_8700,.inl_a_8675,.inl_.X2235_8679,.inl_.X2236_8688,.inl_b_8689,.inl_.inl_c_1989_8717 finally: 10967, Generating update self(_PSD_var,_Src_var,_Origin_var,_instrument_var,_Vout_var) mcenabletrace: 6050, Generating update device(mcdotrace) DEBUG: CMD: nvc finished INFO: ===