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

openmc-dev / openmc / 12385490469

18 Dec 2024 02:58AM UTC coverage: 82.673% (-2.2%) from 84.823%
12385490469

Pull #3087

github

web-flow
Merge 3317476f5 into 775c41512
Pull Request #3087: wheel building with scikit build core

106679 of 129038 relevant lines covered (82.67%)

12084526.77 hits per line

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

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

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

30
#include "xtensor/xview.hpp"
31

32
namespace openmc {
33

34
void free_memory()
5,357✔
35
{
36
  free_memory_geometry();
5,357✔
37
  free_memory_surfaces();
5,357✔
38
  free_memory_material();
5,357✔
39
  free_memory_volume();
5,357✔
40
  free_memory_simulation();
5,357✔
41
  free_memory_photon();
5,357✔
42
  free_memory_settings();
5,357✔
43
  free_memory_thermal();
5,357✔
44
  library_clear();
5,357✔
45
  nuclides_clear();
5,357✔
46
  free_memory_source();
5,357✔
47
  free_memory_mesh();
5,357✔
48
  free_memory_tally();
5,357✔
49
  free_memory_bank();
5,357✔
50
  free_memory_plot();
5,357✔
51
  free_memory_weight_windows();
5,357✔
52
  if (mpi::master) {
5,357✔
53
    free_memory_cmfd();
4,469✔
54
  }
55
  if (settings::event_based) {
5,357✔
56
    free_event_queues();
×
57
  }
58
}
5,357✔
59

60
} // namespace openmc
61

62
using namespace openmc;
63

64
int openmc_finalize()
5,357✔
65
{
66
  if (simulation::initialized)
5,357✔
67
    openmc_simulation_finalize();
×
68

69
  // Clear results
70
  openmc_reset();
5,357✔
71

72
  // Reset timers
73
  reset_timers();
5,357✔
74

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

147
  simulation::keff = 1.0;
5,357✔
148
  simulation::need_depletion_rx = false;
5,357✔
149
  simulation::ssw_current_file = 1;
5,357✔
150
  simulation::total_gen = 0;
5,357✔
151

152
  simulation::entropy_mesh = nullptr;
5,357✔
153
  simulation::ufs_mesh = nullptr;
5,357✔
154

155
  data::energy_max = {INFTY, INFTY};
5,357✔
156
  data::energy_min = {0.0, 0.0};
5,357✔
157
  data::temperature_min = 0.0;
5,357✔
158
  data::temperature_max = INFTY;
5,357✔
159
  model::root_universe = -1;
5,357✔
160
  model::plotter_seed = 1;
5,357✔
161
  openmc::openmc_set_seed(DEFAULT_SEED);
5,357✔
162

163
  // Deallocate arrays
164
  free_memory();
5,357✔
165

166
#ifdef LIBMESH
167
  settings::libmesh_init.reset();
933✔
168
#endif
169

170
  // Free all MPI types
171
#ifdef OPENMC_MPI
172
  if (mpi::source_site != MPI_DATATYPE_NULL)
2,772✔
173
    MPI_Type_free(&mpi::source_site);
2,772✔
174
#endif
175

176
  return 0;
5,357✔
177
}
178

179
int openmc_reset()
10,346✔
180
{
181

182
  model::universe_cell_counts.clear();
10,346✔
183
  model::universe_level_counts.clear();
10,346✔
184

185
  for (auto& t : model::tallies) {
58,402✔
186
    t->reset();
48,056✔
187
  }
188

189
  // Reset global tallies
190
  simulation::n_realizations = 0;
10,346✔
191
  xt::view(simulation::global_tallies, xt::all()) = 0.0;
10,346✔
192

193
  simulation::k_col_abs = 0.0;
10,346✔
194
  simulation::k_col_tra = 0.0;
10,346✔
195
  simulation::k_abs_tra = 0.0;
10,346✔
196
  simulation::k_sum = {0.0, 0.0};
10,346✔
197
  simulation::satisfy_triggers = false;
10,346✔
198

199
  settings::cmfd_run = false;
10,346✔
200

201
  simulation::n_lost_particles = 0;
10,346✔
202

203
  return 0;
10,346✔
204
}
205

206
int openmc_reset_timers()
×
207
{
208
  reset_timers();
×
209
  return 0;
×
210
}
211

212
int openmc_hard_reset()
×
213
{
214
  // Reset all tallies and timers
215
  openmc_reset();
×
216
  reset_timers();
×
217

218
  // Reset total generations and keff guess
219
  simulation::keff = 1.0;
×
220
  simulation::total_gen = 0;
×
221

222
  // Reset the random number generator state
223
  openmc::openmc_set_seed(DEFAULT_SEED);
×
224
  return 0;
×
225
}
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

© 2025 Coveralls, Inc