• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

openmc-dev / openmc / 27780945043

18 Jun 2026 06:30PM UTC coverage: 81.097% (-0.2%) from 81.34%
27780945043

Pull #3911

github

web-flow
Merge c5ade9293 into 09ee8308d
Pull Request #3911: Creating a new HDF5 nuclear data library for UQ

18119 of 26286 branches covered (68.93%)

Branch coverage included in aggregate %.

310 of 599 new or added lines in 3 files covered. (51.75%)

2247 existing lines in 53 files now uncovered.

59544 of 69480 relevant lines covered (85.7%)

40971728.6 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

98.83
/src/finalize.cpp
1
#include "openmc/finalize.h"
2

3
#include "openmc/bank.h"
4
#include "openmc/capi.h"
5
#include "openmc/chain.h"
6
#include "openmc/cmfd_solver.h"
7
#include "openmc/collision_track.h"
8
#include "openmc/constants.h"
9
#include "openmc/cross_sections.h"
10
#include "openmc/dagmc.h"
11
#include "openmc/eigenvalue.h"
12
#include "openmc/event.h"
13
#include "openmc/geometry.h"
14
#include "openmc/geometry_aux.h"
15
#include "openmc/material.h"
16
#include "openmc/mesh.h"
17
#include "openmc/message_passing.h"
18
#include "openmc/mgxs_interface.h"
19
#include "openmc/nuclide.h"
20
#include "openmc/photon.h"
21
#include "openmc/plot.h"
22
#include "openmc/random_lcg.h"
23
#include "openmc/random_ray/random_ray_simulation.h"
24
#include "openmc/settings.h"
25
#include "openmc/simulation.h"
26
#include "openmc/source.h"
27
#include "openmc/surface.h"
28
#include "openmc/tallies/tally.h"
29
#include "openmc/thermal.h"
30
#include "openmc/timer.h"
31
#include "openmc/volume_calc.h"
32
#include "openmc/weight_windows.h"
33

34
#include "openmc/tensor.h"
35

36
namespace openmc {
37

38
void free_memory()
6,224✔
39
{
40
  free_memory_geometry();
6,224✔
41
  free_memory_surfaces();
6,224✔
42
  free_memory_material();
6,224✔
43
  free_memory_volume();
6,224✔
44
  free_memory_simulation();
6,224✔
45
  free_memory_photon();
6,224✔
46
  free_memory_settings();
6,224✔
47
  free_memory_thermal();
6,224✔
48
  free_memory_chain();
6,224✔
49
  library_clear();
6,224✔
50
  nuclides_clear();
6,224✔
51
  free_memory_source();
6,224✔
52
  free_memory_mesh();
6,224✔
53
  free_memory_tally();
6,224✔
54
  free_memory_bank();
6,224✔
55
  free_memory_plot();
6,224✔
56
  free_memory_weight_windows();
6,224✔
57
  if (mpi::master) {
6,224✔
58
    free_memory_cmfd();
5,717✔
59
  }
60
  if (settings::event_based) {
6,224!
UNCOV
61
    free_event_queues();
×
62
  }
63
}
6,224✔
64

65
} // namespace openmc
66

67
using namespace openmc;
68

69
int openmc_finalize()
6,224✔
70
{
71
  if (simulation::initialized)
6,224✔
72
    openmc_simulation_finalize();
2✔
73

74
  // Clear results
75
  openmc_reset();
6,224✔
76

77
  // Reset timers
78
  reset_timers();
6,224✔
79

80
  // Reset global variables
81
  settings::assume_separate = false;
6,224✔
82
  settings::check_overlaps = false;
6,224✔
83
  settings::collision_track_config = CollisionTrackConfig {};
6,224✔
84
  settings::confidence_intervals = false;
6,224✔
85
  settings::create_fission_neutrons = true;
6,224✔
86
  settings::create_delayed_neutrons = true;
6,224✔
87
  settings::electron_treatment = ElectronTreatment::LED;
6,224✔
88
  settings::delayed_photon_scaling = true;
6,224✔
89
  settings::energy_cutoff = {0.0, 1000.0, 0.0, 0.0};
6,224✔
90
  settings::time_cutoff = {INFTY, INFTY, INFTY, INFTY};
6,224✔
91
  settings::entropy_on = false;
6,224✔
92
  settings::event_based = false;
6,224✔
93
  settings::free_gas_threshold = 400.0;
6,224✔
94
  settings::gen_per_batch = 1;
6,224✔
95
  settings::legendre_to_tabular = true;
6,224✔
96
  settings::legendre_to_tabular_points = -1;
6,224✔
97
  settings::material_cell_offsets = true;
6,224✔
98
  settings::max_lost_particles = 10;
6,224✔
99
  settings::max_order = 0;
6,224✔
100
  settings::max_particles_in_flight = 100000;
6,224✔
101
  settings::max_secondaries = 10000;
6,224✔
102
  settings::max_particle_events = 1'000'000;
6,224✔
103
  settings::max_history_splits = 10'000'000;
6,224✔
104
  settings::max_tracks = 1000;
6,224✔
105
  settings::max_write_lost_particles = -1;
6,224✔
106
  settings::n_log_bins = 8000;
6,224✔
107
  settings::n_inactive = 0;
6,224✔
108
  settings::n_particles = -1;
6,224✔
109
  settings::output_summary = true;
6,224✔
110
  settings::output_tallies = true;
6,224✔
111
  settings::particle_restart_run = false;
6,224✔
112
  settings::path_cross_sections.clear();
6,224✔
113
  settings::path_input.clear();
6,224✔
114
  settings::path_output.clear();
6,224✔
115
  settings::path_particle_restart.clear();
6,224✔
116
  settings::path_sourcepoint.clear();
6,224✔
117
  settings::path_statepoint.clear();
6,224✔
118
  settings::photon_transport = false;
6,224✔
119
  settings::reduce_tallies = true;
6,224✔
120
  settings::rel_max_lost_particles = 1.0e-6;
6,224✔
121
  settings::res_scat_on = false;
6,224✔
122
  settings::res_scat_method = ResScatMethod::rvs;
6,224✔
123
  settings::res_scat_energy_min = 0.01;
6,224✔
124
  settings::res_scat_energy_max = 1000.0;
6,224✔
125
  settings::restart_run = false;
6,224✔
126
  settings::run_CE = true;
6,224✔
127
  settings::run_mode = RunMode::UNSET;
6,224✔
128
  settings::surface_grazing_cutoff = 0.001;
6,224✔
129
  settings::surface_grazing_ratio = 0.5;
6,224✔
130
  settings::solver_type = SolverType::MONTE_CARLO;
6,224✔
131
  settings::source_latest = false;
6,224✔
132
  settings::source_rejection_fraction = 0.05;
6,224✔
133
  settings::source_separate = false;
6,224✔
134
  settings::source_write = true;
6,224✔
135
  settings::ssw_cell_id = C_NONE;
6,224✔
136
  settings::ssw_cell_type = SSWCellType::None;
6,224✔
137
  settings::ssw_max_particles = 0;
6,224✔
138
  settings::ssw_max_files = 1;
6,224✔
139
  settings::survival_biasing = false;
6,224✔
140
  settings::temperature_default = 293.6;
6,224✔
141
  settings::temperature_method = TemperatureMethod::NEAREST;
6,224✔
142
  settings::temperature_multipole = false;
6,224✔
143
  settings::temperature_range = {0.0, 0.0};
6,224✔
144
  settings::temperature_tolerance = 10.0;
6,224✔
145
  settings::properties_file.clear();
6,224✔
146
  settings::trigger_on = false;
6,224✔
147
  settings::trigger_predict = false;
6,224✔
148
  settings::trigger_batch_interval = 1;
6,224✔
149
  settings::uniform_source_sampling = false;
6,224✔
150
  settings::ufs_on = false;
6,224✔
151
  settings::urr_ptables_on = true;
6,224✔
152
  settings::use_decay_photons = false;
6,224✔
153
  settings::use_shared_secondary_bank = false;
6,224✔
154
  settings::verbosity = -1;
6,224✔
155
  settings::weight_cutoff = 0.25;
6,224✔
156
  settings::weight_survive = 1.0;
6,224✔
157
  settings::weight_windows_file.clear();
6,224✔
158
  settings::weight_windows_on = false;
6,224✔
159
  settings::write_all_tracks = false;
6,224✔
160
  settings::write_initial_source = false;
6,224✔
161

162
  simulation::keff = 1.0;
6,224✔
163
  simulation::need_depletion_rx = false;
6,224✔
164
  simulation::ssw_current_file = 1;
6,224✔
165
  simulation::total_gen = 0;
6,224✔
166

167
  simulation::entropy_mesh = nullptr;
6,224✔
168
  simulation::ufs_mesh = nullptr;
6,224✔
169

170
  data::energy_max = {INFTY, INFTY, INFTY, INFTY};
6,224✔
171
  data::energy_min = {0.0, 0.0, 0.0, 0.0};
6,224✔
172
  data::temperature_min = 0.0;
6,224✔
173
  data::temperature_max = INFTY;
6,224✔
174
  data::mg = {};
6,224✔
175
  model::root_universe = -1;
6,224✔
176
  model::plotter_seed = 1;
6,224✔
177
  openmc::openmc_set_seed(DEFAULT_SEED);
6,224✔
178
  openmc::openmc_set_stride(DEFAULT_STRIDE);
6,224✔
179

180
  // Deallocate arrays
181
  free_memory();
6,224✔
182

183
#ifdef OPENMC_LIBMESH_ENABLED
184
  settings::libmesh_init.reset();
719✔
185
#endif
186

187
  // Free all MPI types
188
#ifdef OPENMC_MPI
189
  if (mpi::source_site != MPI_DATATYPE_NULL) {
1,979✔
190
    MPI_Type_free(&mpi::source_site);
1,937✔
191
  }
192
  if (mpi::collision_track_site != MPI_DATATYPE_NULL) {
1,979✔
193
    MPI_Type_free(&mpi::collision_track_site);
1,937✔
194
  }
195
#endif
196

197
  openmc_finalize_random_ray();
6,224✔
198

199
  return 0;
6,224✔
200
}
201

202
int openmc_reset()
12,338✔
203
{
204

205
  model::universe_level_counts.clear();
12,338✔
206

207
  for (auto& t : model::tallies) {
50,346✔
208
    t->reset();
38,008✔
209
  }
210

211
  // Reset global tallies
212
  simulation::n_realizations = 0;
12,338✔
213
  simulation::global_tallies.fill(0.0);
12,338✔
214

215
  simulation::k_col_abs = 0.0;
12,338✔
216
  simulation::k_col_tra = 0.0;
12,338✔
217
  simulation::k_abs_tra = 0.0;
12,338✔
218
  simulation::k_sum = {0.0, 0.0};
12,338✔
219
  simulation::satisfy_triggers = false;
12,338✔
220

221
  settings::cmfd_run = false;
12,338✔
222

223
  simulation::n_lost_particles = 0;
12,338✔
224
  simulation::simulation_tracks_completed = 0;
12,338✔
225

226
  return 0;
12,338✔
227
}
228

229
int openmc_reset_timers()
178✔
230
{
231
  reset_timers();
178✔
232
  return 0;
178✔
233
}
234

235
int openmc_hard_reset()
136✔
236
{
237
  // Reset all tallies and timers
238
  openmc_reset();
136✔
239
  reset_timers();
136✔
240

241
  // Reset total generations and keff guess
242
  simulation::keff = 1.0;
136✔
243
  simulation::total_gen = 0;
136✔
244

245
  // Reset the random number generator state
246
  openmc::openmc_set_seed(DEFAULT_SEED);
136✔
247
  openmc::openmc_set_stride(DEFAULT_STRIDE);
136✔
248
  return 0;
136✔
249
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc