From 4ea7e4ff6fa13456c35fdbe70cebd410679d3fc0 Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 7 Nov 2022 10:42:52 -0600 Subject: [PATCH 01/34] read_depcode_info() -> read_step_metadata(); sim_info -> step_metadata consistency changes associated with this name changes --- doc/releasenotes/v0.5.0.rst | 8 +++-- saltproc/abc.py | 14 ++++---- saltproc/openmc_depcode.py | 12 +++---- saltproc/serpent_depcode.py | 34 +++++++++--------- saltproc/simulation.py | 36 +++++++++---------- .../database_storage/test.py | 4 +-- tests/unit_tests/test_depcode_serpent.py | 24 ++++++------- 7 files changed, 68 insertions(+), 64 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index 3cee61738..dfc204c18 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -108,21 +108,25 @@ Python API Changes longer be initialized by the user during object creation. -- New/changed classes and methods: +- New/changed classes, methods, and attributes: - ``Depcode`` - ``template_inputfile_path`` → ``template_input_file_path`` - Changed `iter_inputfile` and `iter_matfile` to be attributes instead of parameters + - ``read_depcode_info()`` → ``read_step_metadata()`` + - ``sim_info`` → ``step_metadata`` - ``DepcodeSerpent`` → ``SerpentDepcode`` - ``template_inputfile_path`` → ``template_input_file_path`` - Changed `iter_inputfile` and `iter_matfile` to be attributes instead of parameters + - ``read_depcode_info()`` → ``read_depletion_step_metadata()`` + - ``sim_info`` → ``step_metadata`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - + - ``read_depletion_step_metadata()`` - ``run_depcode()`` - ``switch_to_next_geometry()`` - ``write_depcode_input()`` diff --git a/saltproc/abc.py b/saltproc/abc.py index 2438ee1e2..6a6d74462 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -12,9 +12,9 @@ class Depcode(ABC): param : dict of str to type Holds depletion step parameter information. Parameter names are keys and parameter values are values. - sim_info : dict of str to type - Holds simulation settings information. Setting names are keys - and setting values are values. + step_metadata : dict of str to type + Holds depletion code depletion step metadata. Metadata labels are keys + and metadata values are values. iter_inputfile : str Path to depletion code input file for depletion code rerunning. iter_matfile : str @@ -64,14 +64,14 @@ def __init__(self, self.active_cycles = active_cycles self.inactive_cycles = inactive_cycles self.param = {} - self.sim_info = {} + self.step_metadata = {} self.iter_inputfile = './iter_input' self.iter_matfile = './iter_mat' @abstractmethod - def read_depcode_info(self): - """Parses initial depletion code info data from depletion code - output and stores it in the `Depcode` object's ``sim_info`` attribute. + def read_step_metadata(self): + """Reads depletion code's depletion step metadata and stores it in the + :class:`Depcode` object's :attr:`step_metadata` attribute. """ @abstractmethod diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 67ec1c250..4a0025b1c 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -23,9 +23,9 @@ class OpenMCDepcode(Depcode): param : dict of str to type Holds depletion step parameter information. Parameter names are keys and parameter values are values. - sim_info : dict of str to type - Holds simulation settings information. Setting names are keys - and setting values are values. + step_metadata : dict of str to type + Holds OpenMC depletion step metadata. Metadata labels are keys + and metadata values are values. iter_inputfile : dict of str to str Paths to OpenMC input files for OpenMC rerunning. iter_matfile : str @@ -79,9 +79,9 @@ def __init__(self, 'settings': './settings.xml'}, self.iter_matfile = './materials.xml' - def read_depcode_info(self): - """Parses initial OpenMC simulation info from the OpenMC output files - and stores it in the `Depcode` object's ``sim_info`` attribute. + def read_step_metadata(self): + """Reads OpenMC's depletion step metadata and stores it in the + :class:`OpenMCDepcode` object's :attr:`step_metadata` attribute. """ def read_depcode_step_param(self): diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index aecdddbe5..f0769304a 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -21,9 +21,9 @@ class SerpentDepcode(Depcode): param : dict of str to type Holds Serpent depletion step parameter information. Parameter names are keys and parameter values are values. - sim_info : dict of str to type - Holds Serpent simulation settings information. Setting names are keys - and setting values are values. + step_metadata : dict of str to type + Holds Serpent2 depletion step metadata. Metadata labels are keys + and metadata values are values. iter_inputfile : str Path to Serpent2 input file for Serpent2 rerunning. iter_matfile : str @@ -302,26 +302,26 @@ def read_dep_comp(self, read_at_end=False): self.create_nuclide_name_map_zam_to_serpent() return mats - def read_depcode_info(self): - """Parses initial simulation info data from Serpent2 output and stores - it in the `SerpentDepcode` object's ``sim_info`` attributes. + def read_step_metadata(self): + """Reads Serpent2 depletion step metadata and stores it in the + :class:`SerpentDepcode` object's :attr:`step_metadata` attribute. """ res = serpent.parse_res(self.iter_inputfile + "_res.m") depcode_name, depcode_ver = res['VERSION'][0].decode('utf-8').split() - self.sim_info['depcode_name'] = depcode_name - self.sim_info['depcode_version'] = depcode_ver - self.sim_info['title'] = res['TITLE'][0].decode('utf-8') - self.sim_info['depcode_input_filename'] = \ + self.step_metadata['depcode_name'] = depcode_name + self.step_metadata['depcode_version'] = depcode_ver + self.step_metadata['title'] = res['TITLE'][0].decode('utf-8') + self.step_metadata['depcode_input_filename'] = \ res['INPUT_FILE_NAME'][0].decode('utf-8') - self.sim_info['depcode_working_dir'] = \ + self.step_metadata['depcode_working_dir'] = \ res['WORKING_DIRECTORY'][0].decode('utf-8') - self.sim_info['xs_data_path'] = \ + self.step_metadata['xs_data_path'] = \ res['XS_DATA_FILE_PATH'][0].decode('utf-8') - self.sim_info['OMP_threads'] = res['OMP_THREADS'][0] - self.sim_info['MPI_tasks'] = res['MPI_TASKS'][0] - self.sim_info['memory_optimization_mode'] = res['OPTIMIZATION_MODE'][0] - self.sim_info['depletion_timestep'] = res['BURN_DAYS'][1][0] - self.sim_info['depletion_timestep'] = res['BURN_DAYS'][1][0] + self.step_metadata['OMP_threads'] = res['OMP_THREADS'][0] + self.step_metadata['MPI_tasks'] = res['MPI_TASKS'][0] + self.step_metadata['memory_optimization_mode'] = res['OPTIMIZATION_MODE'][0] + self.step_metadata['depletion_timestep'] = res['BURN_DAYS'][1][0] + self.step_metadata['depletion_timestep'] = res['BURN_DAYS'][1][0] def read_depcode_step_param(self): """Parses data from Serpent2 output for each step and stores it in diff --git a/saltproc/simulation.py b/saltproc/simulation.py index bfee76c72..f54106b74 100644 --- a/saltproc/simulation.py +++ b/saltproc/simulation.py @@ -367,7 +367,7 @@ def store_run_init_info(self): # numpy arraw row storage for run info # delete and make this datatype specific # to Depcode subclasses - sim_info_dtype = np.dtype([ + step_metadata_dtype = np.dtype([ ('neutron_population', int), ('active_cycles', int), ('inactive_cycles', int), @@ -383,24 +383,24 @@ def store_run_init_info(self): ('depletion_timestep', float) ]) # Read info from depcode _res.m File - self.sim_depcode.read_depcode_info() + self.sim_depcode.read_step_metadata() # Store information about material properties in new array row - sim_info_row = ( + step_metadata_row = ( self.sim_depcode.npop, self.sim_depcode.active_cycles, self.sim_depcode.inactive_cycles, # delete the below - self.sim_depcode.sim_info['depcode_name'], - self.sim_depcode.sim_info['depcode_version'], - self.sim_depcode.sim_info['title'], - self.sim_depcode.sim_info['depcode_input_filename'], - self.sim_depcode.sim_info['depcode_working_dir'], - self.sim_depcode.sim_info['xs_data_path'], - self.sim_depcode.sim_info['OMP_threads'], - self.sim_depcode.sim_info['MPI_tasks'], - self.sim_depcode.sim_info['memory_optimization_mode'], - self.sim_depcode.sim_info['depletion_timestep'] + self.sim_depcode.step_metadata['depcode_name'], + self.sim_depcode.step_metadata['depcode_version'], + self.sim_depcode.step_metadata['title'], + self.sim_depcode.step_metadata['depcode_input_filename'], + self.sim_depcode.step_metadata['depcode_working_dir'], + self.sim_depcode.step_metadata['xs_data_path'], + self.sim_depcode.step_metadata['OMP_threads'], + self.sim_depcode.step_metadata['MPI_tasks'], + self.sim_depcode.step_metadata['memory_optimization_mode'], + self.sim_depcode.step_metadata['depletion_timestep'] ) - sim_info_array = np.array([sim_info_row], dtype=sim_info_dtype) + step_metadata_array = np.array([step_metadata_row], dtype=step_metadata_dtype) # Open or restore db and append datat to it db = tb.open_file( @@ -408,14 +408,14 @@ def store_run_init_info(self): mode='a', filters=self.compression_params) try: - sim_info_table = db.get_node(db.root, 'initial_depcode_siminfo') + step_metadata_table = db.get_node(db.root, 'initial_depcode_siminfo') except Exception: - sim_info_table = db.create_table( + step_metadata_table = db.create_table( db.root, 'initial_depcode_siminfo', - sim_info_array, + step_metadata_array, "Initial depletion code simulation parameters") - sim_info_table.flush() + step_metadata_table.flush() db.close() def read_k_eds_delta(self, current_timestep): diff --git a/tests/integration_tests/database_storage/test.py b/tests/integration_tests/database_storage/test.py index 7bfc3f99e..28f99d1eb 100644 --- a/tests/integration_tests/database_storage/test.py +++ b/tests/integration_tests/database_storage/test.py @@ -268,8 +268,8 @@ def test_store_run_init_info(simulation): """ # read data - simulation.sim_depcode.read_depcode_info() - init_info = simulation.sim_depcode.sim_info + simulation.sim_depcode.read_step_metadata() + init_info = simulation.sim_depcode.step_metadata # we want to keep the old path for other sims, but for this # test we'll want a fresh db diff --git a/tests/unit_tests/test_depcode_serpent.py b/tests/unit_tests/test_depcode_serpent.py index 06ad3f919..c1fb65bfe 100644 --- a/tests/unit_tests/test_depcode_serpent.py +++ b/tests/unit_tests/test_depcode_serpent.py @@ -53,22 +53,22 @@ def test_get_nuc_name(serpent_depcode): assert serpent_depcode.get_nuc_name('491142')[0] == 'In114m2' -def test_read_depcode_info(serpent_depcode): - serpent_depcode.read_depcode_info() - assert serpent_depcode.sim_info['depcode_name'] == 'Serpent' - assert serpent_depcode.sim_info['depcode_version'] == '2.1.31' - assert serpent_depcode.sim_info['title'] == 'Untitled' - assert serpent_depcode.sim_info['depcode_input_filename'] == \ +def test_read_step_metadata(serpent_depcode): + serpent_depcode.read_step_metadata() + assert serpent_depcode.step_metadata['depcode_name'] == 'Serpent' + assert serpent_depcode.step_metadata['depcode_version'] == '2.1.31' + assert serpent_depcode.step_metadata['title'] == 'Untitled' + assert serpent_depcode.step_metadata['depcode_input_filename'] == \ '/home/andrei2/Desktop/git/saltproc/develop/saltproc/data/saltproc_tap' - assert serpent_depcode.sim_info['depcode_working_dir'] == \ + assert serpent_depcode.step_metadata['depcode_working_dir'] == \ '/home/andrei2/Desktop/git/saltproc/develop/saltproc' - assert serpent_depcode.sim_info['xs_data_path'] == \ + assert serpent_depcode.step_metadata['xs_data_path'] == \ '/home/andrei2/serpent/xsdata/jeff312/sss_jeff312.xsdata' - assert serpent_depcode.sim_info['MPI_tasks'] == 1 - assert serpent_depcode.sim_info['OMP_threads'] == 4 - assert serpent_depcode.sim_info['memory_optimization_mode'] == 4 - assert serpent_depcode.sim_info['depletion_timestep'] == 3.0 + assert serpent_depcode.step_metadata['MPI_tasks'] == 1 + assert serpent_depcode.step_metadata['OMP_threads'] == 4 + assert serpent_depcode.step_metadata['memory_optimization_mode'] == 4 + assert serpent_depcode.step_metadata['depletion_timestep'] == 3.0 def test_read_depcode_step_param(serpent_depcode): From 152806f1990b6b90c6718a7d2c35293e8511161e Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 7 Nov 2022 11:41:38 -0600 Subject: [PATCH 02/34] update depcode unit test filenames --- .../unit_tests/{test_depcode_openmc.py => test_openmc_depcode.py} | 0 .../{test_depcode_serpent.py => test_serpent_depcode.py} | 0 2 files changed, 0 insertions(+), 0 deletions(-) rename tests/unit_tests/{test_depcode_openmc.py => test_openmc_depcode.py} (100%) rename tests/unit_tests/{test_depcode_serpent.py => test_serpent_depcode.py} (100%) diff --git a/tests/unit_tests/test_depcode_openmc.py b/tests/unit_tests/test_openmc_depcode.py similarity index 100% rename from tests/unit_tests/test_depcode_openmc.py rename to tests/unit_tests/test_openmc_depcode.py diff --git a/tests/unit_tests/test_depcode_serpent.py b/tests/unit_tests/test_serpent_depcode.py similarity index 100% rename from tests/unit_tests/test_depcode_serpent.py rename to tests/unit_tests/test_serpent_depcode.py From 4947cd7e4905a0d3083732861ab2885373802b88 Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 7 Nov 2022 12:22:15 -0600 Subject: [PATCH 03/34] read_depcode_step_param() -> read_neutronics_parameters(); param -> neutronics_parameters conistency changes associated with function and attribute name change --- doc/releasenotes/v0.5.0.rst | 4 ++ saltproc/abc.py | 13 ++++--- saltproc/openmc_depcode.py | 13 ++++--- saltproc/serpent_depcode.py | 39 +++++++++++-------- saltproc/simulation.py | 37 +++++++++--------- .../database_storage/test.py | 10 ++--- tests/unit_tests/test_serpent_depcode.py | 18 ++++----- 7 files changed, 72 insertions(+), 62 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index dfc204c18..043b2047f 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -116,6 +116,8 @@ Python API Changes - Changed `iter_inputfile` and `iter_matfile` to be attributes instead of parameters - ``read_depcode_info()`` → ``read_step_metadata()`` - ``sim_info`` → ``step_metadata`` + - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` + - ``param`` → ``neutronics_parameters`` - ``DepcodeSerpent`` → ``SerpentDepcode`` @@ -123,6 +125,8 @@ Python API Changes - Changed `iter_inputfile` and `iter_matfile` to be attributes instead of parameters - ``read_depcode_info()`` → ``read_depletion_step_metadata()`` - ``sim_info`` → ``step_metadata`` + - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` + - ``param`` → ``neutronics_parameters`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions diff --git a/saltproc/abc.py b/saltproc/abc.py index 6a6d74462..a5fb67ff5 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -9,8 +9,8 @@ class Depcode(ABC): Attributes ----------- - param : dict of str to type - Holds depletion step parameter information. Parameter names are keys + neutronics_parameters : dict of str to type + Holds depletion step neutronics parameters. Parameter names are keys and parameter values are values. step_metadata : dict of str to type Holds depletion code depletion step metadata. Metadata labels are keys @@ -63,7 +63,7 @@ def __init__(self, self.npop = npop self.active_cycles = active_cycles self.inactive_cycles = inactive_cycles - self.param = {} + self.neutronics_parameters = {} self.step_metadata = {} self.iter_inputfile = './iter_input' self.iter_matfile = './iter_mat' @@ -75,9 +75,10 @@ def read_step_metadata(self): """ @abstractmethod - def read_depcode_step_param(self): - """Parses data from depletion code output for each step and stores - it in `Depcode` object's ``param`` attributes. + def read_neutronics_parameters(self): + """Reads depletion code's depletion step neutronics parameters and + stores them in :class:`Depcode` object's + :attr:`neutronics_parameters` attribute. """ @abstractmethod diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 4a0025b1c..cd8e572ed 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -20,9 +20,9 @@ class OpenMCDepcode(Depcode): Attributes ---------- - param : dict of str to type - Holds depletion step parameter information. Parameter names are keys - and parameter values are values. + neutronics_parameters : dict of str to type + Holds OpenMC depletion step neutronics parameters. Parameter names are + keys and parameter values are values. step_metadata : dict of str to type Holds OpenMC depletion step metadata. Metadata labels are keys and metadata values are values. @@ -84,9 +84,10 @@ def read_step_metadata(self): :class:`OpenMCDepcode` object's :attr:`step_metadata` attribute. """ - def read_depcode_step_param(self): - """Parses data from OpenMC depletion output for each step and stores - it in `Depcode` object's ``param`` attributes. + def read_neutronics_parameters(self): + """Reads OpenMC depletion step neutronics parameters and stores them + in :class:`OpenMCDepcode` object's :attr:`neutronics_parameters` + attribute. """ def read_dep_comp(self, read_at_end=False): diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index f0769304a..14d9e81e5 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -18,8 +18,8 @@ class SerpentDepcode(Depcode): Attributes ----------- - param : dict of str to type - Holds Serpent depletion step parameter information. Parameter names are + neutronics_parameters : dict of str to type + Holds Serpent2 depletion step neutronics parameters. Parameter names are keys and parameter values are values. step_metadata : dict of str to type Holds Serpent2 depletion step metadata. Metadata labels are keys @@ -321,26 +321,31 @@ def read_step_metadata(self): self.step_metadata['MPI_tasks'] = res['MPI_TASKS'][0] self.step_metadata['memory_optimization_mode'] = res['OPTIMIZATION_MODE'][0] self.step_metadata['depletion_timestep'] = res['BURN_DAYS'][1][0] - self.step_metadata['depletion_timestep'] = res['BURN_DAYS'][1][0] + self.step_metadata['execution_time'] = res['RUNNING_TIME'][1] + self.step_metadata['memory_usage'] = res['MEMSIZE'][0] + - def read_depcode_step_param(self): - """Parses data from Serpent2 output for each step and stores it in - `SerpentDepcode` object's ``param`` attributes. + def read_neutronics_parameters(self): + """Reads Serpent2 depletion step neutronics parameters and stores them + in :class:`SerpentDepcode` object's :attr:`neutronics_parameters` + attribute. """ res = serpent.parse_res(self.iter_inputfile + "_res.m") - self.param['keff_bds'] = res['IMP_KEFF'][0] - self.param['keff_eds'] = res['IMP_KEFF'][1] - self.param['breeding_ratio'] = res['CONVERSION_RATIO'][1] - self.param['execution_time'] = res['RUNNING_TIME'][1] - self.param['burn_days'] = res['BURN_DAYS'][1][0] - self.param['power_level'] = res['TOT_POWER'][1][0] - self.param['memory_usage'] = res['MEMSIZE'][0] + self.neutronics_parameters['keff_bds'] = res['IMP_KEFF'][0] + self.neutronics_parameters['keff_eds'] = res['IMP_KEFF'][1] + self.neutronics_parameters['breeding_ratio'] = \ + res['CONVERSION_RATIO'][1] + self.neutronics_parameters['burn_days'] = res['BURN_DAYS'][1][0] + self.neutronics_parameters['power_level'] = res['TOT_POWER'][1][0] b_l = int(.5 * len(res['FWD_ANA_BETA_ZERO'][1])) - self.param['beta_eff'] = res['FWD_ANA_BETA_ZERO'][1].reshape((b_l, 2)) - self.param['delayed_neutrons_lambda'] = \ + self.neutronics_parameters['beta_eff'] = \ + res['FWD_ANA_BETA_ZERO'][1].reshape((b_l, 2)) + self.neutronics_parameters['delayed_neutrons_lambda'] = \ res['FWD_ANA_LAMBDA'][1].reshape((b_l, 2)) - self.param['fission_mass_bds'] = res['INI_FMASS'][1] - self.param['fission_mass_eds'] = res['TOT_FMASS'][1] + self.neutronics_parameters['fission_mass_bds'] = \ + res['INI_FMASS'][1] + self.neutronics_parameters['fission_mass_eds'] = \ + res['TOT_FMASS'][1] def read_plaintext_file(self, file_path): """Reads the content of a plaintext file for use by other methods. diff --git a/saltproc/simulation.py b/saltproc/simulation.py index f54106b74..b1fa48ef2 100644 --- a/saltproc/simulation.py +++ b/saltproc/simulation.py @@ -290,19 +290,17 @@ def store_run_step_info(self): """ # Read info from depcode _res.m File - self.sim_depcode.read_depcode_step_param() + self.sim_depcode.read_neutronics_parameters() # Initialize beta groups number - b_g = len(self.sim_depcode.param['beta_eff']) + b_g = len(self.sim_depcode.neutronics_parameters['beta_eff']) # numpy array row storage for run info class Step_info(tb.IsDescription): keff_bds = tb.Float32Col((2,)) keff_eds = tb.Float32Col((2,)) breeding_ratio = tb.Float32Col((2,)) - step_execution_time = tb.Float32Col() cumulative_time_at_eds = tb.Float32Col() power_level = tb.Float32Col() - memory_usage = tb.Float32Col() beta_eff_eds = tb.Float32Col((b_g, 2)) delayed_neutrons_lambda_eds = tb.Float32Col((b_g, 2)) fission_mass_bds = tb.Float32Col() @@ -326,28 +324,24 @@ class Step_info(tb.IsDescription): "Simulation parameters after each timestep") # Intializing burn_time array at the first depletion step self.burn_time = 0.0 - self.burn_time += self.sim_depcode.param['burn_days'] + self.burn_time += self.sim_depcode.neutronics_parameters['burn_days'] # Define row of table as step_info step_info = step_info_table.row # Define all values in the row - step_info['keff_bds'] = self.sim_depcode.param['keff_bds'] - step_info['keff_eds'] = self.sim_depcode.param['keff_eds'] - step_info['breeding_ratio'] = self.sim_depcode.param[ + step_info['keff_bds'] = self.sim_depcode.neutronics_parameters['keff_bds'] + step_info['keff_eds'] = self.sim_depcode.neutronics_parameters['keff_eds'] + step_info['breeding_ratio'] = self.sim_depcode.neutronics_parameters[ 'breeding_ratio'] - step_info['step_execution_time'] = self.sim_depcode.param[ - 'execution_time'] step_info['cumulative_time_at_eds'] = self.burn_time - step_info['power_level'] = self.sim_depcode.param['power_level'] - step_info['memory_usage'] = self.sim_depcode.param[ - 'memory_usage'] - step_info['beta_eff_eds'] = self.sim_depcode.param[ + step_info['power_level'] = self.sim_depcode.neutronics_parameters['power_level'] + step_info['beta_eff_eds'] = self.sim_depcode.neutronics_parameters[ 'beta_eff'] - step_info['delayed_neutrons_lambda_eds'] = self.sim_depcode.param[ + step_info['delayed_neutrons_lambda_eds'] = self.sim_depcode.neutronics_parameters[ 'delayed_neutrons_lambda'] - step_info['fission_mass_bds'] = self.sim_depcode.param[ + step_info['fission_mass_bds'] = self.sim_depcode.neutronics_parameters[ 'fission_mass_bds'] - step_info['fission_mass_eds'] = self.sim_depcode.param[ + step_info['fission_mass_eds'] = self.sim_depcode.neutronics_parameters[ 'fission_mass_eds'] # Inject the Record value into the table @@ -380,7 +374,9 @@ def store_run_init_info(self): ('OMP_threads', int), ('MPI_tasks', int), ('memory_optimization_mode', int), - ('depletion_timestep', float) + ('depletion_timestep', float), + ('execution_time', float), + ('memory_usage', float) ]) # Read info from depcode _res.m File self.sim_depcode.read_step_metadata() @@ -398,7 +394,10 @@ def store_run_init_info(self): self.sim_depcode.step_metadata['OMP_threads'], self.sim_depcode.step_metadata['MPI_tasks'], self.sim_depcode.step_metadata['memory_optimization_mode'], - self.sim_depcode.step_metadata['depletion_timestep'] + self.sim_depcode.step_metadata['depletion_timestep'], + self.sim_depcode.step_metadata['execution_time'], + self.sim_depcode.step_metadata['memory_usage'] + ) step_metadata_array = np.array([step_metadata_row], dtype=step_metadata_dtype) diff --git a/tests/integration_tests/database_storage/test.py b/tests/integration_tests/database_storage/test.py index 28f99d1eb..14c4ee580 100644 --- a/tests/integration_tests/database_storage/test.py +++ b/tests/integration_tests/database_storage/test.py @@ -305,6 +305,8 @@ def test_store_run_init_info(simulation): assert tinit_info[10] == init_info['MPI_tasks'] assert tinit_info[11] == init_info['memory_optimization_mode'] assert tinit_info[12] == init_info['depletion_timestep'] + assert tinit_info[13] == init_info['execution_time'] + assert tinit_info[14] == init_info['memory_usage'] except AssertionError: db.close() os.remove(db_file) @@ -340,8 +342,8 @@ def test_store_run_step_info(simulation): explicity in value and implicitly in type. """ # read data - simulation.sim_depcode.read_depcode_step_param() - step_info = simulation.sim_depcode.param + simulation.sim_depcode.read_neutronics_parameters() + step_info = simulation.sim_depcode.neutronics_parameters # we want to keep the old path for other sims, but for this # test we'll want a fresh db @@ -376,9 +378,7 @@ def test_store_run_step_info(simulation): step_info['keff_bds'].astype('float32')) assert np.array_equal(tstep_info[7], step_info['keff_eds'].astype('float32')) - assert tstep_info[8] == step_info['memory_usage'].astype('float32') - assert tstep_info[9] == step_info['power_level'].astype('float32') - assert tstep_info[10] == step_info['execution_time'].astype('float32') + assert tstep_info[8] == step_info['power_level'].astype('float32') except AssertionError: db.close() os.remove(db_file) diff --git a/tests/unit_tests/test_serpent_depcode.py b/tests/unit_tests/test_serpent_depcode.py index c1fb65bfe..7ee9e3556 100644 --- a/tests/unit_tests/test_serpent_depcode.py +++ b/tests/unit_tests/test_serpent_depcode.py @@ -69,17 +69,17 @@ def test_read_step_metadata(serpent_depcode): assert serpent_depcode.step_metadata['OMP_threads'] == 4 assert serpent_depcode.step_metadata['memory_optimization_mode'] == 4 assert serpent_depcode.step_metadata['depletion_timestep'] == 3.0 + assert serpent_depcode.step_metadata['memory_usage'] == [10552.84] + assert serpent_depcode.step_metadata['execution_time'] == [81.933] -def test_read_depcode_step_param(serpent_depcode): - serpent_depcode.read_depcode_step_param() - assert serpent_depcode.param['memory_usage'] == [10552.84] - assert serpent_depcode.param['execution_time'] == [81.933] - assert serpent_depcode.param['keff_bds'][0] == 1.00651e+00 - assert serpent_depcode.param['keff_eds'][0] == 1.00569e+00 - assert serpent_depcode.param['fission_mass_bds'] == [70081] - assert serpent_depcode.param['fission_mass_eds'] == [70077.1] - assert serpent_depcode.param['breeding_ratio'][1] == 5.20000e-04 +def test_read_neutronics_parameters(serpent_depcode): + serpent_depcode.read_neutronics_parameters() + assert serpent_depcode.neutronics_parameters['keff_bds'][0] == 1.00651e+00 + assert serpent_depcode.neutronics_parameters['keff_eds'][0] == 1.00569e+00 + assert serpent_depcode.neutronics_parameters['fission_mass_bds'] == [70081] + assert serpent_depcode.neutronics_parameters['fission_mass_eds'] == [70077.1] + assert serpent_depcode.neutronics_parameters['breeding_ratio'][1] == 5.20000e-04 def test_read_dep_comp(serpent_depcode): From 94b2647ab53702c1d611376c02cc9e60ef33b52b Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 7 Nov 2022 13:12:04 -0600 Subject: [PATCH 04/34] read_dep_comp() -> read_depleted_materials(); variable name adjustments associated changes to relevant files --- doc/releasenotes/v0.5.0.rst | 4 +- saltproc/abc.py | 14 ++--- saltproc/app.py | 4 +- saltproc/openmc_depcode.py | 15 +++-- saltproc/serpent_depcode.py | 56 +++++++++---------- .../basic_reprocessing/test.py | 2 +- .../database_storage/test.py | 6 +- .../file_interface_serpent/test.py | 2 +- .../run_no_reprocessing/test.py | 4 +- tests/unit_tests/test_materialflow.py | 6 +- tests/unit_tests/test_process.py | 2 +- tests/unit_tests/test_separator.py | 2 +- tests/unit_tests/test_serpent_depcode.py | 4 +- tests/unit_tests/test_sparger.py | 2 +- 14 files changed, 60 insertions(+), 63 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index 043b2047f..8a033f4c1 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -118,6 +118,7 @@ Python API Changes - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` - ``param`` → ``neutronics_parameters`` + - ``read_dep_comp()`` → ``read_depleted_materials()`` - ``DepcodeSerpent`` → ``SerpentDepcode`` @@ -127,10 +128,9 @@ Python API Changes - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` - ``param`` → ``neutronics_parameters`` - + - ``read_dep_comp()`` → ``read_depleted_materials()`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - - ``read_depletion_step_metadata()`` - ``run_depcode()`` - ``switch_to_next_geometry()`` - ``write_depcode_input()`` diff --git a/saltproc/abc.py b/saltproc/abc.py index a5fb67ff5..50892755f 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -82,28 +82,26 @@ def read_neutronics_parameters(self): """ @abstractmethod - def read_dep_comp(self, read_at_end=False): - """Reads the depleted material data from the depcode simulation - and returns a dictionary with a `Materialflow` object for each - burnable material. + def read_depleted_materials(self, read_at_end=False): + """Reads depleted materials from the depletion step results + and returns a dictionary containing them. Parameters ---------- read_at_end : bool, optional - Controls at which moment in the depletion step to read the data. If `True`, the function reads data at the end of the depletion step. Otherwise, the function reads data at the beginning of the depletion step. Returns ------- - mats : dict of str to Materialflow - Dictionary that contains `Materialflow` objects. + depleted_materials : dict of str to Materialflow + Dictionary containing depleted materials. ``key`` Name of burnable material. ``value`` - `Materialflow` object holding composition and properties. + :class:`Materialflow` object holding material composition and properties. """ diff --git a/saltproc/app.py b/saltproc/app.py index 0cd1b5404..0dc9042f9 100644 --- a/saltproc/app.py +++ b/saltproc/app.py @@ -48,11 +48,11 @@ def run(): # Read general simulation data which never changes simulation.store_run_init_info() # Parse and store data for initial state (beginning of dep_step) - mats = depcode.read_dep_comp(False) + mats = depcode.read_depleted_materials(False) simulation.store_mat_data(mats, dep_step - 1, False) # Finish of First step # Main sequence - mats = depcode.read_dep_comp(True) + mats = depcode.read_depleted_materials(True) simulation.store_mat_data(mats, dep_step, False) simulation.store_run_step_info() # Reprocessing here diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index cd8e572ed..c26cb612a 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -90,28 +90,27 @@ def read_neutronics_parameters(self): attribute. """ - def read_dep_comp(self, read_at_end=False): - """Reads the depleted material data from the OpenMC depletion - simulation and returns a dictionary with a `Materialflow` object for - each burnable material. + def read_depleted_materials(self, read_at_end=False): + """Reads depleted materials from OpenMC's `depletion_results.h5` file + and returns a dictionary with a :class:`Materialflow` object for each + depleted material. Parameters ---------- read_at_end : bool, optional - Controls at which moment in the depletion step to read the data. If `True`, the function reads data at the end of the depletion step. Otherwise, the function reads data at the beginning of the depletion step. Returns ------- - mats : dict of str to Materialflow - Dictionary that contains `Materialflow` objects. + depleted_materials : dict of str to Materialflow + Dictionary containing depleted materials. ``key`` Name of burnable material. ``value`` - `Materialflow` object holding composition and properties. + :class:`Materialflow` object holding composition and properties. """ diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 14d9e81e5..9f055a57b 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -250,27 +250,26 @@ def insert_path_to_geometry(self, template_data): 'include \"' + str(self.geo_files[0]) + '\"\n') return template_data - def read_dep_comp(self, read_at_end=False): - """Reads the Serpent2 `*_dep.m` file and returns a dictionary with - a `Materialflow` object for each burnable material. + def read_depleted_materials(self, read_at_end=False): + """Reads depleted materials from Serpent2's `*_dep.m` + file and returns a dictionary containing them. Parameters ---------- read_at_end : bool, optional - Controls at which moment in the depletion step to read the data. If `True`, the function reads data at the end of the depletion step. Otherwise, the function reads data at the beginning of the depletion step. Returns ------- - mats : dict of str to Materialflow - Dictionary that contains `Materialflow` objects. + depleted_materials : dict of str to Materialflow + Dictionary containing depleted materials. ``key`` Name of burnable material. ``value`` - `Materialflow` object holding composition and properties. + :class:`Materialflow` object holding material composition and properties. """ # Determine moment in depletion step to read data from @@ -279,28 +278,29 @@ def read_dep_comp(self, read_at_end=False): else: moment = 0 - dep_file = os.path.join('%s_dep.m' % self.iter_inputfile) - dep = serpent.parse_dep(dep_file, make_mats=False) - self.days = dep['DAYS'][moment] - # Read materials names from the file - mat_name = [] - mats = {} - for key in dep.keys(): - m = re.search('MAT_(.+?)_VOLUME', key) - if m: - mat_name.append(m.group(1)) - zai = list(map(int, dep['ZAI'][:-2])) # zzaaam codes of isotopes - - for m in mat_name: - volume = dep['MAT_' + m + '_VOLUME'][moment] - nucvec = dict(zip(zai, dep['MAT_' + m + '_MDENS'][:, moment])) - mats[m] = Materialflow(nucvec) - mats[m].density = dep['MAT_' + m + '_MDENS'][-1, moment] - mats[m].mass = mats[m].density * volume - mats[m].vol = volume - mats[m].burnup = dep['MAT_' + m + '_BURNUP'][moment] + results_file = os.path.join('%s_dep.m' % self.iter_inputfile) + results = serpent.parse_dep(results_file, make_mats=False) + self.days = results['DAYS'][moment] + + # Get material names + mat_names = [] + depleted_materials = {} + for key in results.keys(): + name_match = re.search('MAT_(.+?)_VOLUME', key) + if name_match: + mat_names.append(name_match.group(1)) + zai = list(map(int, results['ZAI'][:-2])) # zzaaam codes of isotopes + + for name in mat_names: + volume = results[f'MAT_{name}_VOLUME'][moment] + nucvec = dict(zip(zai, results[f'MAT_{name}_MDENS'][:, moment])) + depleted_materials[name] = Materialflow(nucvec) + depleted_materials[name].density = results[f'MAT_{name}_MDENS'][-1, moment] + depleted_materials[name].mass = depleted_materials[name].density * volume + depleted_materials[name].vol = volume + depleted_materials[name].burnup = results[f'MAT_{name}_BURNUP'][moment] self.create_nuclide_name_map_zam_to_serpent() - return mats + return depleted_materials def read_step_metadata(self): """Reads Serpent2 depletion step metadata and stores it in the diff --git a/tests/integration_tests/basic_reprocessing/test.py b/tests/integration_tests/basic_reprocessing/test.py index 1fe2eb367..b4a115bcd 100644 --- a/tests/integration_tests/basic_reprocessing/test.py +++ b/tests/integration_tests/basic_reprocessing/test.py @@ -8,7 +8,7 @@ def test_reprocessing_and_refill( serpent_depcode, proc_test_file, path_test_file): - mats = serpent_depcode.read_dep_comp(True) + mats = serpent_depcode.read_depleted_materials(True) waste_streams, extracted_mass = reprocess_materials(mats, proc_test_file, path_test_file) diff --git a/tests/integration_tests/database_storage/test.py b/tests/integration_tests/database_storage/test.py index 14c4ee580..bcd566f8b 100644 --- a/tests/integration_tests/database_storage/test.py +++ b/tests/integration_tests/database_storage/test.py @@ -34,7 +34,7 @@ def test_store_after_reprocessing( """ # read data - mats = simulation.sim_depcode.read_dep_comp( + mats = simulation.sim_depcode.read_depleted_materials( True) waste_streams, extracted_mass = reprocess_materials( mats, proc_test_file, path_test_file) @@ -139,9 +139,9 @@ def test_store_mat_data(simulation): explicity in value and implicitly in type. """ # read data - mats_before = simulation.sim_depcode.read_dep_comp( + mats_before = simulation.sim_depcode.read_depleted_materials( False) - mats_after = simulation.sim_depcode.read_dep_comp( + mats_after = simulation.sim_depcode.read_depleted_materials( True) fuel_before = mats_before['fuel'] diff --git a/tests/integration_tests/file_interface_serpent/test.py b/tests/integration_tests/file_interface_serpent/test.py index 573aedfd8..00f9e276b 100644 --- a/tests/integration_tests/file_interface_serpent/test.py +++ b/tests/integration_tests/file_interface_serpent/test.py @@ -58,7 +58,7 @@ def test_iter_input_from_template(serpent_depcode, msr): def test_write_iter_files(serpent_depcode, msr): - mats = serpent_depcode.read_dep_comp(True) + mats = serpent_depcode.read_depleted_materials(True) # write_mat_file serpent_depcode.write_mat_file(mats, 12.0) diff --git a/tests/integration_tests/run_no_reprocessing/test.py b/tests/integration_tests/run_no_reprocessing/test.py index 20e49f49f..9a7c14384 100644 --- a/tests/integration_tests/run_no_reprocessing/test.py +++ b/tests/integration_tests/run_no_reprocessing/test.py @@ -88,7 +88,7 @@ def runsim_no_reproc(simulation, reactor, nsteps): # Read general simulation data which never changes simulation.store_run_init_info() # Parse and store data for initial state (beginning of dep_step) - mats = simulation.sim_depcode.read_dep_comp( + mats = simulation.sim_depcode.read_depleted_materials( False) simulation.store_mat_data(mats, dep_step, False) # Finish of First step @@ -97,7 +97,7 @@ def runsim_no_reproc(simulation, reactor, nsteps): simulation.sim_depcode.run_depcode( simulation.core_number, simulation.node_number) - mats = simulation.sim_depcode.read_dep_comp( + mats = simulation.sim_depcode.read_depleted_materials( True) simulation.store_mat_data(mats, dep_step, False) simulation.store_run_step_info() diff --git a/tests/unit_tests/test_materialflow.py b/tests/unit_tests/test_materialflow.py index 5180857c2..dca96ff42 100644 --- a/tests/unit_tests/test_materialflow.py +++ b/tests/unit_tests/test_materialflow.py @@ -2,13 +2,13 @@ def test_get_mass(serpent_depcode): - mats = serpent_depcode.read_dep_comp(True) + mats = serpent_depcode.read_depleted_materials(True) assert mats['fuel'].get_mass() == 112683343.50000001 assert mats['ctrlPois'].get_mass() == 65563.2355 def test_scale_matflow(serpent_depcode): - mats = serpent_depcode.read_dep_comp(True) + mats = serpent_depcode.read_depleted_materials(True) scale_factor = 0.7 scaled_matflow = mats['fuel'].scale_matflow(scale_factor) assert scaled_matflow[922350000] == scale_factor * 3499538.3359278883 @@ -18,7 +18,7 @@ def test_scale_matflow(serpent_depcode): def test_copy_pymat_attrs(serpent_depcode): - mats = serpent_depcode.read_dep_comp(True) + mats = serpent_depcode.read_depleted_materials(True) target_mat = mats['fuel'] target_mat.copy_pymat_attrs(mats['ctrlPois']) assert target_mat.density == 5.873 diff --git a/tests/unit_tests/test_process.py b/tests/unit_tests/test_process.py index f9b372a5f..4cd76bebc 100644 --- a/tests/unit_tests/test_process.py +++ b/tests/unit_tests/test_process.py @@ -15,7 +15,7 @@ def process(): def test_process_material(serpent_depcode, process): - mats = serpent_depcode.read_dep_comp(True) + mats = serpent_depcode.read_depleted_materials(True) thru, waste = process.process_material(mats['fuel']) np.testing.assert_almost_equal(waste[541350000], 19.79776930513891) np.testing.assert_almost_equal(waste[541360000], 176.44741987005173) diff --git a/tests/unit_tests/test_separator.py b/tests/unit_tests/test_separator.py index 64725ecce..79bc8b4ed 100644 --- a/tests/unit_tests/test_separator.py +++ b/tests/unit_tests/test_separator.py @@ -15,7 +15,7 @@ def separator(): def test_rem_elements(serpent_depcode, separator): - mats = serpent_depcode.read_dep_comp(True) + mats = serpent_depcode.read_depleted_materials(True) thru, waste = separator.process_material(mats['fuel']) np.testing.assert_almost_equal(waste[541350000], 19.5320018359295) np.testing.assert_almost_equal(waste[541360000], 174.0787699729534) diff --git a/tests/unit_tests/test_serpent_depcode.py b/tests/unit_tests/test_serpent_depcode.py index 7ee9e3556..2e0129e63 100644 --- a/tests/unit_tests/test_serpent_depcode.py +++ b/tests/unit_tests/test_serpent_depcode.py @@ -82,8 +82,8 @@ def test_read_neutronics_parameters(serpent_depcode): assert serpent_depcode.neutronics_parameters['breeding_ratio'][1] == 5.20000e-04 -def test_read_dep_comp(serpent_depcode): - mats = serpent_depcode.read_dep_comp(True) +def test_read_depleted_materials(serpent_depcode): + mats = serpent_depcode.read_depleted_materials(True) assert mats['fuel']['U235'] == 3499538.3359278883 assert mats['fuel']['U238'] == 66580417.24509208 assert mats['fuel']['F19'] == 37145139.35897285 diff --git a/tests/unit_tests/test_sparger.py b/tests/unit_tests/test_sparger.py index cf0ce047f..a9269426a 100644 --- a/tests/unit_tests/test_sparger.py +++ b/tests/unit_tests/test_sparger.py @@ -15,7 +15,7 @@ def sparger(): def test_rem_elements(serpent_depcode, sparger): - mats = serpent_depcode.read_dep_comp(True) + mats = serpent_depcode.read_depleted_materials(True) thru, waste = sparger.process_material(mats['fuel']) np.testing.assert_almost_equal(waste[541350000], 8.061014535231715) np.testing.assert_almost_equal(waste[541360000], 71.8437109936129) From 053b64a9cd429d50c05731765a9dd8d076f0a435 Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 7 Nov 2022 13:49:02 -0600 Subject: [PATCH 05/34] create_nuclide_name_map_zam_to_serpent() -> map_nuclide_code_zam_to_serpent() - variable name adjustments in function - consitency changes in relevant test files - docstring changes --- doc/releasenotes/v0.5.0.rst | 1 + saltproc/serpent_depcode.py | 53 ++++++++++++------------ tests/unit_tests/test_serpent_depcode.py | 18 ++++---- 3 files changed, 36 insertions(+), 36 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index 8a033f4c1..cb9cdcce8 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -129,6 +129,7 @@ Python API Changes - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` - ``param`` → ``neutronics_parameters`` - ``read_dep_comp()`` → ``read_depleted_materials()`` + - ``create_nuclide_name_map_zam_to_serpent()`` → ``map_nuclide_code_zam_to_serpent()`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - ``run_depcode()`` diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 9f055a57b..bdd88a530 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -193,42 +193,41 @@ def get_nuc_name(self, nuc_code): self.convert_nuclide_name_serpent_to_zam(pyname.zzaaam(nuc_code)) return nuc_name, nuc_zzaaam - def create_nuclide_name_map_zam_to_serpent(self): - """ Create a map that accepts nuclide names in `zzaaam` format and - returns the Serpent2 nuclide code format. Uses Serpent2 `*.out` file - with list of all nuclides in simulation. + def map_nuclide_code_zam_to_serpent(self): + """Creates a dictionary mapping nuclide codes in `zzaaam` format + to Serpent2's nuclide code format. Returns ------- - nuclide_map : dict of str to str - Contains mapping for nuclide names from `zzaaam` to Serpent2 - format imported from Serpent2 ouput file: + nuc_code_map : dict of str to str + Maps `zzaaam` nuclide codes to Serpent2 + nuclide codes. ``key`` - The key is nuclide name in `zzaaam` format. For example, + Nuclide code in `zzaaam` format. For example, `922350` or `982510`. ``value`` - Serpent2-oriented name. For instance, 92235.09c for transport - isotope or 982510 for decay only isotope). + Nuclide code in Serpent2 formate. For instance, 92235.09c for a + nuclide with cross section data, 982510 for a decay-only nuclide). """ - map_dict = {} + nuc_code_map = {} # Construct path to the *.out File out_file = os.path.join('%s.out' % self.iter_inputfile) - file = open(out_file, 'r') - str_list = file.read().split('\n') - # Stop-line - end = ' --- Table 2: Reaction and decay data: ' - for line in str_list: - if not line: - continue - if end in line: - break - if 'c TRA' in line or 'c DEC' in line: - line = line.split() - iname, zzaaam = self.get_nuc_name(line[2]) - map_dict.update({zzaaam: line[2]}) - self.iso_map = map_dict + with open(out_file, 'r') as f: + file_lines = f.read().split('\n') + # Stop-line + end = ' --- Table 2: Reaction and decay data: ' + for line in file_lines: + if not line: + continue + if end in line: + break + if 'c TRA' in line or 'c DEC' in line: + line = line.split() + iname, zzaaam = self.get_nuc_name(line[2]) + nuc_code_map.update({zzaaam: line[2]}) + return nuc_code_map def insert_path_to_geometry(self, template_data): """Inserts ``include `` line on the 6th line of @@ -299,7 +298,6 @@ def read_depleted_materials(self, read_at_end=False): depleted_materials[name].mass = depleted_materials[name].density * volume depleted_materials[name].vol = volume depleted_materials[name].burnup = results[f'MAT_{name}_BURNUP'][moment] - self.create_nuclide_name_map_zam_to_serpent() return depleted_materials def read_step_metadata(self): @@ -559,6 +557,7 @@ def write_mat_file(self, dep_dict, dep_end_time): matf = open(self.iter_matfile, 'w') matf.write('%% Material compositions (after %f days)\n\n' % dep_end_time) + nuc_code_map = self.map_nuclide_code_zam_to_serpent() for key, value in dep_dict.items(): matf.write('mat %s %5.9E burn 1 fix %3s %4i vol %7.5E\n' % (key, @@ -570,6 +569,6 @@ def write_mat_file(self, dep_dict, dep_end_time): # Transforms iso name from zas to zzaaam and then to SERPENT iso_name_serpent = pyname.zzaaam(nuc_code) matf.write(' %9s %7.14E\n' % - (self.iso_map[iso_name_serpent], + (nuc_code_map[iso_name_serpent], -wt_frac)) matf.close() diff --git a/tests/unit_tests/test_serpent_depcode.py b/tests/unit_tests/test_serpent_depcode.py index 2e0129e63..b41dae7fd 100644 --- a/tests/unit_tests/test_serpent_depcode.py +++ b/tests/unit_tests/test_serpent_depcode.py @@ -6,15 +6,15 @@ def test_create_nuclide_name_map_zam_to_serpent(serpent_depcode): - serpent_depcode.create_nuclide_name_map_zam_to_serpent() - assert serpent_depcode.iso_map[380880] == '38088.09c' - assert serpent_depcode.iso_map[962400] == '96240.09c' - assert serpent_depcode.iso_map[952421] == '95342.09c' - assert serpent_depcode.iso_map[340831] == '340831' - assert serpent_depcode.iso_map[300732] == '300732' - assert serpent_depcode.iso_map[511262] == '511262' - assert serpent_depcode.iso_map[420931] == '420931' - assert serpent_depcode.iso_map[410911] == '410911' + nuc_code_map = serpent_depcode.map_nuclide_code_zam_to_serpent() + assert nuc_code_map[380880] == '38088.09c' + assert nuc_code_map[962400] == '96240.09c' + assert nuc_code_map[952421] == '95342.09c' + assert nuc_code_map[340831] == '340831' + assert nuc_code_map[300732] == '300732' + assert nuc_code_map[511262] == '511262' + assert nuc_code_map[420931] == '420931' + assert nuc_code_map[410911] == '410911' def test_convert_nuclide_name_serpent_to_zam(serpent_depcode): From 93c0a1c916c143c19d493f45cd10489fc129d816 Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 7 Nov 2022 14:51:34 -0600 Subject: [PATCH 06/34] run_depcode() -> run_depletion_step() - adjust docstrings - associated changes in other files --- doc/releasenotes/v0.5.0.rst | 2 ++ saltproc/abc.py | 4 +-- saltproc/app.py | 2 +- saltproc/openmc_depcode.py | 4 +-- saltproc/serpent_depcode.py | 25 +++---------------- .../run_no_reprocessing/test.py | 4 +-- 6 files changed, 13 insertions(+), 28 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index cb9cdcce8..a07fc578f 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -119,6 +119,7 @@ Python API Changes - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` - ``param`` → ``neutronics_parameters`` - ``read_dep_comp()`` → ``read_depleted_materials()`` + - ``run_depcode()`` → ``run_depletion_step()`` - ``DepcodeSerpent`` → ``SerpentDepcode`` @@ -130,6 +131,7 @@ Python API Changes - ``param`` → ``neutronics_parameters`` - ``read_dep_comp()`` → ``read_depleted_materials()`` - ``create_nuclide_name_map_zam_to_serpent()`` → ``map_nuclide_code_zam_to_serpent()`` + - ``run_depcode()`` → ``run_depletion_step()`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - ``run_depcode()`` diff --git a/saltproc/abc.py b/saltproc/abc.py index 50892755f..39a5ba87e 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -106,8 +106,8 @@ def read_depleted_materials(self, read_at_end=False): """ @abstractmethod - def run_depcode(self, cores, nodes): - """Runs depletion code as a subprocess with the given parameters. + def run_depletion_step(self, cores, nodes): + """Runs a depletion step as a subprocess with the given parameters. Parameters ---------- diff --git a/saltproc/app.py b/saltproc/app.py index 0dc9042f9..9444c16c4 100644 --- a/saltproc/app.py +++ b/saltproc/app.py @@ -43,7 +43,7 @@ def run(): simulation.sim_depcode.write_depcode_input(msr, dep_step, simulation.restart_flag) - depcode.run_depcode(cores, nodes) + depcode.run_depletion_step(cores, nodes) if dep_step == 0 and simulation.restart_flag is False: # First step # Read general simulation data which never changes simulation.store_run_init_info() diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index c26cb612a..6187a468a 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -114,8 +114,8 @@ def read_depleted_materials(self, read_at_end=False): """ - def run_depcode(self, cores, nodes): - """Runs OpenMC depletion simulation as a subprocess with the given + def run_depletion_step(self, cores, nodes): + """Runs a depletion step in OpenMC as a subprocess with the given parameters. Parameters diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index bdd88a530..4003b9c14 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -410,8 +410,9 @@ def replace_burnup_parameters( current_depstep)) return template_data - def run_depcode(self, cores, nodes): - """Runs Serpent2 as a subprocess with the given parameters. + def run_depletion_step(self, cores, nodes): + """Runs a depletion step in Serpent2 as a subprocess with the given + parameters. Parameters ---------- @@ -422,25 +423,7 @@ def run_depcode(self, cores, nodes): """ - if self.exec_path.startswith('/projects/sciteam/bahg/'): # check if BW - args = ( - 'aprun', - '-n', - str(nodes), - '-d', str(cores), - self.exec_path, - '-omp', - str(cores), - self.iter_inputfile) - elif self.exec_path.startswith('/apps/exp_ctl/'): # check if Falcon - args = ( - 'mpiexec', - self.exec_path, - self.iter_inputfile, - '-omp', - str(18)) - else: - args = (self.exec_path, '-omp', str(cores), self.iter_inputfile) + args = (self.exec_path, '-omp', str(cores), self.iter_inputfile) print('Running %s' % (self.codename)) try: subprocess.check_output( diff --git a/tests/integration_tests/run_no_reprocessing/test.py b/tests/integration_tests/run_no_reprocessing/test.py index 9a7c14384..78978424a 100644 --- a/tests/integration_tests/run_no_reprocessing/test.py +++ b/tests/integration_tests/run_no_reprocessing/test.py @@ -82,7 +82,7 @@ def runsim_no_reproc(simulation, reactor, nsteps): reactor, dep_step, False) - simulation.sim_depcode.run_depcode( + simulation.sim_depcode.run_depletion_step( simulation.core_number, simulation.node_number) # Read general simulation data which never changes @@ -94,7 +94,7 @@ def runsim_no_reproc(simulation, reactor, nsteps): # Finish of First step # Main sequence else: - simulation.sim_depcode.run_depcode( + simulation.sim_depcode.run_depletion_step( simulation.core_number, simulation.node_number) mats = simulation.sim_depcode.read_depleted_materials( From d823203bc851b500feb45f3337800a4c253f6f38 Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 7 Nov 2022 15:12:20 -0600 Subject: [PATCH 07/34] write_mat_file() -> update_depletable_materials() - docstring changes - associated testfile changes --- doc/releasenotes/v0.5.0.rst | 4 +- saltproc/abc.py | 14 +++--- saltproc/app.py | 4 +- saltproc/openmc_depcode.py | 12 ++--- saltproc/serpent_depcode.py | 46 +++++++++---------- .../file_interface_serpent/test.py | 4 +- .../run_no_reprocessing/test.py | 2 +- 7 files changed, 40 insertions(+), 46 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index a07fc578f..17c7f47b8 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -120,6 +120,7 @@ Python API Changes - ``param`` → ``neutronics_parameters`` - ``read_dep_comp()`` → ``read_depleted_materials()`` - ``run_depcode()`` → ``run_depletion_step()`` + - ``write_mat_file()`` → ``update_depletable_materials()`` - ``DepcodeSerpent`` → ``SerpentDepcode`` @@ -132,9 +133,10 @@ Python API Changes - ``read_dep_comp()`` → ``read_depleted_materials()`` - ``create_nuclide_name_map_zam_to_serpent()`` → ``map_nuclide_code_zam_to_serpent()`` - ``run_depcode()`` → ``run_depletion_step()`` + - ``write_mat_file()`` → ``update_depletable_materials()`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - - ``run_depcode()`` + - ``run_depletion_step()`` - ``switch_to_next_geometry()`` - ``write_depcode_input()`` - ``write_depletion_settings()`` diff --git a/saltproc/abc.py b/saltproc/abc.py index 39a5ba87e..f17dc8e9b 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -125,7 +125,7 @@ def switch_to_next_geometry(self): @abstractmethod def write_depcode_input(self, reactor, dep_step, restart): - """ Writes prepared data into depletion code input file(s). + """Writes prepared data into depletion code input file(s). Parameters ---------- @@ -139,20 +139,18 @@ def write_depcode_input(self, reactor, dep_step, restart): """ @abstractmethod - def write_mat_file(self, dep_dict, dep_end_time): - """Writes the iteration input file containing the burnable materials - composition used in depletion runs and updated after each depletion - step. + def update_depletable_materials(self, mats, dep_end_time): + """Update material file with reprocessed material compositions. Parameters ---------- - dep_dict : dict of str to Materialflow - Dictionary that contains `Materialflow` objects. + mats : dict of str to Materialflow + Dictionary containing reprocessed material compositions. ``key`` Name of burnable material. ``value`` - `Materialflow` object holding composition and properties. + :class:`Materialflow` object holding composition and properties. dep_end_time : float Current time at the end of the depletion step (d). diff --git a/saltproc/app.py b/saltproc/app.py index 9444c16c4..a174ba31f 100644 --- a/saltproc/app.py +++ b/saltproc/app.py @@ -84,7 +84,7 @@ def run(): print("Removed mass [g]:", extracted_mass) # Store in DB after reprocessing and refill (right before next depl) simulation.store_after_repr(mats, waste_and_feed_streams, dep_step) - depcode.write_mat_file(mats, simulation.burn_time) + depcode.update_depletable_materials(mats, simulation.burn_time) del mats, waste_streams, waste_and_feed_streams, extracted_mass gc.collect() # Switch to another geometry? @@ -520,7 +520,7 @@ def refill_materials(mats, extracted_mass, waste_streams, process_file): process_file : str Path to the `.json` file describing the fuel reprocessing components. - Returns + Returns ------- waste_streams : dict of str to dict Superset of the input parameter `waste_streams`. Dictionary has diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 6187a468a..9d4cfb184 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -255,20 +255,18 @@ def write_depletion_settings(self, reactor, current_depstep_idx): with open(self.iter_inputfile['depletion_settings'], 'w') as f: f.writelines(json_dep_settings) - def write_mat_file(self, dep_dict, dep_end_time): - """Writes the iteration input file containing the burnable materials - composition used in OpenMC depletion runs and updated after each - depletion step. + def update_depletable_materials(self, mats, dep_end_time): + """Updates material file with reprocessed material compositions. Parameters ---------- - dep_dict : dict of str to Materialflow - Dictionary that contains `Materialflow` objects. + mats : dict of str to Materialflow + Dictionary containing reprocessed material compositions ``key`` Name of burnable material. ``value`` - `Materialflow` object holding composition and properties. + :class:`Materialflow` object holding composition and properties. dep_end_time : float Current time at the end of the depletion step (d). diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 4003b9c14..bf5aef10b 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -518,40 +518,36 @@ def write_depcode_input(self, reactor, dep_step, restart): out_file.writelines(data) out_file.close() - def write_mat_file(self, dep_dict, dep_end_time): - """Writes the iteration input file containing the burnable materials - composition used in Serpent2 runs and updated after each depletion - step. + def update_depletable_materials(self, mats, dep_end_time): + """Update material file with reprocessed material compositions. Parameters ---------- - dep_dict : dict of str to Materialflow - Dictionary that contains `Materialflow` objects. + mats : dict of str to Materialflow + Dictionary containing reprocessed material compositions ``key`` Name of burnable material. ``value`` - `Materialflow` object holding composition and properties. + :class:`Materialflow` object holding composition and properties. dep_end_time : float Current time at the end of the depletion step (d). """ - matf = open(self.iter_matfile, 'w') - matf.write('%% Material compositions (after %f days)\n\n' - % dep_end_time) - nuc_code_map = self.map_nuclide_code_zam_to_serpent() - for key, value in dep_dict.items(): - matf.write('mat %s %5.9E burn 1 fix %3s %4i vol %7.5E\n' % - (key, - -dep_dict[key].density, - '09c', - dep_dict[key].temp, - dep_dict[key].vol)) - for nuc_code, wt_frac in dep_dict[key].comp.items(): - # Transforms iso name from zas to zzaaam and then to SERPENT - iso_name_serpent = pyname.zzaaam(nuc_code) - matf.write(' %9s %7.14E\n' % - (nuc_code_map[iso_name_serpent], - -wt_frac)) - matf.close() + with open(self.iter_matfile, 'w') as f: + f.write('%% Material compositions (after %f days)\n\n' + % dep_end_time) + nuc_code_map = self.map_nuclide_code_zam_to_serpent() + for name, mat in mats.items(): + f.write('mat %s %5.9E burn 1 fix %3s %4i vol %7.5E\n' % + (name, + -mat.density, + '09c', + mat.temp, + mat.vol)) + for nuc_code, mass_fraction in mat.comp.items(): + zam_code = pyname.zzaaam(nuc_code) + f.write(' %9s %7.14E\n' % + (nuc_code_map[zam_code], + -mass_fraction)) diff --git a/tests/integration_tests/file_interface_serpent/test.py b/tests/integration_tests/file_interface_serpent/test.py index 00f9e276b..cdd84754f 100644 --- a/tests/integration_tests/file_interface_serpent/test.py +++ b/tests/integration_tests/file_interface_serpent/test.py @@ -60,8 +60,8 @@ def test_iter_input_from_template(serpent_depcode, msr): def test_write_iter_files(serpent_depcode, msr): mats = serpent_depcode.read_depleted_materials(True) - # write_mat_file - serpent_depcode.write_mat_file(mats, 12.0) + # update_depletable_materials + serpent_depcode.update_depletable_materials(mats, 12.0) file = serpent_depcode.iter_matfile file_data = serpent_depcode.read_plaintext_file(file) assert file_data[0] == '% Material compositions (after 12.000000 days)\n' diff --git a/tests/integration_tests/run_no_reprocessing/test.py b/tests/integration_tests/run_no_reprocessing/test.py index 78978424a..ba66bcd1d 100644 --- a/tests/integration_tests/run_no_reprocessing/test.py +++ b/tests/integration_tests/run_no_reprocessing/test.py @@ -101,6 +101,6 @@ def runsim_no_reproc(simulation, reactor, nsteps): True) simulation.store_mat_data(mats, dep_step, False) simulation.store_run_step_info() - simulation.sim_depcode.write_mat_file( + simulation.sim_depcode.update_depletable_materials( mats, simulation.burn_time) From 94f1479f479bbfe6b12d199ada2bd198f1e1539b Mon Sep 17 00:00:00 2001 From: yardasol Date: Wed, 9 Nov 2022 11:53:08 -0600 Subject: [PATCH 08/34] cleanup nuclide code handling functions - get_nuc_name() -> convert_nuclide_code_to_name() - convert_nuclide_name_serpent_to_zam() -> convert_nuclide_code_to_zam() - docstring cleanup and fixes - consitency changes in other relevant files --- doc/releasenotes/v0.5.0.rst | 2 ++ saltproc/serpent_depcode.py | 45 ++++++++++++----------- saltproc/simulation.py | 4 +-- tests/unit_tests/test_serpent_depcode.py | 46 ++++++++++++------------ 4 files changed, 51 insertions(+), 46 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index 17c7f47b8..eff21fa2e 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -134,6 +134,8 @@ Python API Changes - ``create_nuclide_name_map_zam_to_serpent()`` → ``map_nuclide_code_zam_to_serpent()`` - ``run_depcode()`` → ``run_depletion_step()`` - ``write_mat_file()`` → ``update_depletable_materials()`` + - ``get_nuc_name()`` → ``convert_nuclide_code_to_name()`` + - ``convert_nuclide_name_serpent_to_zam()`` → ``convert_nuclide_code_to_zam()`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - ``run_depletion_step()`` diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index bf5aef10b..05fdddc4d 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -146,23 +146,20 @@ def create_iter_matfile(self, template_data): shutil.copy2(abs_src_matfile, self.iter_matfile) return [s.replace(src_file, self.iter_matfile) for s in template_data] - def get_nuc_name(self, nuc_code): - """Returns nuclide name in human-readable notation: chemical symbol - (one or two characters), dash, and the atomic weight. Lastly, if the - nuclide is in metastable state, the letter `m` is concatenated with - number of excited state. For example, `Am-242m1`. + def convert_nuclide_code_to_name(self, nuc_code): + """Converts Serpent2 nuclide code to symbolic nuclide name. + If nuclide is in a metastable state, the nuclide name is concatenated + with the letter `m` and the state index. Parameters ---------- nuc_code : str - Name of nuclide in Serpent2 form. For instance, `Am-242m`. + Nuclide code in Serpent2 format (`47310.09c`) Returns ------- nuc_name : str - Name of nuclide in human-readable notation (`Am-242m1`). - nuc_zzaaam : str - Name of nuclide in `zzaaam` form (`952421`). + Symbolic nuclide name (`Am242m1`). """ @@ -171,7 +168,6 @@ def get_nuc_name(self, nuc_code): zz = pyname.znum(nuc_code) aa = pyname.anum(nuc_code) aa_str = str(aa) - # at_mass = pydata.atomic_mass(nuc_code_id) if aa > 300: if zz > 76: aa_str = str(aa - 100) + 'm1' @@ -189,9 +185,8 @@ def get_nuc_name(self, nuc_code): nuc_name = pyname.name(nuc_code)[:-1] + 'm' + str(meta_flag) else: nuc_name = pyname.name(nuc_code) - nuc_zzaaam = \ - self.convert_nuclide_name_serpent_to_zam(pyname.zzaaam(nuc_code)) - return nuc_name, nuc_zzaaam + + return nuc_name def map_nuclide_code_zam_to_serpent(self): """Creates a dictionary mapping nuclide codes in `zzaaam` format @@ -207,8 +202,8 @@ def map_nuclide_code_zam_to_serpent(self): Nuclide code in `zzaaam` format. For example, `922350` or `982510`. ``value`` - Nuclide code in Serpent2 formate. For instance, 92235.09c for a - nuclide with cross section data, 982510 for a decay-only nuclide). + Nuclide code in Serpent2 format. For instance, 92235.09c for a + nuclide with cross section data or 982510 for a decay-only nuclide. """ nuc_code_map = {} @@ -225,7 +220,13 @@ def map_nuclide_code_zam_to_serpent(self): break if 'c TRA' in line or 'c DEC' in line: line = line.split() - iname, zzaaam = self.get_nuc_name(line[2]) + nuc_code = line[2] + if '.' in str(nuc_code): + nuc_code = pyname.zzzaaa_to_id(int(nuc_code.split('.')[0])) + + zzaaam = \ + self.convert_nuclide_code_to_zam(pyname.zzaaam(nuc_code)) + nuc_code_map.update({zzaaam: line[2]}) return nuc_code_map @@ -436,22 +437,24 @@ def run_depletion_step(self, cores, nodes): % (self.codename)) print('Finished Serpent2 Run') - def convert_nuclide_name_serpent_to_zam(self, nuc_code): - """Checks Serpent2-specific meta stable-flag for zzaaam. For instance, + def convert_nuclide_code_to_zam(self, nuc_code): + """Converts nuclide code from Serpent2 format to zam format. + Checks Serpent2-specific meta stable-flag for zzaaam. For instance, 47310 instead of 471101 for `Ag-110m1`. Metastable isotopes represented with `aaa` started with ``3``. Parameters ---------- - nuc_code : str - Name of nuclide in Serpent2 form. For instance, `47310`. + nuc_code : int + Nuclide code in Serpent2 format (`47310`). Returns ------- nuc_zzaam : int - Name of nuclide in `zzaaam` form (`471101`). + Nuclide code in in `zzaaam` form (`471101`). """ + zz = pyname.znum(nuc_code) aa = pyname.anum(nuc_code) if aa > 300: diff --git a/saltproc/simulation.py b/saltproc/simulation.py index b1fa48ef2..f9fc3f36c 100644 --- a/saltproc/simulation.py +++ b/saltproc/simulation.py @@ -133,7 +133,7 @@ def store_after_repr(self, after_mats, waste_dict, dep_step): # Read isotopes from Materialflow for nuc, wt_frac in waste_dict[mn][proc].comp.items(): # Dictonary in format {isotope_name : index(int)} - iso_idx[self.sim_depcode.get_nuc_name(nuc)[0]] = coun + iso_idx[self.sim_depcode.convert_nuclide_code_to_name(nuc)] = coun # Convert wt% to absolute [user units] iso_wt_frac.append(wt_frac * waste_dict[mn][proc].mass) coun += 1 @@ -230,7 +230,7 @@ def store_mat_data(self, mats, dep_step, store_at_end=False): # Read isotopes from Materialflow for material for nuc_code, wt_frac in mats[key].comp.items(): # Dictonary in format {isotope_name : index(int)} - iso_idx[key][self.sim_depcode.get_nuc_name(nuc_code)[0]] = coun + iso_idx[key][self.sim_depcode.convert_nuclide_code_to_name(nuc_code)] = coun # Convert wt% to absolute [user units] iso_wt_frac.append(wt_frac * mats[key].mass) coun += 1 diff --git a/tests/unit_tests/test_serpent_depcode.py b/tests/unit_tests/test_serpent_depcode.py index b41dae7fd..43078af0f 100644 --- a/tests/unit_tests/test_serpent_depcode.py +++ b/tests/unit_tests/test_serpent_depcode.py @@ -17,14 +17,14 @@ def test_create_nuclide_name_map_zam_to_serpent(serpent_depcode): assert nuc_code_map[410911] == '410911' -def test_convert_nuclide_name_serpent_to_zam(serpent_depcode): - assert serpent_depcode.convert_nuclide_name_serpent_to_zam(47310) == 471101 - assert serpent_depcode.convert_nuclide_name_serpent_to_zam(95342) == 952421 - assert serpent_depcode.convert_nuclide_name_serpent_to_zam(61348) == 611481 - assert serpent_depcode.convert_nuclide_name_serpent_to_zam(52327) == 521271 - assert serpent_depcode.convert_nuclide_name_serpent_to_zam(1001) == 1001 - assert serpent_depcode.convert_nuclide_name_serpent_to_zam(1002) == 1002 - assert serpent_depcode.convert_nuclide_name_serpent_to_zam(48315) == 481151 +def test_convert_nuclide_code_to_zam(serpent_depcode): + assert serpent_depcode.convert_nuclide_code_to_zam(47310) == 471101 + assert serpent_depcode.convert_nuclide_code_to_zam(95342) == 952421 + assert serpent_depcode.convert_nuclide_code_to_zam(61348) == 611481 + assert serpent_depcode.convert_nuclide_code_to_zam(52327) == 521271 + assert serpent_depcode.convert_nuclide_code_to_zam(1001) == 1001 + assert serpent_depcode.convert_nuclide_code_to_zam(1002) == 1002 + assert serpent_depcode.convert_nuclide_code_to_zam(48315) == 481151 def test_read_plaintext_file(serpent_depcode): @@ -36,21 +36,21 @@ def test_read_plaintext_file(serpent_depcode): assert template_str[23] == 'set pcc 1\n' -def test_get_nuc_name(serpent_depcode): - assert serpent_depcode.get_nuc_name('92235.09c')[0] == 'U235' - assert serpent_depcode.get_nuc_name('38088.09c')[0] == 'Sr88' - assert serpent_depcode.get_nuc_name('95342.09c')[0] == 'Am242m1' - assert serpent_depcode.get_nuc_name('61348.03c')[0] == 'Pm148m1' - assert serpent_depcode.get_nuc_name('20060')[0] == 'He6' - assert serpent_depcode.get_nuc_name('110241')[0] == 'Na24m1' - assert serpent_depcode.get_nuc_name('170381')[0] == 'Cl38m1' - assert serpent_depcode.get_nuc_name('310741')[0] == 'Ga74m1' - assert serpent_depcode.get_nuc_name('290702')[0] == 'Cu70m2' - assert serpent_depcode.get_nuc_name('250621')[0] == 'Mn62m1' - assert serpent_depcode.get_nuc_name('300732')[0] == 'Zn73m2' - assert serpent_depcode.get_nuc_name('370981')[0] == 'Rb98m1' - assert serpent_depcode.get_nuc_name('390972')[0] == 'Y97m2' - assert serpent_depcode.get_nuc_name('491142')[0] == 'In114m2' +def test_convert_nuclide_code_to_name(serpent_depcode): + assert serpent_depcode.convert_nuclide_code_to_name('92235.09c') == 'U235' + assert serpent_depcode.convert_nuclide_code_to_name('38088.09c') == 'Sr88' + assert serpent_depcode.convert_nuclide_code_to_name('95342.09c') == 'Am242m1' + assert serpent_depcode.convert_nuclide_code_to_name('61348.03c') == 'Pm148m1' + assert serpent_depcode.convert_nuclide_code_to_name('20060') == 'He6' + assert serpent_depcode.convert_nuclide_code_to_name('110241') == 'Na24m1' + assert serpent_depcode.convert_nuclide_code_to_name('170381') == 'Cl38m1' + assert serpent_depcode.convert_nuclide_code_to_name('310741') == 'Ga74m1' + assert serpent_depcode.convert_nuclide_code_to_name('290702') == 'Cu70m2' + assert serpent_depcode.convert_nuclide_code_to_name('250621') == 'Mn62m1' + assert serpent_depcode.convert_nuclide_code_to_name('300732') == 'Zn73m2' + assert serpent_depcode.convert_nuclide_code_to_name('370981') == 'Rb98m1' + assert serpent_depcode.convert_nuclide_code_to_name('390972') == 'Y97m2' + assert serpent_depcode.convert_nuclide_code_to_name('491142') == 'In114m2' def test_read_step_metadata(serpent_depcode): From 475ff1fe88d3ea485d8c25674c433091e548ec30 Mon Sep 17 00:00:00 2001 From: yardasol Date: Sat, 26 Nov 2022 11:51:43 -0600 Subject: [PATCH 09/34] change_sim_par() -> apply_neutron_settings(); cleanup read_plaintext_file() --- saltproc/serpent_depcode.py | 53 +++++++++---------- .../file_interface_serpent/test.py | 2 +- 2 files changed, 26 insertions(+), 29 deletions(-) diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 05fdddc4d..f6b5a6b8e 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -69,39 +69,36 @@ def __init__(self, self.iter_inputfile = './serpent_iter_input.serpent' self.iter_matfile = './serpent_iter_mat.ini' - def change_sim_par(self, template_data): - """Finds simulation parameters (neutron population, cycles) in the - Serpent2 template file and change them to the parameters from the - SaltProc input file. + def apply_neutron_settings(self, file_lines): + """Apply neutron settings (no. of neutrons per cycle, no. of active and + inactive cycles) from the SaltProc input file to the runtime Serpent2 + input file. Parameters ---------- - template_data : list - List of strings parsed from user's Serpent2 template file. + file_lines : list of str + Serpent2 runtime input file. Returns ------- - input_data : list - List of strings containing Serpent2 input file with new - simulation parameters. + file_lines : list of str + Serpent2 runtime input file with updated neutron settings. """ if self.npop and self.active_cycles and self.inactive_cycles: - sim_param = [s for s in template_data if s.startswith("set pop")] - if len(sim_param) > 1: - print('ERROR: Template file %s contains multiple lines with ' - 'simulation parameters:\n' - % (self.template_input_file_path), sim_param) - return - elif len(sim_param) < 1: - print( - 'ERROR: Template file %s does not contain line with ' - 'simulation parameters.' % - (self.template_input_file_path)) - return + neutron_settings = \ + [line for line in file_lines if line.startswith("set pop")] + if len(neutron_settings) > 1: + raise(IOError('Template file' + f'{self.template_input_file_path} contains')) + 'multuple lines with neutron settings' + elif len(neutron_settings) < 1: + raise(IOError('Template file' + f'{self.template_input_file_path} does not' + 'contain neutron settings.')) args = 'set pop %i %i %i\n' % (self.npop, self.active_cycles, self.inactive_cycles) - return [s.replace(sim_param[0], args) for s in template_data] + return [line.replace(neutron_settings[0], args) for line in file_lines] def create_iter_matfile(self, template_data): """Finds ``include`` line with path to material file, copies content of @@ -356,14 +353,14 @@ def read_plaintext_file(self, file_path): Returns ------- - file_data : list - List of strings containing file lines. + file_lines : list of str + File lines. """ - template_data = [] + file_lines with open(file_path, 'r') as file: - template_data = file.readlines() - return template_data + file_lines = file.readlines() + return file_lines def replace_burnup_parameters( self, @@ -510,7 +507,7 @@ def write_depcode_input(self, reactor, dep_step, restart): if dep_step == 0 and not restart: data = self.read_plaintext_file(self.template_input_file_path) data = self.insert_path_to_geometry(data) - data = self.change_sim_par(data) + data = self.apply_neutron_settings(data) data = self.create_iter_matfile(data) else: data = self.read_plaintext_file(self.iter_inputfile) diff --git a/tests/integration_tests/file_interface_serpent/test.py b/tests/integration_tests/file_interface_serpent/test.py index cdd84754f..ba4990994 100644 --- a/tests/integration_tests/file_interface_serpent/test.py +++ b/tests/integration_tests/file_interface_serpent/test.py @@ -27,7 +27,7 @@ def test_iter_input_from_template(serpent_depcode, msr): file_data = serpent_depcode.read_plaintext_file(file) # change_sim_par - file_data = serpent_depcode.change_sim_par(file_data) + file_data = serpent_depcode.apply_neutron_settings(file_data) assert file_data[18] == 'set pop %i %i %i\n' % ( serpent_depcode.npop, serpent_depcode.active_cycles, From 9ab1823ea18db0fbf1c516b2ed8f4e08b2c63afe Mon Sep 17 00:00:00 2001 From: yardasol Date: Sat, 26 Nov 2022 12:37:29 -0600 Subject: [PATCH 10/34] create_iter_matfile() -> create_runtime_matfile() --- doc/releasenotes/v0.5.0.rst | 2 + saltproc/serpent_depcode.py | 65 +++++++++---------- .../file_interface_serpent/test.py | 4 +- 3 files changed, 35 insertions(+), 36 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index eff21fa2e..4e8280b21 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -136,6 +136,8 @@ Python API Changes - ``write_mat_file()`` → ``update_depletable_materials()`` - ``get_nuc_name()`` → ``convert_nuclide_code_to_name()`` - ``convert_nuclide_name_serpent_to_zam()`` → ``convert_nuclide_code_to_zam()`` + - ``change_sim_par()`` → ``apply_neutron_settings()`` + - ``create_iter_matfile()`` → ``create_runtime_matfile()`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - ``run_depletion_step()`` diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index f6b5a6b8e..c6685979b 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -1,3 +1,4 @@ +from pathlib import Path import subprocess import os import shutil @@ -89,59 +90,55 @@ def apply_neutron_settings(self, file_lines): neutron_settings = \ [line for line in file_lines if line.startswith("set pop")] if len(neutron_settings) > 1: - raise(IOError('Template file' - f'{self.template_input_file_path} contains')) - 'multuple lines with neutron settings' + raise IOError('Template file ' + f'{self.template_input_file_path} contains ' + 'multuple lines with neutron settings') elif len(neutron_settings) < 1: - raise(IOError('Template file' - f'{self.template_input_file_path} does not' - 'contain neutron settings.')) + raise IOError('Template file ' + f'{self.template_input_file_path} does not ' + 'contain neutron settings.') args = 'set pop %i %i %i\n' % (self.npop, self.active_cycles, self.inactive_cycles) return [line.replace(neutron_settings[0], args) for line in file_lines] - def create_iter_matfile(self, template_data): - """Finds ``include`` line with path to material file, copies content of - this file to iteration material file, changes path in ``include`` line - to newly created iteration material file. + def create_runtime_matfile(self, file_lines): + """Creates the runtime material file tracking burnable materials + ans inserts the path to this file in the Serpent2 runtime input file Parameters ---------- - template_data : list - List of strings parsed from user's template file. + file_lines : list of str + Serpent2 runtime input file. Returns ------- - input_data : list - List of strings containing modified user template file. + file_lines : list of str + Serpent2 runtime input file with updated material file path. """ - data_dir = os.path.dirname(self.template_input_file_path) - include_str = [s for s in template_data if s.startswith("include ")] + runtime_dir = Path(self.template_input_file_path).parents[0] + include_str = [line for line in file_lines if line.startswith("include ")] if not include_str: - print('ERROR: Template file %s has no ' - ' statements ' % (self.template_input_file_path)) - return + raise IOError('Template file ' + f'{self.template_input_file_path} has no statements') src_file = include_str[0].split()[1][1:-1] - if not os.path.isabs(src_file): - abs_src_matfile = os.path.normpath(data_dir) + '/' + src_file + if not Path(src_file).is_absolute(): + abs_src_matfile = (runtime_dir / src_file) else: - abs_src_matfile = src_file - if 'mat ' not in open(abs_src_matfile).read(): - print('ERROR: Template file %s has not include file with' - ' materials description or ' - ' statement is not appears' - ' as first statement\n' - % (self.template_input_file_path)) - return + abs_src_matfile = Path(src_file) + with open(abs_src_matfile) as f: + if 'mat ' not in f.read(): + raise IOError('Template file ' + f'{self.template_input_file_path} includes ' + 'no file with materials description') # Create data directory try: - os.mkdir(os.path.dirname(self.iter_matfile)) - except FileExistsError: - pass + Path.mkdir(Path(self.iter_matfile).parents[0], exist_ok=True) + # Create file with path for SaltProc rewritable iterative material file shutil.copy2(abs_src_matfile, self.iter_matfile) - return [s.replace(src_file, self.iter_matfile) for s in template_data] + return [line.replace(src_file, self.iter_matfile) for line in file_lines] def convert_nuclide_code_to_name(self, nuc_code): """Converts Serpent2 nuclide code to symbolic nuclide name. @@ -508,7 +505,7 @@ def write_depcode_input(self, reactor, dep_step, restart): data = self.read_plaintext_file(self.template_input_file_path) data = self.insert_path_to_geometry(data) data = self.apply_neutron_settings(data) - data = self.create_iter_matfile(data) + data = self.create_runtime_matfile(data) else: data = self.read_plaintext_file(self.iter_inputfile) data = self.replace_burnup_parameters(data, reactor, dep_step) diff --git a/tests/integration_tests/file_interface_serpent/test.py b/tests/integration_tests/file_interface_serpent/test.py index ba4990994..32916d001 100644 --- a/tests/integration_tests/file_interface_serpent/test.py +++ b/tests/integration_tests/file_interface_serpent/test.py @@ -37,8 +37,8 @@ def test_iter_input_from_template(serpent_depcode, msr): file_data = serpent_depcode.insert_path_to_geometry(file_data) assert file_data[5].split('/')[-1] == 'tap_geometry_base.ini"\n' - # create_iter_matfile - file_data = serpent_depcode.create_iter_matfile(file_data) + # create_runtime_matfile + file_data = serpent_depcode.create_runtime_matfile(file_data) assert file_data[0].split()[-1] == '\"' + \ serpent_depcode.iter_matfile + '\"' remove(serpent_depcode.iter_matfile) From abc61f3b73561e3cc1c636b49044c95fafe6d40a Mon Sep 17 00:00:00 2001 From: yardasol Date: Sat, 26 Nov 2022 13:02:44 -0600 Subject: [PATCH 11/34] replace_burnup_parameters() -> set_power_load() --- doc/releasenotes/v0.5.0.rst | 1 + saltproc/serpent_depcode.py | 46 +++++++++---------- .../file_interface_serpent/test.py | 6 +-- 3 files changed, 24 insertions(+), 29 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index 4e8280b21..7c803c5e2 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -138,6 +138,7 @@ Python API Changes - ``convert_nuclide_name_serpent_to_zam()`` → ``convert_nuclide_code_to_zam()`` - ``change_sim_par()`` → ``apply_neutron_settings()`` - ``create_iter_matfile()`` → ``create_runtime_matfile()`` + - ``replace_burnup_parameters()`` → ``set_power_load()`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - ``run_depletion_step()`` diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index c6685979b..c91d81de4 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -133,8 +133,7 @@ def create_runtime_matfile(self, file_lines): f'{self.template_input_file_path} includes ' 'no file with materials description') # Create data directory - try: - Path.mkdir(Path(self.iter_matfile).parents[0], exist_ok=True) + Path.mkdir(Path(self.iter_matfile).parents[0], exist_ok=True) # Create file with path for SaltProc rewritable iterative material file shutil.copy2(abs_src_matfile, self.iter_matfile) @@ -354,25 +353,23 @@ def read_plaintext_file(self, file_path): File lines. """ - file_lines + file_lines = [] with open(file_path, 'r') as file: file_lines = file.readlines() return file_lines - def replace_burnup_parameters( - self, - template_data, - reactor, - current_depstep_idx): - """Adds or replaces the ``set power P dep daystep DEPSTEP`` line in - the Serpent2 input file. This line defines depletion history and power - levels with respect to the depletion step in the single run and - activates depletion calculation mode. + def set_power_load(self, + file_lines, + reactor, + current_depstep_idx): + """Add power load attributes in a :class:`Reactor` object to the + ``set power P dep daystep DEPSTEP`` line in the Serpent2 runtime input + file. Parameters ---------- - template_data : list - List of strings parsed from user template file. + file_lines : list of str + Serpent2 runtime input file. reactor : Reactor Contains information about power load curve and cumulative depletion time for the integration test. @@ -381,8 +378,8 @@ def replace_burnup_parameters( Returns ------- - template_data : list - List of strings containing modified in this function template file. + file_lines : list of str + Serpent2 runtime input file with power load specification. """ @@ -394,16 +391,15 @@ def replace_burnup_parameters( current_depstep = \ reactor.dep_step_length_cumulative[current_depstep_idx] - \ reactor.dep_step_length_cumulative[current_depstep_idx - 1] - for line in template_data: + for line in file_lines: if line.startswith('set power '): - line_idx = template_data.index(line) - del template_data[line_idx] + line_idx = file_lines.index(line) + del file_lines[line_idx] - template_data.insert(line_idx, # Insert on 9th line - 'set power %5.9E dep daystep %7.5E\n' % - (current_depstep_power, - current_depstep)) - return template_data + file_lines.insert(line_idx, # Insert on 9th line + 'set power %5.9E dep daystep %7.5E\n' % + (current_depstep_power, current_depstep)) + return file_lines def run_depletion_step(self, cores, nodes): """Runs a depletion step in Serpent2 as a subprocess with the given @@ -508,7 +504,7 @@ def write_depcode_input(self, reactor, dep_step, restart): data = self.create_runtime_matfile(data) else: data = self.read_plaintext_file(self.iter_inputfile) - data = self.replace_burnup_parameters(data, reactor, dep_step) + data = self.set_power_load(data, reactor, dep_step) if data: out_file = open(self.iter_inputfile, 'w') diff --git a/tests/integration_tests/file_interface_serpent/test.py b/tests/integration_tests/file_interface_serpent/test.py index 32916d001..2c332e9bc 100644 --- a/tests/integration_tests/file_interface_serpent/test.py +++ b/tests/integration_tests/file_interface_serpent/test.py @@ -43,14 +43,12 @@ def test_iter_input_from_template(serpent_depcode, msr): serpent_depcode.iter_matfile + '\"' remove(serpent_depcode.iter_matfile) - # replace_burnup_parameters + # set_power_load time = msr.dep_step_length_cumulative.copy() time.insert(0, 0.0) depsteps = np.diff(time) for idx in range(len(msr.power_levels)): - file_data = serpent_depcode.replace_burnup_parameters(file_data, - msr, - idx) + file_data = serpent_depcode.set_power_load(file_data, msr, idx) assert file_data[8].split()[4] == 'daystep' assert file_data[8].split()[2] == str("%5.9E" % msr.power_levels[idx]) From 69ee50d0833688cf23453c925925f3b55db92843 Mon Sep 17 00:00:00 2001 From: yardasol Date: Sat, 26 Nov 2022 13:09:10 -0600 Subject: [PATCH 12/34] cleanup switch_to_next_geometry() --- saltproc/serpent_depcode.py | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index c91d81de4..1925a4c0f 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -462,11 +462,10 @@ def switch_to_next_geometry(self): beginning of the Serpent iteration input file. """ geo_line_n = 5 - f = open(self.iter_inputfile, 'r') - data = f.readlines() - f.close() + with open(self.iter_inputfile, 'r') as f: + lines = f.readlines() - current_geo_file = data[geo_line_n].split('\"')[1] + current_geo_file = lines[geo_line_n].split('\"')[1] current_geo_idx = self.geo_files.index(current_geo_file) try: new_geo_file = self.geo_files[current_geo_idx + 1] @@ -474,13 +473,13 @@ def switch_to_next_geometry(self): print('No more geometry files available \ and the system went subcritical \n\n') print('Aborting simulation') - return - new_data = [d.replace(current_geo_file, new_geo_file) for d in data] + + new_lines = \ + [line.replace(current_geo_file, new_geo_file) for line in lines] print('Switching to next geometry file: ', new_geo_file) - f = open(self.iter_inputfile, 'w') - f.writelines(new_data) - f.close() + with open(self.iter_inputfile, 'w') as f: + f.writelines(new_lines) def write_depcode_input(self, reactor, dep_step, restart): """Writes prepared data into the Serpent2 input file. From be590375d809a6cf5bdbc90659cc92928c318eb6 Mon Sep 17 00:00:00 2001 From: yardasol Date: Sat, 26 Nov 2022 13:13:22 -0600 Subject: [PATCH 13/34] cleanup insert_path_to_geometry() --- saltproc/serpent_depcode.py | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 1925a4c0f..844440882 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -223,25 +223,24 @@ def map_nuclide_code_zam_to_serpent(self): nuc_code_map.update({zzaaam: line[2]}) return nuc_code_map - def insert_path_to_geometry(self, template_data): + def insert_path_to_geometry(self, lines): """Inserts ``include `` line on the 6th line of Serpent2 input file. Parameters ---------- - template_data : list - List of strings parsed from user's template file. + lines : list of str + Serpent2 runtime input file. Returns ------- - template_data : list - List of strings containing modified path to geometry - in user's template file. + lines : list of str + Serpent 2 runtime input file containing modified path to geometry """ - template_data.insert(5, # Inserts on 6th line + lines.insert(5, # Inserts on 6th line 'include \"' + str(self.geo_files[0]) + '\"\n') - return template_data + return lines def read_depleted_materials(self, read_at_end=False): """Reads depleted materials from Serpent2's `*_dep.m` From f5aec4e873b137737af0bd8b3789c9cee12d8772 Mon Sep 17 00:00:00 2001 From: yardasol Date: Sat, 26 Nov 2022 13:21:23 -0600 Subject: [PATCH 14/34] write_depcode_input() -> write_depletion_step_input() --- doc/releasenotes/v0.5.0.rst | 3 +++ saltproc/abc.py | 4 ++-- saltproc/openmc_depcode.py | 4 ++-- saltproc/serpent_depcode.py | 22 +++++++++---------- .../file_interface_openmc/test.py | 8 +++---- .../file_interface_serpent/test.py | 8 +++---- 6 files changed, 25 insertions(+), 24 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index 7c803c5e2..d816c3644 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -121,6 +121,7 @@ Python API Changes - ``read_dep_comp()`` → ``read_depleted_materials()`` - ``run_depcode()`` → ``run_depletion_step()`` - ``write_mat_file()`` → ``update_depletable_materials()`` + - ``write_depcode_input()`` → ``write_depletion_step_input()`` - ``DepcodeSerpent`` → ``SerpentDepcode`` @@ -139,6 +140,7 @@ Python API Changes - ``change_sim_par()`` → ``apply_neutron_settings()`` - ``create_iter_matfile()`` → ``create_runtime_matfile()`` - ``replace_burnup_parameters()`` → ``set_power_load()`` + - ``write_depcode_input()`` → ``write_depletion_step_input()`` - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - ``run_depletion_step()`` @@ -146,6 +148,7 @@ Python API Changes - ``write_depcode_input()`` - ``write_depletion_settings()`` - ``write_saltproc_openmc_tallies()`` + - ``write_depcode_input()`` → ``write_depletion_step_input()`` - ``app.py`` diff --git a/saltproc/abc.py b/saltproc/abc.py index f17dc8e9b..75ca1f0a3 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -124,8 +124,8 @@ def switch_to_next_geometry(self): """ @abstractmethod - def write_depcode_input(self, reactor, dep_step, restart): - """Writes prepared data into depletion code input file(s). + def write_depletion_step_input(self, reactor, dep_step, restart): + """Write input file(s) for running depletion step Parameters ---------- diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 9d4cfb184..fdbbeae11 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -167,8 +167,8 @@ def switch_to_next_geometry(self): next_geometry.export_to_xml(path=self.iter_inputfile['geometry']) del mats, next_geometry - def write_depcode_input(self, reactor, dep_step, restart): - """ Writes prepared data into OpenMC input file(s). + def write_depletion_step_input(self, reactor, dep_step, restart): + """Write OpenMC input files for running depletion step. Parameters ---------- diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 844440882..cf56975a2 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -480,8 +480,8 @@ def switch_to_next_geometry(self): with open(self.iter_inputfile, 'w') as f: f.writelines(new_lines) - def write_depcode_input(self, reactor, dep_step, restart): - """Writes prepared data into the Serpent2 input file. + def write_depletion_step_input(self, reactor, dep_step, restart): + """Write Serpent2 input file for running depletion step Parameters ---------- @@ -496,18 +496,16 @@ def write_depcode_input(self, reactor, dep_step, restart): """ if dep_step == 0 and not restart: - data = self.read_plaintext_file(self.template_input_file_path) - data = self.insert_path_to_geometry(data) - data = self.apply_neutron_settings(data) - data = self.create_runtime_matfile(data) + lines = self.read_plaintext_file(self.template_input_file_path) + lines = self.insert_path_to_geometry(lines) + lines = self.apply_neutron_settings(lines) + lines = self.create_runtime_matfile(lines) else: - data = self.read_plaintext_file(self.iter_inputfile) - data = self.set_power_load(data, reactor, dep_step) + lines = self.read_plaintext_file(self.iter_inputfile) + lines = self.set_power_load(lines, reactor, dep_step) - if data: - out_file = open(self.iter_inputfile, 'w') - out_file.writelines(data) - out_file.close() + with open(self.iter_inputfile, 'w') as out_file + out_file.writelines(lines) def update_depletable_materials(self, mats, dep_end_time): """Update material file with reprocessed material compositions. diff --git a/tests/integration_tests/file_interface_openmc/test.py b/tests/integration_tests/file_interface_openmc/test.py index c32f8931f..7a01c072d 100644 --- a/tests/integration_tests/file_interface_openmc/test.py +++ b/tests/integration_tests/file_interface_openmc/test.py @@ -22,7 +22,7 @@ def msr(scope='module'): return reactor -def test_write_depcode_input(openmc_depcode, msr): +def test_write_depletion_step_input(openmc_depcode, msr): # OpenMC input_materials = openmc.Materials.from_xml( openmc_depcode.template_input_file_path['materials']) @@ -35,9 +35,9 @@ def test_write_depcode_input(openmc_depcode, msr): input_surfaces = input_geometry.get_all_surfaces() input_universes = input_geometry.get_all_universes() - openmc_depcode.write_depcode_input(msr, - 0, - False) + openmc_depcode.write_depletion_step_input(msr, + 0, + False) # Load in the iter_ objects iter_materials = openmc.Materials.from_xml(openmc_depcode.iter_matfile) iter_geometry = openmc.Geometry.from_xml( diff --git a/tests/integration_tests/file_interface_serpent/test.py b/tests/integration_tests/file_interface_serpent/test.py index 2c332e9bc..bf6e8f049 100644 --- a/tests/integration_tests/file_interface_serpent/test.py +++ b/tests/integration_tests/file_interface_serpent/test.py @@ -74,10 +74,10 @@ def test_write_iter_files(serpent_depcode, msr): assert file_data[4] == ' 1001.09c -1.21000137902945E-35\n' remove(serpent_depcode.iter_matfile) - # write_depcode_input - serpent_depcode.write_depcode_input(msr, - 0, - False) + # write_depletion_step_input + serpent_depcode.write_depletion_step_input(msr, + 0, + False) file = serpent_depcode.iter_inputfile file_data = serpent_depcode.read_plaintext_file(file) From 87fed8156e42e1db41f1ec4790660cdfb28b66b6 Mon Sep 17 00:00:00 2001 From: yardasol Date: Sat, 26 Nov 2022 14:36:26 -0600 Subject: [PATCH 15/34] attribute name change: iter_* -> runtime_* --- doc/releasenotes/v0.5.0.rst | 8 +++ saltproc/abc.py | 14 ++--- saltproc/app.py | 10 ++-- saltproc/openmc_depcode.py | 55 +++++++++---------- saltproc/serpent_depcode.py | 41 +++++++------- saltproc/simulation.py | 4 +- tests/conftest.py | 14 ++--- .../file_interface_openmc/test.py | 50 ++++++++--------- .../file_interface_serpent/test.py | 18 +++--- .../run_no_reprocessing/test.py | 4 +- 10 files changed, 113 insertions(+), 105 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index d816c3644..fb9a087d8 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -122,6 +122,8 @@ Python API Changes - ``run_depcode()`` → ``run_depletion_step()`` - ``write_mat_file()`` → ``update_depletable_materials()`` - ``write_depcode_input()`` → ``write_depletion_step_input()`` + - ``iter_inputfile`` → ``runtime_inputfile`` + - ``iter_matfile`` → ``runtime_matfile`` - ``DepcodeSerpent`` → ``SerpentDepcode`` @@ -141,6 +143,9 @@ Python API Changes - ``create_iter_matfile()`` → ``create_runtime_matfile()`` - ``replace_burnup_parameters()`` → ``set_power_load()`` - ``write_depcode_input()`` → ``write_depletion_step_input()`` + - ``iter_inputfile`` → ``runtime_inputfile`` + - ``iter_matfile`` → ``runtime_matfile`` + - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - ``run_depletion_step()`` @@ -149,6 +154,9 @@ Python API Changes - ``write_depletion_settings()`` - ``write_saltproc_openmc_tallies()`` - ``write_depcode_input()`` → ``write_depletion_step_input()`` + - ``iter_inputfile`` → ``runtime_inputfile`` + - ``iter_matfile`` → ``runtime_matfile`` + - ``app.py`` diff --git a/saltproc/abc.py b/saltproc/abc.py index 75ca1f0a3..a3e9951ca 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -15,11 +15,11 @@ class Depcode(ABC): step_metadata : dict of str to type Holds depletion code depletion step metadata. Metadata labels are keys and metadata values are values. - iter_inputfile : str - Path to depletion code input file for depletion code rerunning. - iter_matfile : str - Path to iterative, rewritable material file for depletion code - rerunning. This file is modified during the simulation. + runtime_inputfile : str + Path to input file used to run depletion step. + runtime_matfile : str + Path to material file containing burnable materials used to + run depletion step. """ @@ -65,8 +65,8 @@ def __init__(self, self.inactive_cycles = inactive_cycles self.neutronics_parameters = {} self.step_metadata = {} - self.iter_inputfile = './iter_input' - self.iter_matfile = './iter_mat' + self.runtime_inputfile = './runtime_input' + self.runtime_matfile = './runtime_mat' @abstractmethod def read_step_metadata(self): diff --git a/saltproc/app.py b/saltproc/app.py index a174ba31f..512e47d25 100644 --- a/saltproc/app.py +++ b/saltproc/app.py @@ -26,14 +26,14 @@ def run(): object_input[1], depcode, cores, nodes) msr = _create_reactor_object(object_input[2]) - if isinstance(depcode.iter_inputfile, str): - depcode.iter_inputfile = (input_path / - depcode.iter_inputfile).resolve().as_posix() + if isinstance(depcode.runtime_inputfile, str): + depcode.runtime_inputfile = (input_path / + depcode.runtime_inputfile).resolve().as_posix() else: raise ValueError("not implemented") - depcode.iter_matfile = ( + depcode.runtime_matfile = ( input_path / - depcode.iter_matfile).resolve().as_posix() + depcode.runtime_matfile).resolve().as_posix() # Check: Restarting previous simulation or starting new? simulation.check_restart() # Run sequence diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index fdbbeae11..9d18cc80a 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -26,13 +26,12 @@ class OpenMCDepcode(Depcode): step_metadata : dict of str to type Holds OpenMC depletion step metadata. Metadata labels are keys and metadata values are values. - iter_inputfile : dict of str to str - Paths to OpenMC input files for OpenMC rerunning. - iter_matfile : str - Path to iterative, rewritable material file for OpenMC - rerunning. This file is modified during the simulation. - - + runtime_inputfile : dict of str to str + Paths to OpenMC input files used to run depletion step. Contains neutron + settings and geometry. + runtime_matfile : str + Path to OpenMC material file containing materials used to + run depletion step, and modified after fuel reprocessing. """ @@ -75,9 +74,9 @@ def __init__(self, npop, active_cycles, inactive_cycles) - self.iter_inputfile = {'geometry': './geometry.xml', + self.runtime_inputfile = {'geometry': './geometry.xml', 'settings': './settings.xml'}, - self.iter_matfile = './materials.xml' + self.runtime_matfile = './materials.xml' def read_step_metadata(self): """Reads OpenMC's depletion step metadata and stores it in the @@ -133,15 +132,15 @@ def run_depletion_step(self, cores, nodes): 'python', './deplete_openmc.py' '-mat', - self.iter_matfile, + self.runtime_matfile, '-geo', - self.iter_inputfile['geometry'], + self.runtime_inputfile['geometry'], '-set', - self.iter_inputfile['settings'], + self.runtime_inputfile['settings'], '-tal', - self.iter_inputfile['tallies'], + self.runtime_inputfile['tallies'], '-dep', - self.iter_inputfile['depletion_settings']) + self.runtime_inputfile['depletion_settings']) print('Running %s' % (self.codename)) # TODO: Need to figure out how to adapt this to openmc @@ -160,11 +159,11 @@ def switch_to_next_geometry(self): """Switches the geometry file for the OpenMC depletion simulation to the next geometry file in `geo_files`. """ - mats = openmc.Materials.from_xml(self.iter_matfile) + mats = openmc.Materials.from_xml(self.runtime_matfile) next_geometry = openmc.Geometry.from_xml( path=self.geo_files.pop(0), materials=mats) - next_geometry.export_to_xml(path=self.iter_inputfile['geometry']) + next_geometry.export_to_xml(path=self.runtime_inputfile['geometry']) del mats, next_geometry def write_depletion_step_input(self, reactor, dep_step, restart): @@ -192,15 +191,15 @@ def write_depletion_step_input(self, reactor, dep_step, restart): settings.inactive = self.inactive_cycles settings.batches = self.active_cycles + self.inactive_cycles else: - materials = openmc.Materials.from_xml(self.iter_matfile) + materials = openmc.Materials.from_xml(self.runtime_matfile) geometry = openmc.Geometry.from_xml( - self.iter_inputfile['geometry'], materials=materials) + self.runtime_inputfile['geometry'], materials=materials) settings = openmc.Settings.from_xml( - self.iter_inputfile['settings']) + self.runtime_inputfile['settings']) - materials.export_to_xml(self.iter_matfile) - geometry.export_to_xml(self.iter_inputfile['geometry']) - settings.export_to_xml(self.iter_inputfile['settings']) + materials.export_to_xml(self.runtime_matfile) + geometry.export_to_xml(self.runtime_inputfile['geometry']) + settings.export_to_xml(self.runtime_inputfile['settings']) self.write_depletion_settings(reactor, dep_step) self.write_saltproc_openmc_tallies(materials, geometry) del materials, geometry, settings @@ -229,7 +228,7 @@ def write_depletion_settings(self, reactor, current_depstep_idx): reactor.dep_step_length_cumulative[current_depstep_idx] - \ reactor.dep_step_length_cumulative[current_depstep_idx - 1] - out_path = os.path.dirname(self.iter_inputfile['settings']) + out_path = os.path.dirname(self.runtime_inputfile['settings']) depletion_settings['directory'] = out_path depletion_settings['timesteps'] = [current_depstep] @@ -249,10 +248,10 @@ def write_depletion_settings(self, reactor, current_depstep_idx): depletion_settings['operator_kwargs'] = operator_kwargs depletion_settings['integrator_kwargs'] = integrator_kwargs - self.iter_inputfile['depletion_settings'] = \ + self.runtime_inputfile['depletion_settings'] = \ os.path.join(out_path, 'depletion_settings.json') json_dep_settings = json.JSONEncoder().encode(depletion_settings) - with open(self.iter_inputfile['depletion_settings'], 'w') as f: + with open(self.runtime_inputfile['depletion_settings'], 'w') as f: f.writelines(json_dep_settings) def update_depletable_materials(self, mats, dep_end_time): @@ -315,10 +314,10 @@ def write_saltproc_openmc_tallies(self, materials, geometry): tally.scores = ['heating'] tallies.append(tally) - out_path = os.path.dirname(self.iter_inputfile['settings']) - self.iter_inputfile['tallies'] = \ + out_path = os.path.dirname(self.runtime_inputfile['settings']) + self.runtime_inputfile['tallies'] = \ os.path.join(out_path, 'tallies.xml') - tallies.export_to_xml(self.iter_inputfile['tallies']) + tallies.export_to_xml(self.runtime_inputfile['tallies']) del tallies diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index cf56975a2..e11a5d075 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -25,11 +25,12 @@ class SerpentDepcode(Depcode): step_metadata : dict of str to type Holds Serpent2 depletion step metadata. Metadata labels are keys and metadata values are values. - iter_inputfile : str - Path to Serpent2 input file for Serpent2 rerunning. - iter_matfile : str - Path to iterative, rewritable material file for Serpent2 - rerunning. This file is modified during the simulation. + runtime_inputfile : str + Path to Serpent2 input file used to run depletion step. Contains neutron + settings and non-burnable materials. + runtime_matfile : str + Path to Serpent2 material file containing burnable materials used to + run depletion step, and modified after fuel reprocessing. """ @@ -67,8 +68,8 @@ def __init__(self, npop=npop, active_cycles=active_cycles, inactive_cycles=inactive_cycles) - self.iter_inputfile = './serpent_iter_input.serpent' - self.iter_matfile = './serpent_iter_mat.ini' + self.runtime_inputfile = './serpent_runtime_input.serpent' + self.runtime_matfile = './serpent_runtime_mat.ini' def apply_neutron_settings(self, file_lines): """Apply neutron settings (no. of neutrons per cycle, no. of active and @@ -133,11 +134,11 @@ def create_runtime_matfile(self, file_lines): f'{self.template_input_file_path} includes ' 'no file with materials description') # Create data directory - Path.mkdir(Path(self.iter_matfile).parents[0], exist_ok=True) + Path.mkdir(Path(self.runtime_matfile).parents[0], exist_ok=True) # Create file with path for SaltProc rewritable iterative material file - shutil.copy2(abs_src_matfile, self.iter_matfile) - return [line.replace(src_file, self.iter_matfile) for line in file_lines] + shutil.copy2(abs_src_matfile, self.runtime_matfile) + return [line.replace(src_file, self.runtime_matfile) for line in file_lines] def convert_nuclide_code_to_name(self, nuc_code): """Converts Serpent2 nuclide code to symbolic nuclide name. @@ -201,7 +202,7 @@ def map_nuclide_code_zam_to_serpent(self): """ nuc_code_map = {} # Construct path to the *.out File - out_file = os.path.join('%s.out' % self.iter_inputfile) + out_file = os.path.join('%s.out' % self.runtime_inputfile) with open(out_file, 'r') as f: file_lines = f.read().split('\n') # Stop-line @@ -270,7 +271,7 @@ def read_depleted_materials(self, read_at_end=False): else: moment = 0 - results_file = os.path.join('%s_dep.m' % self.iter_inputfile) + results_file = os.path.join('%s_dep.m' % self.runtime_inputfile) results = serpent.parse_dep(results_file, make_mats=False) self.days = results['DAYS'][moment] @@ -297,7 +298,7 @@ def read_step_metadata(self): """Reads Serpent2 depletion step metadata and stores it in the :class:`SerpentDepcode` object's :attr:`step_metadata` attribute. """ - res = serpent.parse_res(self.iter_inputfile + "_res.m") + res = serpent.parse_res(self.runtime_inputfile + "_res.m") depcode_name, depcode_ver = res['VERSION'][0].decode('utf-8').split() self.step_metadata['depcode_name'] = depcode_name self.step_metadata['depcode_version'] = depcode_ver @@ -321,7 +322,7 @@ def read_neutronics_parameters(self): in :class:`SerpentDepcode` object's :attr:`neutronics_parameters` attribute. """ - res = serpent.parse_res(self.iter_inputfile + "_res.m") + res = serpent.parse_res(self.runtime_inputfile + "_res.m") self.neutronics_parameters['keff_bds'] = res['IMP_KEFF'][0] self.neutronics_parameters['keff_eds'] = res['IMP_KEFF'][1] self.neutronics_parameters['breeding_ratio'] = \ @@ -413,7 +414,7 @@ def run_depletion_step(self, cores, nodes): """ - args = (self.exec_path, '-omp', str(cores), self.iter_inputfile) + args = (self.exec_path, '-omp', str(cores), self.runtime_inputfile) print('Running %s' % (self.codename)) try: subprocess.check_output( @@ -461,7 +462,7 @@ def switch_to_next_geometry(self): beginning of the Serpent iteration input file. """ geo_line_n = 5 - with open(self.iter_inputfile, 'r') as f: + with open(self.runtime_inputfile, 'r') as f: lines = f.readlines() current_geo_file = lines[geo_line_n].split('\"')[1] @@ -477,7 +478,7 @@ def switch_to_next_geometry(self): [line.replace(current_geo_file, new_geo_file) for line in lines] print('Switching to next geometry file: ', new_geo_file) - with open(self.iter_inputfile, 'w') as f: + with open(self.runtime_inputfile, 'w') as f: f.writelines(new_lines) def write_depletion_step_input(self, reactor, dep_step, restart): @@ -501,10 +502,10 @@ def write_depletion_step_input(self, reactor, dep_step, restart): lines = self.apply_neutron_settings(lines) lines = self.create_runtime_matfile(lines) else: - lines = self.read_plaintext_file(self.iter_inputfile) + lines = self.read_plaintext_file(self.runtime_inputfile) lines = self.set_power_load(lines, reactor, dep_step) - with open(self.iter_inputfile, 'w') as out_file + with open(self.runtime_inputfile, 'w') as out_file: out_file.writelines(lines) def update_depletable_materials(self, mats, dep_end_time): @@ -524,7 +525,7 @@ def update_depletable_materials(self, mats, dep_end_time): """ - with open(self.iter_matfile, 'w') as f: + with open(self.runtime_matfile, 'w') as f: f.write('%% Material compositions (after %f days)\n\n' % dep_end_time) nuc_code_map = self.map_nuclide_code_zam_to_serpent() diff --git a/saltproc/simulation.py b/saltproc/simulation.py index f9fc3f36c..fae69679f 100644 --- a/saltproc/simulation.py +++ b/saltproc/simulation.py @@ -83,8 +83,8 @@ def check_restart(self): if not self.restart_flag: try: os.remove(self.db_path) - os.remove(self.sim_depcode.iter_matfile) - os.remove(self.sim_depcode.iter_inputfile) + os.remove(self.sim_depcode.runtime_matfile) + os.remove(self.sim_depcode.runtime_inputfile) print("Previous run output files were deleted.") except OSError as e: pass diff --git a/tests/conftest.py b/tests/conftest.py index 0e79f3c35..10d55a243 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -28,7 +28,7 @@ def serpent_depcode(cwd): saltproc_input = (cwd / 'serpent_data' / 'tap_input.json').as_posix() _, _, _, object_input = read_main_input(saltproc_input) depcode = _create_depcode_object(object_input[0]) - depcode.iter_inputfile = (cwd / 'serpent_data' / 'tap_reference').as_posix() + depcode.runtime_inputfile = (cwd / 'serpent_data' / 'tap_reference').as_posix() return depcode @@ -43,17 +43,17 @@ def openmc_depcode(cwd): # Openmc initlialization openmc_input_path = (cwd / 'openmc_data') - openmc_iter_inputfiles = { + openmc_runtime_inputfiles = { "geometry": "geometry.xml", "settings": "settings.xml", } - for key in openmc_iter_inputfiles: - openmc_iter_inputfiles[key] = \ - (openmc_input_path / openmc_iter_inputfiles[key]).as_posix() + for key in openmc_runtime_inputfiles: + openmc_runtime_inputfiles[key] = \ + (openmc_input_path / openmc_runtime_inputfiles[key]).as_posix() - depcode.iter_inputfile = openmc_iter_inputfiles - depcode.iter_matfile = (openmc_input_path / 'materials.xml').as_posix() + depcode.runtime_inputfile = openmc_runtime_inputfiles + depcode.runtime_matfile = (openmc_input_path / 'materials.xml').as_posix() return depcode diff --git a/tests/integration_tests/file_interface_openmc/test.py b/tests/integration_tests/file_interface_openmc/test.py index 7a01c072d..37c86ff95 100644 --- a/tests/integration_tests/file_interface_openmc/test.py +++ b/tests/integration_tests/file_interface_openmc/test.py @@ -38,34 +38,34 @@ def test_write_depletion_step_input(openmc_depcode, msr): openmc_depcode.write_depletion_step_input(msr, 0, False) - # Load in the iter_ objects - iter_materials = openmc.Materials.from_xml(openmc_depcode.iter_matfile) - iter_geometry = openmc.Geometry.from_xml( - openmc_depcode.iter_inputfile['geometry'], - materials=iter_materials) - iter_settings = openmc.Settings.from_xml( - openmc_depcode.iter_inputfile['settings']) - - iter_cells = iter_geometry.get_all_cells() - iter_lattices = iter_geometry.get_all_lattices() - iter_surfaces = iter_geometry.get_all_surfaces() - iter_universes = iter_geometry.get_all_universes() + # Load in the runtime_ objects + runtime_materials = openmc.Materials.from_xml(openmc_depcode.runtime_matfile) + runtime_geometry = openmc.Geometry.from_xml( + openmc_depcode.runtime_inputfile['geometry'], + materials=runtime_materials) + runtime_settings = openmc.Settings.from_xml( + openmc_depcode.runtime_inputfile['settings']) + + runtime_cells = runtime_geometry.get_all_cells() + runtime_lattices = runtime_geometry.get_all_lattices() + runtime_surfaces = runtime_geometry.get_all_surfaces() + runtime_universes = runtime_geometry.get_all_universes() # an easier approach may just be to compare the # file contents themselves - assertion_dict = {'mat': (input_materials, iter_materials), - 'cells': (input_cells, iter_cells), - 'lattices': (input_lattices, iter_lattices), - 'surfs': (input_surfaces, iter_surfaces), - 'univs': (input_universes, iter_universes)} + assertion_dict = {'mat': (input_materials, runtime_materials), + 'cells': (input_cells, runtime_cells), + 'lattices': (input_lattices, runtime_lattices), + 'surfs': (input_surfaces, runtime_surfaces), + 'univs': (input_universes, runtime_universes)} _check_openmc_iterables_equal(assertion_dict) - assert iter_settings.inactive == openmc_depcode.inactive_cycles - assert iter_settings.batches == openmc_depcode.active_cycles + \ + assert runtime_settings.inactive == openmc_depcode.inactive_cycles + assert runtime_settings.batches == openmc_depcode.active_cycles + \ openmc_depcode.inactive_cycles - assert iter_settings.particles == openmc_depcode.npop + assert runtime_settings.particles == openmc_depcode.npop - del iter_materials, iter_geometry + del runtime_materials, runtime_geometry del input_materials, input_geometry @@ -74,10 +74,10 @@ def test_write_depletion_settings(openmc_depcode, msr): Unit test for `Depcodeopenmc_depcode.write_depletion_settings` """ openmc_depcode.write_depletion_settings(msr, 0) - with open(openmc_depcode.iter_inputfile['depletion_settings']) as f: + with open(openmc_depcode.runtime_inputfile['depletion_settings']) as f: j = json.load(f) assert j['directory'] == Path( - openmc_depcode.iter_inputfile['settings']).parents[0].as_posix() + openmc_depcode.runtime_inputfile['settings']).parents[0].as_posix() assert j['timesteps'][0] == msr.dep_step_length_cumulative[0] assert j['operator_kwargs']['chain_file'] == \ openmc_depcode.template_input_file_path['chain_file'] @@ -96,7 +96,7 @@ def test_write_saltproc_openmc_tallies(openmc_depcode): openmc_depcode.geo_files[0], mat) openmc_depcode.write_saltproc_openmc_tallies(mat, geo) del mat, geo - tallies = openmc.Tallies.from_xml(openmc_depcode.iter_inputfile['tallies']) + tallies = openmc.Tallies.from_xml(openmc_depcode.runtime_inputfile['tallies']) # now write asserts statements based on the openmc_depcode.Tallies API and # what we expect our tallies to be @@ -140,7 +140,7 @@ def test_switch_to_next_geometry(openmc_depcode): openmc_depcode.switch_to_next_geometry() switched_geometry = openmc.Geometry.from_xml( - openmc_depcode.iter_inputfile['geometry'], mat) + openmc_depcode.runtime_inputfile['geometry'], mat) switched_cells = switched_geometry.get_all_cells() switched_lattices = switched_geometry.get_all_lattices() diff --git a/tests/integration_tests/file_interface_serpent/test.py b/tests/integration_tests/file_interface_serpent/test.py index bf6e8f049..7aec2473d 100644 --- a/tests/integration_tests/file_interface_serpent/test.py +++ b/tests/integration_tests/file_interface_serpent/test.py @@ -22,7 +22,7 @@ def msr(scope='module'): return reactor -def test_iter_input_from_template(serpent_depcode, msr): +def test_runtime_input_from_template(serpent_depcode, msr): file = serpent_depcode.template_input_file_path file_data = serpent_depcode.read_plaintext_file(file) @@ -40,8 +40,8 @@ def test_iter_input_from_template(serpent_depcode, msr): # create_runtime_matfile file_data = serpent_depcode.create_runtime_matfile(file_data) assert file_data[0].split()[-1] == '\"' + \ - serpent_depcode.iter_matfile + '\"' - remove(serpent_depcode.iter_matfile) + serpent_depcode.runtime_matfile + '\"' + remove(serpent_depcode.runtime_matfile) # set_power_load time = msr.dep_step_length_cumulative.copy() @@ -55,12 +55,12 @@ def test_iter_input_from_template(serpent_depcode, msr): assert file_data[8].split()[5] == str("%7.5E" % depsteps[idx]) -def test_write_iter_files(serpent_depcode, msr): +def test_write_runtime_files(serpent_depcode, msr): mats = serpent_depcode.read_depleted_materials(True) # update_depletable_materials serpent_depcode.update_depletable_materials(mats, 12.0) - file = serpent_depcode.iter_matfile + file = serpent_depcode.runtime_matfile file_data = serpent_depcode.read_plaintext_file(file) assert file_data[0] == '% Material compositions (after 12.000000 days)\n' if 'fuel' in file_data[3]: @@ -72,16 +72,16 @@ def test_write_iter_files(serpent_depcode, msr): elif 'ctrlPois' in file_data[3]: assert file_data[3].split()[-1] == '1.11635E+04' assert file_data[4] == ' 1001.09c -1.21000137902945E-35\n' - remove(serpent_depcode.iter_matfile) + remove(serpent_depcode.runtime_matfile) # write_depletion_step_input serpent_depcode.write_depletion_step_input(msr, 0, False) - file = serpent_depcode.iter_inputfile + file = serpent_depcode.runtime_inputfile file_data = serpent_depcode.read_plaintext_file(file) - assert file_data[0] == 'include "./serpent_iter_mat.ini"\n' + assert file_data[0] == 'include "./serpent_runtime_mat.ini"\n' assert file_data[8].split()[2] == '1.250000000E+09' assert file_data[8].split()[4] == 'daystep' assert file_data[8].split()[-1] == '1.11111E+02' @@ -94,4 +94,4 @@ def test_write_iter_files(serpent_depcode, msr): file_data = serpent_depcode.read_plaintext_file(file) assert file_data[5].split('/')[-1] == '406.inp"\n' - remove(serpent_depcode.iter_inputfile) + remove(serpent_depcode.runtime_inputfile) diff --git a/tests/integration_tests/run_no_reprocessing/test.py b/tests/integration_tests/run_no_reprocessing/test.py index ba66bcd1d..689dbed47 100644 --- a/tests/integration_tests/run_no_reprocessing/test.py +++ b/tests/integration_tests/run_no_reprocessing/test.py @@ -21,8 +21,8 @@ def setup(): depcode = app._create_depcode_object(object_input[0]) sss_file = cwd + '/_test' - depcode.iter_inputfile = sss_file - depcode.iter_matfile = cwd + '/_test_mat' + depcode.runtime_inputfile = sss_file + depcode.runtime_matfile = cwd + '/_test_mat' simulation = app._create_simulation_object(object_input[1], depcode, 1, 1) From 5d9838659fba7a617b16d8ce15e6b4d0d6048564 Mon Sep 17 00:00:00 2001 From: yardasol Date: Sat, 26 Nov 2022 15:03:47 -0600 Subject: [PATCH 16/34] write_depletion_step_input() -> write_runtime_input() --- doc/releasenotes/v0.5.0.rst | 6 +++--- saltproc/abc.py | 2 +- saltproc/app.py | 2 +- saltproc/openmc_depcode.py | 4 ++-- saltproc/serpent_depcode.py | 4 ++-- tests/integration_tests/file_interface_openmc/test.py | 8 ++++---- tests/integration_tests/file_interface_serpent/test.py | 8 ++++---- tests/integration_tests/run_no_reprocessing/test.py | 2 +- 8 files changed, 18 insertions(+), 18 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index fb9a087d8..e452bfe2c 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -121,7 +121,7 @@ Python API Changes - ``read_dep_comp()`` → ``read_depleted_materials()`` - ``run_depcode()`` → ``run_depletion_step()`` - ``write_mat_file()`` → ``update_depletable_materials()`` - - ``write_depcode_input()`` → ``write_depletion_step_input()`` + - ``write_depcode_input()`` → ``write_runtime_input()`` - ``iter_inputfile`` → ``runtime_inputfile`` - ``iter_matfile`` → ``runtime_matfile`` @@ -142,7 +142,7 @@ Python API Changes - ``change_sim_par()`` → ``apply_neutron_settings()`` - ``create_iter_matfile()`` → ``create_runtime_matfile()`` - ``replace_burnup_parameters()`` → ``set_power_load()`` - - ``write_depcode_input()`` → ``write_depletion_step_input()`` + - ``write_depcode_input()`` → ``write_runtime_input()`` - ``iter_inputfile`` → ``runtime_inputfile`` - ``iter_matfile`` → ``runtime_matfile`` @@ -153,7 +153,7 @@ Python API Changes - ``write_depcode_input()`` - ``write_depletion_settings()`` - ``write_saltproc_openmc_tallies()`` - - ``write_depcode_input()`` → ``write_depletion_step_input()`` + - ``write_depcode_input()`` → ``write_runtime_input()`` - ``iter_inputfile`` → ``runtime_inputfile`` - ``iter_matfile`` → ``runtime_matfile`` diff --git a/saltproc/abc.py b/saltproc/abc.py index a3e9951ca..5149e0dd1 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -124,7 +124,7 @@ def switch_to_next_geometry(self): """ @abstractmethod - def write_depletion_step_input(self, reactor, dep_step, restart): + def write_runtime_input(self, reactor, dep_step, restart): """Write input file(s) for running depletion step Parameters diff --git a/saltproc/app.py b/saltproc/app.py index 512e47d25..236c4bcd1 100644 --- a/saltproc/app.py +++ b/saltproc/app.py @@ -40,7 +40,7 @@ def run(): # Start sequence for dep_step in range(len(msr.dep_step_length_cumulative)): print("\n\n\nStep #%i has been started" % (dep_step + 1)) - simulation.sim_depcode.write_depcode_input(msr, + simulation.sim_depcode.write_runtime_input(msr, dep_step, simulation.restart_flag) depcode.run_depletion_step(cores, nodes) diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 9d18cc80a..e5063ba82 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -166,8 +166,8 @@ def switch_to_next_geometry(self): next_geometry.export_to_xml(path=self.runtime_inputfile['geometry']) del mats, next_geometry - def write_depletion_step_input(self, reactor, dep_step, restart): - """Write OpenMC input files for running depletion step. + def write_runtime_input(self, reactor, dep_step, restart): + """Write OpenMC runtime input files for running depletion step. Parameters ---------- diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index e11a5d075..c55b9a40d 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -481,8 +481,8 @@ def switch_to_next_geometry(self): with open(self.runtime_inputfile, 'w') as f: f.writelines(new_lines) - def write_depletion_step_input(self, reactor, dep_step, restart): - """Write Serpent2 input file for running depletion step + def write_runtime_input(self, reactor, dep_step, restart): + """Write Serpent2 runtime input file for running depletion step Parameters ---------- diff --git a/tests/integration_tests/file_interface_openmc/test.py b/tests/integration_tests/file_interface_openmc/test.py index 37c86ff95..a9f48c0bb 100644 --- a/tests/integration_tests/file_interface_openmc/test.py +++ b/tests/integration_tests/file_interface_openmc/test.py @@ -22,7 +22,7 @@ def msr(scope='module'): return reactor -def test_write_depletion_step_input(openmc_depcode, msr): +def test_write_runtime_input(openmc_depcode, msr): # OpenMC input_materials = openmc.Materials.from_xml( openmc_depcode.template_input_file_path['materials']) @@ -35,9 +35,9 @@ def test_write_depletion_step_input(openmc_depcode, msr): input_surfaces = input_geometry.get_all_surfaces() input_universes = input_geometry.get_all_universes() - openmc_depcode.write_depletion_step_input(msr, - 0, - False) + openmc_depcode.write_runtime_input(msr, + 0, + False) # Load in the runtime_ objects runtime_materials = openmc.Materials.from_xml(openmc_depcode.runtime_matfile) runtime_geometry = openmc.Geometry.from_xml( diff --git a/tests/integration_tests/file_interface_serpent/test.py b/tests/integration_tests/file_interface_serpent/test.py index 7aec2473d..b683704c4 100644 --- a/tests/integration_tests/file_interface_serpent/test.py +++ b/tests/integration_tests/file_interface_serpent/test.py @@ -74,10 +74,10 @@ def test_write_runtime_files(serpent_depcode, msr): assert file_data[4] == ' 1001.09c -1.21000137902945E-35\n' remove(serpent_depcode.runtime_matfile) - # write_depletion_step_input - serpent_depcode.write_depletion_step_input(msr, - 0, - False) + # write_runtime_input + serpent_depcode.write_runtime_input(msr, + 0, + False) file = serpent_depcode.runtime_inputfile file_data = serpent_depcode.read_plaintext_file(file) diff --git a/tests/integration_tests/run_no_reprocessing/test.py b/tests/integration_tests/run_no_reprocessing/test.py index 689dbed47..fbc1c8f15 100644 --- a/tests/integration_tests/run_no_reprocessing/test.py +++ b/tests/integration_tests/run_no_reprocessing/test.py @@ -78,7 +78,7 @@ def runsim_no_reproc(simulation, reactor, nsteps): for dep_step in range(nsteps): print("\nStep #%i has been started" % (dep_step + 1)) if dep_step == 0: # First step - simulation.sim_depcode.write_depcode_input( + simulation.sim_depcode.write_runtime_input( reactor, dep_step, False) From 0d6aff4fdf1503ca84e2090d78ac2a615fccb47a Mon Sep 17 00:00:00 2001 From: yardasol Date: Sun, 27 Nov 2022 16:20:59 -0600 Subject: [PATCH 17/34] remove default path values in depcode classes --- doc/releasenotes/v0.5.0.rst | 11 +++++------ saltproc/abc.py | 2 +- saltproc/input_schema.json | 35 +++++++++++++++++++++++++---------- saltproc/openmc_depcode.py | 13 ++++++++----- saltproc/serpent_depcode.py | 6 +++--- 5 files changed, 42 insertions(+), 25 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index e452bfe2c..3121cb117 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -113,7 +113,8 @@ Python API Changes - ``Depcode`` - ``template_inputfile_path`` → ``template_input_file_path`` - - Changed `iter_inputfile` and `iter_matfile` to be attributes instead of parameters + - Removed default values for `geo_files` + - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters - ``read_depcode_info()`` → ``read_step_metadata()`` - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` @@ -128,7 +129,8 @@ Python API Changes - ``DepcodeSerpent`` → ``SerpentDepcode`` - ``template_inputfile_path`` → ``template_input_file_path`` - - Changed `iter_inputfile` and `iter_matfile` to be attributes instead of parameters + - Removed default values for `exec_path`, `template_input_file_path`, `geo_files` + - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters - ``read_depcode_info()`` → ``read_depletion_step_metadata()`` - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` @@ -150,12 +152,9 @@ Python API Changes - ``OpenMCDepcode`` is a ``Depcode`` subclass that interfaces with ``openmc``. This class implements the following functions - ``run_depletion_step()`` - ``switch_to_next_geometry()`` - - ``write_depcode_input()`` + - ``write_runtime_input()`` - ``write_depletion_settings()`` - ``write_saltproc_openmc_tallies()`` - - ``write_depcode_input()`` → ``write_runtime_input()`` - - ``iter_inputfile`` → ``runtime_inputfile`` - - ``iter_matfile`` → ``runtime_matfile`` - ``app.py`` diff --git a/saltproc/abc.py b/saltproc/abc.py index 5149e0dd1..fc0b0ef5f 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -27,7 +27,7 @@ def __init__(self, codename, exec_path, template_input_file_path, - geo_files=None, + geo_files, npop=50, active_cycles=20, inactive_cycles=20): diff --git a/saltproc/input_schema.json b/saltproc/input_schema.json index 78cefd81f..ade5cb8b4 100644 --- a/saltproc/input_schema.json +++ b/saltproc/input_schema.json @@ -17,7 +17,7 @@ "output_path": { "description": "Path output data storing folder", "type": "string", - "pattern": "^\\.\\/(.*)$" + "pattern": "^(.\\/)*(.*)$" }, "num_depsteps": { "description": "Number of steps for constant power and depletion interval case", @@ -53,7 +53,7 @@ "type": "array", "items": { "type": "string"}, "minItems": 1, - "uniqueItems": false + "uniqueItems": true } }, "allOf": [ @@ -63,10 +63,14 @@ }, "then": { "properties": { + "exec_path": { + "description": "Path to Serpent executable", + "type": "string", + "default": "sss2"}, "template_input_file_path": { "description": "Path to Serpent template inputfile", "type": "string", - "pattern": "^\\.\\/(.*)$"} + "pattern": "^(.\\/)*(.*)$"} } } }, @@ -76,6 +80,10 @@ }, "then": { "properties": { + "exec_path": { + "description": "Path to OpenMC depletion script", + "type": "string", + "default": "openmc_deplete.py"}, "template_input_file_path": { "description": "Paths to OpenMC template input files", "type": "object", @@ -83,22 +91,29 @@ "settings": { "description": "OpenMC settings file", "type": "string", - "pattern": "^\\.\\/(.*)\\.xml$"}, + "pattern": "^(.\\/)*(.*)\\.xml$", + "default": "settings.xml"}, "materials": { "description": "OpenMC materials file", "type": "string", - "pattern": "^\\.\\/(.*)\\.xml$"}, - "plots": { - "description": "OpenMC plots file (optional)", - "type": "string", - "pattern": "^\\.\\/(.*)\\.xml$"}, + "pattern": "^(.\\/)*(.*)\\.xml$", + "default": "materials.xml"}, "chain_file": { "description": "OpenMC depletion chain file", "type": "string", - "pattern": "^\\.\\/(.*)\\.xml$"} + "pattern": "^(.\\/)*(.*)\\.xml$"} }, "required": ["settings", "materials", "chain_file"] + }, + "geo_file_paths": { + "description": "Path(s) to geometry file(s) to switch to in OpenMC code runs", + "type": "array", + "items": { "type": "string", + "pattern": "^(.\\/)*(.*)\\.xml$"}, + "minItems": 1, + "uniqueItems": true, + "default": ["geometry.xml"] } } } diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index e5063ba82..89285f4a0 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -36,11 +36,9 @@ class OpenMCDepcode(Depcode): """ def __init__(self, - exec_path="openmc_deplete.py", - template_input_file_path={"geometry": "./geometry.xml", - "settings": "./settings.xml", - "chain_file": "./chain_simple.xml"}, - geo_files=None, + exec_path, + template_input_file_path, + geo_files, npop=50, active_cycles=20, inactive_cycles=20): @@ -67,6 +65,11 @@ def __init__(self, Number of inactive cycles. """ + + # if using the default depletion file, make sure we have the right path + if exec_path == "openmc_deplete.py": + exec_path = (Path(__file__).parents[0] / exec_path) + super().__init__("openmc", exec_path, template_input_file_path, diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index c55b9a40d..818bc4bc5 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -35,9 +35,9 @@ class SerpentDepcode(Depcode): """ def __init__(self, - exec_path="sss2", - template_input_file_path="reactor.serpent", - geo_files=None, + exec_path, + template_input_file_path, + geo_files, npop=50, active_cycles=20, inactive_cycles=20): From f6962a680f3c169d5b2c4cad7f9e0d0134cb91f5 Mon Sep 17 00:00:00 2001 From: yardasol Date: Sun, 27 Nov 2022 16:40:10 -0600 Subject: [PATCH 18/34] remove npop, active_cycles, inactive_cycles --- doc/releasenotes/v0.5.0.rst | 2 + examples/msbr/msbr_main.json | 10 ++--- examples/tap/tap_main.json | 38 +++++++++---------- saltproc/abc.py | 14 +------ saltproc/app.py | 5 +-- saltproc/input_schema.json | 12 ------ saltproc/openmc_depcode.py | 19 +--------- saltproc/serpent_depcode.py | 48 +----------------------- tests/openmc_data/tap_input.json | 3 -- tests/openmc_data/tap_settings.xml | 6 +-- tests/serpent_data/tap_input.json | 3 -- tests/serpent_data/tap_template.ini | 2 +- tests/unit_tests/test_app.py | 3 -- tests/unit_tests/test_serpent_depcode.py | 2 +- 14 files changed, 33 insertions(+), 134 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index 3121cb117..a02452a6c 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -112,6 +112,7 @@ Python API Changes - ``Depcode`` + - Remove `npop`, `active_cycles`, `inactive_cycles` parameters. - ``template_inputfile_path`` → ``template_input_file_path`` - Removed default values for `geo_files` - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters @@ -128,6 +129,7 @@ Python API Changes - ``DepcodeSerpent`` → ``SerpentDepcode`` + - Remove `npop`, `active_cycles`, `inactive_cycles` parameters. - ``template_inputfile_path`` → ``template_input_file_path`` - Removed default values for `exec_path`, `template_input_file_path`, `geo_files` - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters diff --git a/examples/msbr/msbr_main.json b/examples/msbr/msbr_main.json index f03b7ad1a..063fd4dfe 100644 --- a/examples/msbr/msbr_main.json +++ b/examples/msbr/msbr_main.json @@ -1,16 +1,12 @@ { "proc_input_file": "msbr_objects.json", "dot_input_file": "msbr.dot", - "output_path": "./data", + "output_path": "data", "num_depsteps": 12, "depcode": { "codename": "serpent", - "exec_path": "sss2", - "template_input_file_path": "./msbr.serpent", - "npop": 50, - "active_cycles": 20, - "inactive_cycles": 20, - "geo_file_paths": ["./geometry/msbr_full.ini"] + "template_input_file_path": "msbr.serpent", + "geo_file_paths": ["geometry/msbr_full.ini"] }, "simulation": { "sim_name": "msbr_example_simulation", diff --git a/examples/tap/tap_main.json b/examples/tap/tap_main.json index 3934f663f..783516b70 100644 --- a/examples/tap/tap_main.json +++ b/examples/tap/tap_main.json @@ -1,31 +1,27 @@ { "proc_input_file": "tap_objects.json", "dot_input_file": "tap.dot", - "output_path": "./data", + "output_path": "data", "num_depsteps": 3, "depcode": { "codename": "serpent", - "exec_path": "sss2", - "template_input_file_path": "./tap.serpent", - "npop": 50, - "active_cycles": 20, - "inactive_cycles": 20, + "template_input_file_path": "tap.serpent", "geo_file_paths": [ - "./geometry/347_base.ini", - "./geometry/406.ini", - "./geometry/427.ini", - "./geometry/505.ini", - "./geometry/576.ini", - "./geometry/633.ini", - "./geometry/681.ini", - "./geometry/840.ini", - "./geometry/880.ini", - "./geometry/900.ini", - "./geometry/988.ini", - "./geometry/1126.ini", - "./geometry/1338.ini", - "./geometry/1498.ini", - "./geometry/1668_all.ini" + "geometry/347_base.ini", + "geometry/406.ini", + "geometry/427.ini", + "geometry/505.ini", + "geometry/576.ini", + "geometry/633.ini", + "geometry/681.ini", + "geometry/840.ini", + "geometry/880.ini", + "geometry/900.ini", + "geometry/988.ini", + "geometry/1126.ini", + "geometry/1338.ini", + "geometry/1498.ini", + "geometry/1668_all.ini" ] }, "simulation": { diff --git a/saltproc/abc.py b/saltproc/abc.py index fc0b0ef5f..c7e0b5ecf 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -27,10 +27,7 @@ def __init__(self, codename, exec_path, template_input_file_path, - geo_files, - npop=50, - active_cycles=20, - inactive_cycles=20): + geo_files): """Initializes the Depcode object. Parameters @@ -48,21 +45,12 @@ def __init__(self, Path to file that contains the reactor geometry. List of `str` if reactivity control by switching geometry is `On` or just `str` otherwise. - npop : int, optional - Size of neutron population per cycle for Monte Carlo. - active_cycles : int, optional - Number of active cycles. - inactive_cycles : int, optional - Number of inactive cycles. """ self.codename = codename self.exec_path = exec_path self.template_input_file_path = template_input_file_path self.geo_files = geo_files - self.npop = npop - self.active_cycles = active_cycles - self.inactive_cycles = inactive_cycles self.neutronics_parameters = {} self.step_metadata = {} self.runtime_inputfile = './runtime_input' diff --git a/saltproc/app.py b/saltproc/app.py index 236c4bcd1..7b9e1901a 100644 --- a/saltproc/app.py +++ b/saltproc/app.py @@ -249,10 +249,7 @@ def _create_depcode_object(depcode_input): depcode = depcode(depcode_input['exec_path'], depcode_input['template_input_file_path'], - geo_files=depcode_input['geo_file_paths'], - npop=depcode_input['npop'], - active_cycles=depcode_input['active_cycles'], - inactive_cycles=depcode_input['inactive_cycles']) + geo_files=depcode_input['geo_file_paths']) return depcode diff --git a/saltproc/input_schema.json b/saltproc/input_schema.json index ade5cb8b4..6e5e15f98 100644 --- a/saltproc/input_schema.json +++ b/saltproc/input_schema.json @@ -36,18 +36,6 @@ "type": "string" }, "template_input_file_path": { "description": "Path(s) to user's template depletion code input file(s) with reactor model"}, - "npop": { - "description": "Number of neutrons per generation", - "type": "number", - "minimum": 0}, - "active_cycles": { - "description": "number of active generations", - "type": "number", - "minimum": 0}, - "inactive_cycles": { - "description": "Number of inactive generations", - "type": "number", - "minimum": 0}, "geo_file_paths": { "description": "Path(s) to geometry file(s) to switch to in depletion code runs", "type": "array", diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 89285f4a0..bcf24a3c7 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -38,10 +38,7 @@ class OpenMCDepcode(Depcode): def __init__(self, exec_path, template_input_file_path, - geo_files, - npop=50, - active_cycles=20, - inactive_cycles=20): + geo_files): """Initializes the OpenMCDepcode object. Parameters @@ -57,12 +54,6 @@ def __init__(self, Path to file that contains the reactor geometry. List of `str` if reactivity control by switching geometry is `On` or just `str` otherwise. - npop : int, optional - Size of neutron population per cycle for Monte Carlo. - active_cycles : int, optional - Number of active cycles. - inactive_cycles : int, optional - Number of inactive cycles. """ @@ -73,10 +64,7 @@ def __init__(self, super().__init__("openmc", exec_path, template_input_file_path, - geo_files, - npop, - active_cycles, - inactive_cycles) + geo_files) self.runtime_inputfile = {'geometry': './geometry.xml', 'settings': './settings.xml'}, self.runtime_matfile = './materials.xml' @@ -190,9 +178,6 @@ def write_runtime_input(self, reactor, dep_step, restart): self.geo_files[0], materials=materials) settings = openmc.Settings.from_xml( self.template_input_file_path['settings']) - settings.particles = self.npop - settings.inactive = self.inactive_cycles - settings.batches = self.active_cycles + self.inactive_cycles else: materials = openmc.Materials.from_xml(self.runtime_matfile) geometry = openmc.Geometry.from_xml( diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 818bc4bc5..46231c213 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -37,10 +37,7 @@ class SerpentDepcode(Depcode): def __init__(self, exec_path, template_input_file_path, - geo_files, - npop=50, - active_cycles=20, - inactive_cycles=20): + geo_files): """Initializes the SerpentDepcode object. Parameters @@ -53,55 +50,15 @@ def __init__(self, Path to file that contains the reactor geometry. List of `str` if reactivity control by switching geometry is `On` or just `str` otherwise. - npop : int, optional - Size of neutron population per cycle for Monte Carlo. - active_cycles : int, optional - Number of active cycles. - inactive_cycles : int, optional - Number of inactive cycles. """ super().__init__("serpent", exec_path, template_input_file_path, - geo_files=geo_files, - npop=npop, - active_cycles=active_cycles, - inactive_cycles=inactive_cycles) + geo_files) self.runtime_inputfile = './serpent_runtime_input.serpent' self.runtime_matfile = './serpent_runtime_mat.ini' - def apply_neutron_settings(self, file_lines): - """Apply neutron settings (no. of neutrons per cycle, no. of active and - inactive cycles) from the SaltProc input file to the runtime Serpent2 - input file. - - Parameters - ---------- - file_lines : list of str - Serpent2 runtime input file. - - Returns - ------- - file_lines : list of str - Serpent2 runtime input file with updated neutron settings. - - """ - if self.npop and self.active_cycles and self.inactive_cycles: - neutron_settings = \ - [line for line in file_lines if line.startswith("set pop")] - if len(neutron_settings) > 1: - raise IOError('Template file ' - f'{self.template_input_file_path} contains ' - 'multuple lines with neutron settings') - elif len(neutron_settings) < 1: - raise IOError('Template file ' - f'{self.template_input_file_path} does not ' - 'contain neutron settings.') - args = 'set pop %i %i %i\n' % (self.npop, self.active_cycles, - self.inactive_cycles) - return [line.replace(neutron_settings[0], args) for line in file_lines] - def create_runtime_matfile(self, file_lines): """Creates the runtime material file tracking burnable materials ans inserts the path to this file in the Serpent2 runtime input file @@ -499,7 +456,6 @@ def write_runtime_input(self, reactor, dep_step, restart): if dep_step == 0 and not restart: lines = self.read_plaintext_file(self.template_input_file_path) lines = self.insert_path_to_geometry(lines) - lines = self.apply_neutron_settings(lines) lines = self.create_runtime_matfile(lines) else: lines = self.read_plaintext_file(self.runtime_inputfile) diff --git a/tests/openmc_data/tap_input.json b/tests/openmc_data/tap_input.json index 9a44db43e..689ec4347 100644 --- a/tests/openmc_data/tap_input.json +++ b/tests/openmc_data/tap_input.json @@ -11,9 +11,6 @@ "settings": "tap_settings.xml", "chain_file": "tap_chain.xml" }, - "npop": 50, - "active_cycles": 20, - "inactive_cycles": 20, "geo_file_paths": ["tap_geometry_base.xml"] }, "simulation": { diff --git a/tests/openmc_data/tap_settings.xml b/tests/openmc_data/tap_settings.xml index 92e1f520b..eb9f8920c 100644 --- a/tests/openmc_data/tap_settings.xml +++ b/tests/openmc_data/tap_settings.xml @@ -1,7 +1,7 @@ eigenvalue - 100 - 50 - 10 + 50 + 40 + 20 diff --git a/tests/serpent_data/tap_input.json b/tests/serpent_data/tap_input.json index 260d9dc9d..98ca10fd6 100644 --- a/tests/serpent_data/tap_input.json +++ b/tests/serpent_data/tap_input.json @@ -7,9 +7,6 @@ "codename": "serpent", "exec_path": "sss2", "template_input_file_path": "tap_template.ini", - "npop": 50, - "active_cycles": 20, - "inactive_cycles": 20, "geo_file_paths": ["tap_geometry_base.ini"] }, "simulation": { diff --git a/tests/serpent_data/tap_template.ini b/tests/serpent_data/tap_template.ini index b1257b90e..7d5bc15bc 100644 --- a/tests/serpent_data/tap_template.ini +++ b/tests/serpent_data/tap_template.ini @@ -16,7 +16,7 @@ set nfylib "sss_jeff33.nfy" set sfylib "sss_jeff33.sfy" % --- Neutron population and criticality cycles: -set pop 30 20 10 +set pop 50 20 20 % --- Depletion parameters % --- Options for burnup calculation: diff --git a/tests/unit_tests/test_app.py b/tests/unit_tests/test_app.py index 10771eaad..ab4a5bcf2 100644 --- a/tests/unit_tests/test_app.py +++ b/tests/unit_tests/test_app.py @@ -21,9 +21,6 @@ def test_read_main_input(cwd, codename, ext): assert input_path == data_path assert depcode_input['codename'] == codename - assert depcode_input['npop'] == 50 - assert depcode_input['active_cycles'] == 20 - assert depcode_input['inactive_cycles'] == 20 assert depcode_input['geo_file_paths'][0] == \ (data_path / ('tap_geometry_base' + ext)).as_posix() diff --git a/tests/unit_tests/test_serpent_depcode.py b/tests/unit_tests/test_serpent_depcode.py index 43078af0f..7483b4fef 100644 --- a/tests/unit_tests/test_serpent_depcode.py +++ b/tests/unit_tests/test_serpent_depcode.py @@ -31,7 +31,7 @@ def test_read_plaintext_file(serpent_depcode): template_str = serpent_depcode.read_plaintext_file( serpent_depcode.template_input_file_path) assert template_str[6] == '%therm zrh_h 900 hzr05.32t hzr06.32t\n' - assert template_str[18] == 'set pop 30 20 10\n' + assert template_str[18] == 'set pop 50 20 20\n' assert template_str[22] == 'set bumode 2\n' assert template_str[23] == 'set pcc 1\n' From 7d41cd3b426be8643f6171df34c3ce89ef184ed6 Mon Sep 17 00:00:00 2001 From: yardasol Date: Sun, 27 Nov 2022 16:42:11 -0600 Subject: [PATCH 19/34] fix redudnant path specifier for runtime filenames --- saltproc/abc.py | 4 ++-- saltproc/openmc_depcode.py | 6 +++--- saltproc/serpent_depcode.py | 4 ++-- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/saltproc/abc.py b/saltproc/abc.py index c7e0b5ecf..c3854e099 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -53,8 +53,8 @@ def __init__(self, self.geo_files = geo_files self.neutronics_parameters = {} self.step_metadata = {} - self.runtime_inputfile = './runtime_input' - self.runtime_matfile = './runtime_mat' + self.runtime_inputfile = None + self.runtime_matfile = None @abstractmethod def read_step_metadata(self): diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index bcf24a3c7..85a99401a 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -65,9 +65,9 @@ def __init__(self, exec_path, template_input_file_path, geo_files) - self.runtime_inputfile = {'geometry': './geometry.xml', - 'settings': './settings.xml'}, - self.runtime_matfile = './materials.xml' + self.runtime_inputfile = {'geometry': 'geometry.xml', + 'settings': 'settings.xml'}, + self.runtime_matfile = 'materials.xml' def read_step_metadata(self): """Reads OpenMC's depletion step metadata and stores it in the diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 46231c213..21a0d5f67 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -56,8 +56,8 @@ def __init__(self, exec_path, template_input_file_path, geo_files) - self.runtime_inputfile = './serpent_runtime_input.serpent' - self.runtime_matfile = './serpent_runtime_mat.ini' + self.runtime_inputfile = 'serpent_runtime_input.serpent' + self.runtime_matfile = 'serpent_runtime_mat.ini' def create_runtime_matfile(self, file_lines): """Creates the runtime material file tracking burnable materials From accd451bc1ecc46ba3d31c9f24a67b898e88e9ca Mon Sep 17 00:00:00 2001 From: yardasol Date: Sun, 27 Nov 2022 18:12:06 -0600 Subject: [PATCH 20/34] add npop, active_cycles, inactive_cycles back in; fix some path-related tests --- doc/releasenotes/v0.5.0.rst | 9 ++-- saltproc/abc.py | 11 +++++ saltproc/app.py | 20 +++++---- saltproc/openmc_depcode.py | 21 ++++++++-- saltproc/serpent_depcode.py | 42 ++++++++++++++++++- .../database_storage/test.py | 4 ++ .../file_interface_serpent/test.py | 9 +--- .../run_constant_reprocessing/tap_input.json | 4 -- .../tap_template.ini | 2 +- .../run_no_reprocessing/test_input.ini | 2 +- .../run_no_reprocessing/test_input.json | 4 -- 11 files changed, 94 insertions(+), 34 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index a02452a6c..73433cc32 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -112,10 +112,11 @@ Python API Changes - ``Depcode`` - - Remove `npop`, `active_cycles`, `inactive_cycles` parameters. + - Add `output_path` parameter. - ``template_inputfile_path`` → ``template_input_file_path`` - Removed default values for `geo_files` - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters + - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of - ``read_depcode_info()`` → ``read_step_metadata()`` - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` @@ -129,10 +130,11 @@ Python API Changes - ``DepcodeSerpent`` → ``SerpentDepcode`` - - Remove `npop`, `active_cycles`, `inactive_cycles` parameters. + - Add `output_path` parameter. - ``template_inputfile_path`` → ``template_input_file_path`` - Removed default values for `exec_path`, `template_input_file_path`, `geo_files` - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters + - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of - ``read_depcode_info()`` → ``read_depletion_step_metadata()`` - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` @@ -143,7 +145,8 @@ Python API Changes - ``write_mat_file()`` → ``update_depletable_materials()`` - ``get_nuc_name()`` → ``convert_nuclide_code_to_name()`` - ``convert_nuclide_name_serpent_to_zam()`` → ``convert_nuclide_code_to_zam()`` - - ``change_sim_par()`` → ``apply_neutron_settings()`` + - ``change_sim_par()`` → (deleted) + - (new function) → ``get_neutron_settings()`` - ``create_iter_matfile()`` → ``create_runtime_matfile()`` - ``replace_burnup_parameters()`` → ``set_power_load()`` - ``write_depcode_input()`` → ``write_runtime_input()`` diff --git a/saltproc/abc.py b/saltproc/abc.py index c3854e099..5389e2060 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -20,11 +20,19 @@ class Depcode(ABC): runtime_matfile : str Path to material file containing burnable materials used to run depletion step. + npop : int + Size of neutron population per cycle + active_cycles : int + Number of active cycles. + inactive_cycles : int + Number of inactive cycles. + """ def __init__(self, codename, + output_path, exec_path, template_input_file_path, geo_files): @@ -32,6 +40,8 @@ def __init__(self, Parameters ---------- + output_path : str + Path to results storage directory. codename : str Name of depletion code. exec_path : str @@ -48,6 +58,7 @@ def __init__(self, """ self.codename = codename + self.output_path = output_path self.exec_path = exec_path self.template_input_file_path = template_input_file_path self.geo_files = geo_files diff --git a/saltproc/app.py b/saltproc/app.py index 7b9e1901a..a1b54c59c 100644 --- a/saltproc/app.py +++ b/saltproc/app.py @@ -26,14 +26,14 @@ def run(): object_input[1], depcode, cores, nodes) msr = _create_reactor_object(object_input[2]) - if isinstance(depcode.runtime_inputfile, str): - depcode.runtime_inputfile = (input_path / - depcode.runtime_inputfile).resolve().as_posix() - else: - raise ValueError("not implemented") - depcode.runtime_matfile = ( - input_path / - depcode.runtime_matfile).resolve().as_posix() + #if isinstance(depcode.runtime_inputfile, str): + # depcode.runtime_inputfile = (input_path / + # depcode.runtime_inputfile).resolve().as_posix() + #else: + # raise ValueError("not implemented") + #depcode.runtime_matfile = ( + # input_path / + # depcode.runtime_matfile).resolve().as_posix() # Check: Restarting previous simulation or starting new? simulation.check_restart() # Run sequence @@ -203,6 +203,7 @@ def read_main_input(main_inp_file): f'{depcode_input["codename"]} ' 'is not a supported depletion code') + depcode_input['output_path'] = output_path geo_list = depcode_input['geo_file_paths'] # Global geometry file paths @@ -247,7 +248,8 @@ def _create_depcode_object(depcode_input): raise ValueError( f'{depcode_input["codename"]} is not a supported depletion code') - depcode = depcode(depcode_input['exec_path'], + depcode = depcode(depcode_input['output_path'], + depcode_input['exec_path'], depcode_input['template_input_file_path'], geo_files=depcode_input['geo_file_paths']) diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 85a99401a..9b4b3eae8 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -32,10 +32,17 @@ class OpenMCDepcode(Depcode): runtime_matfile : str Path to OpenMC material file containing materials used to run depletion step, and modified after fuel reprocessing. + npop : int + Size of neutron population per cycle + active_cycles : int + Number of active cycles. + inactive_cycles : int + Number of inactive cycles. """ def __init__(self, + output_path, exec_path, template_input_file_path, geo_files): @@ -43,6 +50,8 @@ def __init__(self, Parameters ---------- + output_path : str + Path to results storage directory. exec_path : str Path to OpenMC depletion script. template_input_file_path : dict of str to str @@ -62,12 +71,14 @@ def __init__(self, exec_path = (Path(__file__).parents[0] / exec_path) super().__init__("openmc", + output_path, exec_path, template_input_file_path, geo_files) - self.runtime_inputfile = {'geometry': 'geometry.xml', - 'settings': 'settings.xml'}, - self.runtime_matfile = 'materials.xml' + self.runtime_inputfile = \ + {'geometry': (output_path / 'geometry.xml').resolve().as_posix(), + 'settings': (output_path / 'settings.xml').resolve().as_posix()} + self.runtime_matfile = (output_path / 'materials.xml').resolve().as_posix() def read_step_metadata(self): """Reads OpenMC's depletion step metadata and stores it in the @@ -178,6 +189,10 @@ def write_runtime_input(self, reactor, dep_step, restart): self.geo_files[0], materials=materials) settings = openmc.Settings.from_xml( self.template_input_file_path['settings']) + self.npop = settings.particles + self.inactive_cycles = settings.inactive + self.active_cycles = settings.batches - self.inactive_cycles + else: materials = openmc.Materials.from_xml(self.runtime_matfile) geometry = openmc.Geometry.from_xml( diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 21a0d5f67..3d69f35de 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -31,10 +31,18 @@ class SerpentDepcode(Depcode): runtime_matfile : str Path to Serpent2 material file containing burnable materials used to run depletion step, and modified after fuel reprocessing. + npop : int + Size of neutron population per cycle + active_cycles : int + Number of active cycles. + inactive_cycles : int + Number of inactive cycles. + """ def __init__(self, + output_path, exec_path, template_input_file_path, geo_files): @@ -42,6 +50,8 @@ def __init__(self, Parameters ---------- + output_path : str + Path to results storage directory. exec_path : str Path to Serpent2 executable. template_input_file_path : str @@ -53,11 +63,38 @@ def __init__(self, """ super().__init__("serpent", + output_path, exec_path, template_input_file_path, geo_files) - self.runtime_inputfile = 'serpent_runtime_input.serpent' - self.runtime_matfile = 'serpent_runtime_mat.ini' + self.runtime_inputfile = \ + (output_path / 'runtime_input.serpent').resolve().as_posix() + self.runtime_matfile = (output_path / 'runtime_mat.ini').resolve().as_posix() + + def get_neutron_settings(self, file_lines): + """Get neutron settings (no. of neutrons per cycle, no. of active and + inactive cycles) from the Serpent2 input file + + Parameters + ---------- + file_lines : list of str + Serpent2 runtime input file. + + """ + neutron_settings = \ + [line for line in file_lines if line.startswith("set pop")] + if len(neutron_settings) > 1: + raise IOError('Template file ' + f'{self.template_input_file_path} contains ' + 'multuple lines with neutron settings') + elif len(neutron_settings) < 1: + raise IOError('Template file ' + f'{self.template_input_file_path} does not ' + 'contain neutron settings.') + _, _, npop, active_cycles, inactive_cycles = neutron_settings[0].split() + self.npop = int(npop) + self.active_cycles = int(active_cycles) + self.inactive_cycles = int(inactive_cycles) def create_runtime_matfile(self, file_lines): """Creates the runtime material file tracking burnable materials @@ -457,6 +494,7 @@ def write_runtime_input(self, reactor, dep_step, restart): lines = self.read_plaintext_file(self.template_input_file_path) lines = self.insert_path_to_geometry(lines) lines = self.create_runtime_matfile(lines) + self.get_neutron_settings(lines) else: lines = self.read_plaintext_file(self.runtime_inputfile) lines = self.set_power_load(lines, reactor, dep_step) diff --git a/tests/integration_tests/database_storage/test.py b/tests/integration_tests/database_storage/test.py index bcd566f8b..aeec3890e 100644 --- a/tests/integration_tests/database_storage/test.py +++ b/tests/integration_tests/database_storage/test.py @@ -269,6 +269,10 @@ def test_store_run_init_info(simulation): # read data simulation.sim_depcode.read_step_metadata() + + file = simulation.sim_depcode.template_input_file_path + file_lines = simulation.sim_depcode.read_plaintext_file(file) + simulation.sim_depcode.get_neutron_settings(file_lines) init_info = simulation.sim_depcode.step_metadata # we want to keep the old path for other sims, but for this diff --git a/tests/integration_tests/file_interface_serpent/test.py b/tests/integration_tests/file_interface_serpent/test.py index b683704c4..e1e0bffd0 100644 --- a/tests/integration_tests/file_interface_serpent/test.py +++ b/tests/integration_tests/file_interface_serpent/test.py @@ -26,12 +26,7 @@ def test_runtime_input_from_template(serpent_depcode, msr): file = serpent_depcode.template_input_file_path file_data = serpent_depcode.read_plaintext_file(file) - # change_sim_par - file_data = serpent_depcode.apply_neutron_settings(file_data) - assert file_data[18] == 'set pop %i %i %i\n' % ( - serpent_depcode.npop, - serpent_depcode.active_cycles, - serpent_depcode.inactive_cycles) + serpent_depcode.get_neutron_settings(file_data) # insert_path_to_geometry file_data = serpent_depcode.insert_path_to_geometry(file_data) @@ -81,7 +76,7 @@ def test_write_runtime_files(serpent_depcode, msr): file = serpent_depcode.runtime_inputfile file_data = serpent_depcode.read_plaintext_file(file) - assert file_data[0] == 'include "./serpent_runtime_mat.ini"\n' + assert file_data[0] == f'include "{serpent_depcode.runtime_matfile}"\n' assert file_data[8].split()[2] == '1.250000000E+09' assert file_data[8].split()[4] == 'daystep' assert file_data[8].split()[-1] == '1.11111E+02' diff --git a/tests/integration_tests/run_constant_reprocessing/tap_input.json b/tests/integration_tests/run_constant_reprocessing/tap_input.json index d28858052..65e71188b 100644 --- a/tests/integration_tests/run_constant_reprocessing/tap_input.json +++ b/tests/integration_tests/run_constant_reprocessing/tap_input.json @@ -5,11 +5,7 @@ "num_depsteps": 2, "depcode": { "codename": "serpent", - "exec_path": "sss2", "template_input_file_path": "tap_template.ini", - "npop": 50, - "active_cycles": 20, - "inactive_cycles": 20, "geo_file_paths": ["tap_geometry_base.ini"] }, "simulation": { diff --git a/tests/integration_tests/run_constant_reprocessing/tap_template.ini b/tests/integration_tests/run_constant_reprocessing/tap_template.ini index 18ff4832a..52e6e5c0a 100644 --- a/tests/integration_tests/run_constant_reprocessing/tap_template.ini +++ b/tests/integration_tests/run_constant_reprocessing/tap_template.ini @@ -28,7 +28,7 @@ set nfylib "sss_jeff33.nfy" set sfylib "sss_jeff33.sfy" % --- Neutron population and criticality cycles: -set pop 15000 500 200 +set pop 50 20 20 %set gcu -1 % --- Reproducibility off (set value to 1 and define seed to set on): diff --git a/tests/integration_tests/run_no_reprocessing/test_input.ini b/tests/integration_tests/run_no_reprocessing/test_input.ini index 02527308e..a5da15836 100644 --- a/tests/integration_tests/run_no_reprocessing/test_input.ini +++ b/tests/integration_tests/run_no_reprocessing/test_input.ini @@ -13,7 +13,7 @@ set nfylib "/home/andrei2/serpent/xsdata/jeff312/sss_jeff33.nfy" set sfylib "/home/andrei2/serpent/xsdata/jeff312/sss_jeff33.sfy" % --- Neutron population and criticality cycles: -set pop 300 40 10 +set pop 100 20 5 %set gcu -1 % --- Depletion parameters % --- Options for burnup calculation: diff --git a/tests/integration_tests/run_no_reprocessing/test_input.json b/tests/integration_tests/run_no_reprocessing/test_input.json index 140304a85..ef13cb42f 100644 --- a/tests/integration_tests/run_no_reprocessing/test_input.json +++ b/tests/integration_tests/run_no_reprocessing/test_input.json @@ -5,11 +5,7 @@ "num_depsteps": 2, "depcode": { "codename": "serpent", - "exec_path": "sss2", "template_input_file_path": "test_input.ini", - "npop": 100, - "active_cycles": 20, - "inactive_cycles": 5, "geo_file_paths": ["../../serpent_data/tap_geometry_base.ini"] }, "simulation": { From c2f085223b64aac0ab0aa48cd5a1a55fc95a60ba Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 28 Nov 2022 10:46:17 -0600 Subject: [PATCH 21/34] remove cruft commented code in app.py --- saltproc/app.py | 8 -------- 1 file changed, 8 deletions(-) diff --git a/saltproc/app.py b/saltproc/app.py index a1b54c59c..5547901c0 100644 --- a/saltproc/app.py +++ b/saltproc/app.py @@ -26,14 +26,6 @@ def run(): object_input[1], depcode, cores, nodes) msr = _create_reactor_object(object_input[2]) - #if isinstance(depcode.runtime_inputfile, str): - # depcode.runtime_inputfile = (input_path / - # depcode.runtime_inputfile).resolve().as_posix() - #else: - # raise ValueError("not implemented") - #depcode.runtime_matfile = ( - # input_path / - # depcode.runtime_matfile).resolve().as_posix() # Check: Restarting previous simulation or starting new? simulation.check_restart() # Run sequence From 623cda370553ee87bfa4094526f3a12dee80e5f9 Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 28 Nov 2022 10:50:08 -0600 Subject: [PATCH 22/34] cleanup main docstrings for depcode classes --- saltproc/abc.py | 8 ++------ saltproc/openmc_depcode.py | 9 +++------ saltproc/serpent_depcode.py | 9 +++------ 3 files changed, 8 insertions(+), 18 deletions(-) diff --git a/saltproc/abc.py b/saltproc/abc.py index 5389e2060..4d04df979 100644 --- a/saltproc/abc.py +++ b/saltproc/abc.py @@ -1,11 +1,7 @@ from abc import ABC, abstractmethod class Depcode(ABC): - """Abstract class for interfacing with monte-carlo particle transport - codes. Contains information about input, output, geometry, and template - files for running depletion simulations. Also contains neutron - population, active, and inactive cycles. Contains methods to read template - and output files, and write new input files for the depletion code. + """Abstract interface for running depletion steps. Attributes ----------- @@ -36,7 +32,7 @@ def __init__(self, exec_path, template_input_file_path, geo_files): - """Initializes the Depcode object. + """Initialize a Depcode object. Parameters ---------- diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 9b4b3eae8..7312c71b7 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -12,11 +12,8 @@ from saltproc.abc import Depcode class OpenMCDepcode(Depcode): - """Class contains information about input, output, geometry, and - template files for running OpenMC depletion simulations. - Also contains neutrons population, active, and inactive cycles. - Contains methods to read template and output files, - write new input files for OpenMC. + """Interface for running depletion steps in OpenMC, as well as obtaining + depletion step results. Attributes ---------- @@ -46,7 +43,7 @@ def __init__(self, exec_path, template_input_file_path, geo_files): - """Initializes the OpenMCDepcode object. + """Initialize a OpenMCDepcode object. Parameters ---------- diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 3d69f35de..eda551e5f 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -11,11 +11,8 @@ from saltproc.abc import Depcode class SerpentDepcode(Depcode): - """Class contains information about input, output, geometry, and - template files for running Serpent2 depletion simulations. - Also contains neutrons population, active, and inactive cycles. - Contains methods to read template and output files, - write new input files for Serpent2. + """Interface for running depletion steps in Serpent, as well as obtaining + depletion step results. Attributes ----------- @@ -46,7 +43,7 @@ def __init__(self, exec_path, template_input_file_path, geo_files): - """Initializes the SerpentDepcode object. + """Initialize a SerpentDepcode object. Parameters ---------- From ec023d87c950c2d871883534e955c731eb9b09fe Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 28 Nov 2022 10:54:08 -0600 Subject: [PATCH 23/34] cleanup run_depletion_step() in OpenMCDepcode --- saltproc/openmc_depcode.py | 12 ++++++------ saltproc/openmc_deplete.py | 25 ++++++++++++------------- 2 files changed, 18 insertions(+), 19 deletions(-) diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 7312c71b7..4b30c7599 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -129,16 +129,16 @@ def run_depletion_step(self, cores, nodes): '-n', str(nodes), 'python', - './deplete_openmc.py' - '-mat', + self.exec_path + '--materials', self.runtime_matfile, - '-geo', + '--geometry', self.runtime_inputfile['geometry'], - '-set', + '--settings', self.runtime_inputfile['settings'], - '-tal', + '--tallies', self.runtime_inputfile['tallies'], - '-dep', + '--depletion_settings', self.runtime_inputfile['depletion_settings']) print('Running %s' % (self.codename)) diff --git a/saltproc/openmc_deplete.py b/saltproc/openmc_deplete.py index ed3aaa679..1d377bfa8 100644 --- a/saltproc/openmc_deplete.py +++ b/saltproc/openmc_deplete.py @@ -21,50 +21,49 @@ def parse_arguments(): """ parser = argparse.ArgumentParser() - parser.add_argument('-mat', + parser.add_argument('--materials', type=str, default=1, help='path to openmc material \ material xml file') - parser.add_argument('-geo', + parser.add_argument('--geometry', type=str, default=1, help='path to openmc geometry \ xml file') - parser.add_argument('-set', + parser.add_argument('--settings', type=str, default=None, help='path to openmc settings \ xml file') - parser.add_argument('-tal', + parser.add_argument('--tallies', type=str, default=None, help='path to openmc tallies \ xml file') - parser.add_argument('-dep', + parser.add_argument('--depletion_settings', type=str, default=None, help='path to saltproc depletion \ settings json file') args = parser.parse_args() - return str(args.mat), str(args.geo), str(args.set), \ - str(args.dep), str(args.tal) + return str(args.materials), str(args.geometry), str(args.settings), \ + str(args.tallies), str(args.depletion_settings) args = parse_arguments() # Initalize OpenMC objects -materials = openmc.Materials.from_xml(path=args.mat) -geometry = openmc.Geometry.from_xml(path=args.geo, materials=materials) -settings = openmc.Settings.from_xml(args.set) -tallies = openmc.Tallies.from_xml(args.tal) +materials = openmc.Materials.from_xml(path=args.materials) +geometry = openmc.Geometry.from_xml(path=args.geometry, materials=materials) +settings = openmc.Settings.from_xml(args.settings) +tallies = openmc.Tallies.from_xml(args.tallies) model = openmc.model.Model(materials=materials, geometry=geometry, settings=settings, tallies=tallies) -depletion_settings = {} -with open(args.dep) as f: +with open(args.depletion_settings) as f: depletion_settings = json.load(f) model.deplete(depletion_settings['timesteps'], From 213f498a8fa10720865ff90f87b36496ecacb6b2 Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 28 Nov 2022 10:59:21 -0600 Subject: [PATCH 24/34] cleanup write_depletion_settings() and write_runtime_input() in OpenMCDepcode --- saltproc/openmc_depcode.py | 31 +++++++++++++++---------------- 1 file changed, 15 insertions(+), 16 deletions(-) diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index 4b30c7599..ff8437f52 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -165,7 +165,7 @@ def switch_to_next_geometry(self): next_geometry.export_to_xml(path=self.runtime_inputfile['geometry']) del mats, next_geometry - def write_runtime_input(self, reactor, dep_step, restart): + def write_runtime_input(self, reactor, depletion_step, restart): """Write OpenMC runtime input files for running depletion step. Parameters @@ -173,13 +173,13 @@ def write_runtime_input(self, reactor, dep_step, restart): reactor : Reactor Contains information about power load curve and cumulative depletion time for the integration test. - dep_step : int + depletion_step : int Current depletion time step. restart : bool Is the current simulation restarted? """ - if dep_step == 0 and not restart: + if depletion_step == 0 and not restart: materials = openmc.Materials.from_xml( self.template_input_file_path['materials']) geometry = openmc.Geometry.from_xml( @@ -200,37 +200,36 @@ def write_runtime_input(self, reactor, dep_step, restart): materials.export_to_xml(self.runtime_matfile) geometry.export_to_xml(self.runtime_inputfile['geometry']) settings.export_to_xml(self.runtime_inputfile['settings']) - self.write_depletion_settings(reactor, dep_step) + self.write_depletion_settings(reactor, depletion_step) self.write_saltproc_openmc_tallies(materials, geometry) del materials, geometry, settings - def write_depletion_settings(self, reactor, current_depstep_idx): - """Write the depeletion settings for the ``openmc.deplete`` - module. + def write_depletion_settings(self, reactor, step_idx): + """Write the depeletion settings for the OpenMC depletion step. Parameters ---------- reactor : Reactor Contains information about power load curve and cumulative depletion time for the integration test. - current_depstep_idx : int + step_idx : int Current depletion step. """ depletion_settings = {} - current_depstep_power = reactor.power_levels[current_depstep_idx] + current_power = reactor.power_levels[step_idx] # Get current depletion step length - if current_depstep_idx == 0: - current_depstep = reactor.dep_step_length_cumulative[0] + if step_idx == 0: + step_length = reactor.dep_step_length_cumulative[0] else: - current_depstep = \ - reactor.dep_step_length_cumulative[current_depstep_idx] - \ - reactor.dep_step_length_cumulative[current_depstep_idx - 1] + step_length = \ + reactor.dep_step_length_cumulative[step_idx] - \ + reactor.dep_step_length_cumulative[step_idx - 1] out_path = os.path.dirname(self.runtime_inputfile['settings']) depletion_settings['directory'] = out_path - depletion_settings['timesteps'] = [current_depstep] + depletion_settings['timesteps'] = [step_length] operator_kwargs = {} @@ -242,7 +241,7 @@ def write_depletion_settings(self, reactor, current_depstep_idx): a chain file in your saltproc input file") integrator_kwargs = {} - integrator_kwargs['power'] = current_depstep_power + integrator_kwargs['power'] = current_power integrator_kwargs['timestep_units'] = 'd' # days depletion_settings['operator_kwargs'] = operator_kwargs From c6909278f65777fd063c6ba6ae797c3d65fc36f7 Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 28 Nov 2022 11:01:21 -0600 Subject: [PATCH 25/34] cleanup set_power_load() in SerpentDepcode --- saltproc/serpent_depcode.py | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index eda551e5f..b526f5d9c 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -352,7 +352,7 @@ def read_plaintext_file(self, file_path): def set_power_load(self, file_lines, reactor, - current_depstep_idx): + step_idx): """Add power load attributes in a :class:`Reactor` object to the ``set power P dep daystep DEPSTEP`` line in the Serpent2 runtime input file. @@ -364,7 +364,7 @@ def set_power_load(self, reactor : Reactor Contains information about power load curve and cumulative depletion time for the integration test. - current_depstep_idx : int + step_idx : int Current depletion step. Returns @@ -375,13 +375,13 @@ def set_power_load(self, """ line_idx = 8 # burnup setting line index by default - current_depstep_power = reactor.power_levels[current_depstep_idx] - if current_depstep_idx == 0: - current_depstep = reactor.dep_step_length_cumulative[0] + current_power = reactor.power_levels[step_idx] + if step_idx == 0: + step_length = reactor.dep_step_length_cumulative[0] else: - current_depstep = \ - reactor.dep_step_length_cumulative[current_depstep_idx] - \ - reactor.dep_step_length_cumulative[current_depstep_idx - 1] + step_length = \ + reactor.dep_step_length_cumulative[step_idx] - \ + reactor.dep_step_length_cumulative[step_idx - 1] for line in file_lines: if line.startswith('set power '): line_idx = file_lines.index(line) @@ -389,7 +389,7 @@ def set_power_load(self, file_lines.insert(line_idx, # Insert on 9th line 'set power %5.9E dep daystep %7.5E\n' % - (current_depstep_power, current_depstep)) + (current_power, step_length)) return file_lines def run_depletion_step(self, cores, nodes): From 84d12b5cc1e0030c2ab8ac9977761259d6422ff1 Mon Sep 17 00:00:00 2001 From: yardasol Date: Mon, 28 Nov 2022 12:56:21 -0600 Subject: [PATCH 26/34] add missing comma --- saltproc/openmc_depcode.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index ff8437f52..e3da6cc26 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -129,7 +129,7 @@ def run_depletion_step(self, cores, nodes): '-n', str(nodes), 'python', - self.exec_path + self.exec_path, '--materials', self.runtime_matfile, '--geometry', From 692c418d568da90499667a946805ee2a27a93fc8 Mon Sep 17 00:00:00 2001 From: yardasol Date: Tue, 29 Nov 2022 16:15:29 -0600 Subject: [PATCH 27/34] cleanup create_runtime_matfile() --- saltproc/serpent_depcode.py | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index b526f5d9c..6034d0174 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -109,17 +109,17 @@ def create_runtime_matfile(self, file_lines): """ runtime_dir = Path(self.template_input_file_path).parents[0] - include_str = [line for line in file_lines if line.startswith("include ")] - if not include_str: + include_card = [line for line in file_lines if line.startswith("include ")] + if not include_card: raise IOError('Template file ' f'{self.template_input_file_path} has no statements') - src_file = include_str[0].split()[1][1:-1] - if not Path(src_file).is_absolute(): - abs_src_matfile = (runtime_dir / src_file) + burnable_materials_path = include_card[0].split()[1][1:-1] + if not Path(burnable_materials_path).is_absolute(): + absolute_path = (runtime_dir / burnable_materials_path) else: - abs_src_matfile = Path(src_file) - with open(abs_src_matfile) as f: + absolute_path = Path(burnable_materials_path) + with open(absolute_path) as f: if 'mat ' not in f.read(): raise IOError('Template file ' f'{self.template_input_file_path} includes ' @@ -128,8 +128,8 @@ def create_runtime_matfile(self, file_lines): Path.mkdir(Path(self.runtime_matfile).parents[0], exist_ok=True) # Create file with path for SaltProc rewritable iterative material file - shutil.copy2(abs_src_matfile, self.runtime_matfile) - return [line.replace(src_file, self.runtime_matfile) for line in file_lines] + shutil.copy2(absolute_path, self.runtime_matfile) + return [line.replace(burnable_materials_path, self.runtime_matfile) for line in file_lines] def convert_nuclide_code_to_name(self, nuc_code): """Converts Serpent2 nuclide code to symbolic nuclide name. From ac78eeca1bf37c9bcb6b6672710f53a5ce74cf9e Mon Sep 17 00:00:00 2001 From: yardasol Date: Tue, 29 Nov 2022 16:32:22 -0600 Subject: [PATCH 28/34] fix integration tests --- examples/msbr/msbr_main.json | 1 + examples/tap/tap_main.json | 1 + tests/integration_tests/run_constant_reprocessing/tap_input.json | 1 + tests/integration_tests/run_no_reprocessing/test_input.json | 1 + 4 files changed, 4 insertions(+) diff --git a/examples/msbr/msbr_main.json b/examples/msbr/msbr_main.json index 063fd4dfe..dccab2b94 100644 --- a/examples/msbr/msbr_main.json +++ b/examples/msbr/msbr_main.json @@ -5,6 +5,7 @@ "num_depsteps": 12, "depcode": { "codename": "serpent", + "exec_path": "sss2", "template_input_file_path": "msbr.serpent", "geo_file_paths": ["geometry/msbr_full.ini"] }, diff --git a/examples/tap/tap_main.json b/examples/tap/tap_main.json index 783516b70..7c2c5b0f4 100644 --- a/examples/tap/tap_main.json +++ b/examples/tap/tap_main.json @@ -5,6 +5,7 @@ "num_depsteps": 3, "depcode": { "codename": "serpent", + "exec_path": "sss2", "template_input_file_path": "tap.serpent", "geo_file_paths": [ "geometry/347_base.ini", diff --git a/tests/integration_tests/run_constant_reprocessing/tap_input.json b/tests/integration_tests/run_constant_reprocessing/tap_input.json index 65e71188b..5c0a45838 100644 --- a/tests/integration_tests/run_constant_reprocessing/tap_input.json +++ b/tests/integration_tests/run_constant_reprocessing/tap_input.json @@ -5,6 +5,7 @@ "num_depsteps": 2, "depcode": { "codename": "serpent", + "exec_path": "sss2", "template_input_file_path": "tap_template.ini", "geo_file_paths": ["tap_geometry_base.ini"] }, diff --git a/tests/integration_tests/run_no_reprocessing/test_input.json b/tests/integration_tests/run_no_reprocessing/test_input.json index ef13cb42f..ff6eb6094 100644 --- a/tests/integration_tests/run_no_reprocessing/test_input.json +++ b/tests/integration_tests/run_no_reprocessing/test_input.json @@ -5,6 +5,7 @@ "num_depsteps": 2, "depcode": { "codename": "serpent", + "exec_path": "sss2", "template_input_file_path": "test_input.ini", "geo_file_paths": ["../../serpent_data/tap_geometry_base.ini"] }, From 4a38449df9d823a83730b460604c8863ef20a588 Mon Sep 17 00:00:00 2001 From: yardasol Date: Tue, 29 Nov 2022 16:41:41 -0600 Subject: [PATCH 29/34] Add test for get_neutron_settings() --- tests/unit_tests/test_serpent_depcode.py | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/tests/unit_tests/test_serpent_depcode.py b/tests/unit_tests/test_serpent_depcode.py index 7483b4fef..4a5f2d244 100644 --- a/tests/unit_tests/test_serpent_depcode.py +++ b/tests/unit_tests/test_serpent_depcode.py @@ -27,6 +27,15 @@ def test_convert_nuclide_code_to_zam(serpent_depcode): assert serpent_depcode.convert_nuclide_code_to_zam(48315) == 481151 +def test_get_neutron_settings(serpent_depcode): + template_str = serpent_depcode.read_plaintext_file( + serpent_depcode.template_input_file_path) + serpent_depcode.get_neutron_settings(template_str) + assert serpent_depcode.npop == 50 + assert serpent_depcode.active_cycles == 20 + assert serpent_depcode.inactive_cycles == 20 + + def test_read_plaintext_file(serpent_depcode): template_str = serpent_depcode.read_plaintext_file( serpent_depcode.template_input_file_path) From 4db68bf1de72e8a015910664b667bc6d983ea734 Mon Sep 17 00:00:00 2001 From: yardasol Date: Wed, 30 Nov 2022 14:53:28 -0600 Subject: [PATCH 30/34] Path.as_posix() -> str(Path) --- saltproc/app.py | 22 +++++++++---------- saltproc/openmc_depcode.py | 6 ++--- saltproc/serpent_depcode.py | 4 ++-- tests/conftest.py | 14 ++++++------ .../database_storage/test.py | 2 +- .../file_interface_openmc/test.py | 2 +- .../run_constant_reprocessing/test.py | 2 +- .../run_no_reprocessing/test.py | 2 +- tests/unit_tests/test_app.py | 6 ++--- 9 files changed, 30 insertions(+), 30 deletions(-) diff --git a/saltproc/app.py b/saltproc/app.py index 5547901c0..96dd7cae5 100644 --- a/saltproc/app.py +++ b/saltproc/app.py @@ -136,7 +136,7 @@ def read_main_input(main_inp_file): Returns ------- - input_path : PosixPath + input_path : Path Path to main input file process_file : str Path to the `.json` file describing the fuel reprocessing components. @@ -164,11 +164,11 @@ def read_main_input(main_inp_file): input_path = (Path.cwd() / Path(f.name).parents[0]) # Saltproc settings - process_file = (input_path / - j['proc_input_file']).resolve().as_posix() - dot_file = ( + process_file = str((input_path / + j['proc_input_file']).resolve()) + dot_file = str(( input_path / - j['dot_input_file']).resolve().as_posix() + j['dot_input_file']).resolve()) output_path = j['output_path'] num_depsteps = j['num_depsteps'] @@ -182,14 +182,14 @@ def read_main_input(main_inp_file): reactor_input = j['reactor'] if depcode_input['codename'] == 'serpent': - depcode_input['template_input_file_path'] = ( + depcode_input['template_input_file_path'] = str(( input_path / - depcode_input['template_input_file_path']).resolve().as_posix() + depcode_input['template_input_file_path']).resolve()) elif depcode_input['codename'] == 'openmc': for key in depcode_input['template_input_file_path']: value = depcode_input['template_input_file_path'][key] - depcode_input['template_input_file_path'][key] = ( - input_path / value).resolve().as_posix() + depcode_input['template_input_file_path'][key] = str(( + input_path / value).resolve()) else: raise ValueError( f'{depcode_input["codename"]} ' @@ -201,12 +201,12 @@ def read_main_input(main_inp_file): # Global geometry file paths geo_file_paths = [] for g in geo_list: - geo_file_paths += [(input_path / g).resolve().as_posix()] + geo_file_paths += [str((input_path / g).resolve())] depcode_input['geo_file_paths'] = geo_file_paths # Global output file paths db_name = (output_path / simulation_input['db_name']) - simulation_input['db_name'] = db_name.resolve().as_posix() + simulation_input['db_name'] = str(db_name.resolve()) reactor_input = _process_main_input_reactor_params( reactor_input, num_depsteps) diff --git a/saltproc/openmc_depcode.py b/saltproc/openmc_depcode.py index e3da6cc26..e48004ba7 100644 --- a/saltproc/openmc_depcode.py +++ b/saltproc/openmc_depcode.py @@ -73,9 +73,9 @@ def __init__(self, template_input_file_path, geo_files) self.runtime_inputfile = \ - {'geometry': (output_path / 'geometry.xml').resolve().as_posix(), - 'settings': (output_path / 'settings.xml').resolve().as_posix()} - self.runtime_matfile = (output_path / 'materials.xml').resolve().as_posix() + {'geometry': str((output_path / 'geometry.xml').resolve()), + 'settings': str((output_path / 'settings.xml').resolve())} + self.runtime_matfile = str((output_path / 'materials.xml').resolve()) def read_step_metadata(self): """Reads OpenMC's depletion step metadata and stores it in the diff --git a/saltproc/serpent_depcode.py b/saltproc/serpent_depcode.py index 6034d0174..679bff333 100644 --- a/saltproc/serpent_depcode.py +++ b/saltproc/serpent_depcode.py @@ -65,8 +65,8 @@ def __init__(self, template_input_file_path, geo_files) self.runtime_inputfile = \ - (output_path / 'runtime_input.serpent').resolve().as_posix() - self.runtime_matfile = (output_path / 'runtime_mat.ini').resolve().as_posix() + str((output_path / 'runtime_input.serpent').resolve()) + self.runtime_matfile = str((output_path / 'runtime_mat.ini').resolve()) def get_neutron_settings(self, file_lines): """Get neutron settings (no. of neutrons per cycle, no. of active and diff --git a/tests/conftest.py b/tests/conftest.py index 10d55a243..9deb3a466 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -25,10 +25,10 @@ def path_test_file(cwd): @pytest.fixture(scope='session') def serpent_depcode(cwd): """SerpentDepcode object for unit tests""" - saltproc_input = (cwd / 'serpent_data' / 'tap_input.json').as_posix() + saltproc_input = str(cwd / 'serpent_data' / 'tap_input.json') _, _, _, object_input = read_main_input(saltproc_input) depcode = _create_depcode_object(object_input[0]) - depcode.runtime_inputfile = (cwd / 'serpent_data' / 'tap_reference').as_posix() + depcode.runtime_inputfile = str(cwd / 'serpent_data' / 'tap_reference') return depcode @@ -36,7 +36,7 @@ def serpent_depcode(cwd): @pytest.fixture(scope='session') def openmc_depcode(cwd): """OpenMCDepcode object for unit tests""" - saltproc_input = (cwd / 'openmc_data' / 'tap_input.json').as_posix() + saltproc_input = str(cwd / 'openmc_data' / 'tap_input.json') _, _, _, object_input = read_main_input(saltproc_input) depcode = _create_depcode_object(object_input[0]) @@ -50,10 +50,10 @@ def openmc_depcode(cwd): for key in openmc_runtime_inputfiles: openmc_runtime_inputfiles[key] = \ - (openmc_input_path / openmc_runtime_inputfiles[key]).as_posix() + str(openmc_input_path / openmc_runtime_inputfiles[key]) depcode.runtime_inputfile = openmc_runtime_inputfiles - depcode.runtime_matfile = (openmc_input_path / 'materials.xml').as_posix() + depcode.runtime_matfile = str(openmc_input_path / 'materials.xml') return depcode @@ -66,8 +66,8 @@ def simulation(cwd, serpent_depcode): sim_depcode=serpent_depcode, core_number=1, node_number=1, - db_path=( + db_path=str( cwd / 'serpent_data' / - 'tap_reference_db.h5').as_posix()) + 'tap_reference_db.h5')) return simulation diff --git a/tests/integration_tests/database_storage/test.py b/tests/integration_tests/database_storage/test.py index aeec3890e..da291bebc 100644 --- a/tests/integration_tests/database_storage/test.py +++ b/tests/integration_tests/database_storage/test.py @@ -12,7 +12,7 @@ def db_file(simulation): cwd = Path.cwd() db_file = (cwd / (simulation.sim_depcode.codename + '_test.h5')) - return db_file.resolve().as_posix() + return str(db_file.resolve()) def test_store_after_reprocessing( diff --git a/tests/integration_tests/file_interface_openmc/test.py b/tests/integration_tests/file_interface_openmc/test.py index a9f48c0bb..53d5265bd 100644 --- a/tests/integration_tests/file_interface_openmc/test.py +++ b/tests/integration_tests/file_interface_openmc/test.py @@ -77,7 +77,7 @@ def test_write_depletion_settings(openmc_depcode, msr): with open(openmc_depcode.runtime_inputfile['depletion_settings']) as f: j = json.load(f) assert j['directory'] == Path( - openmc_depcode.runtime_inputfile['settings']).parents[0].as_posix() + str(openmc_depcode.runtime_inputfile['settings']).parents[0]) assert j['timesteps'][0] == msr.dep_step_length_cumulative[0] assert j['operator_kwargs']['chain_file'] == \ openmc_depcode.template_input_file_path['chain_file'] diff --git a/tests/integration_tests/run_constant_reprocessing/test.py b/tests/integration_tests/run_constant_reprocessing/test.py index fea774adb..1c12b7a34 100644 --- a/tests/integration_tests/run_constant_reprocessing/test.py +++ b/tests/integration_tests/run_constant_reprocessing/test.py @@ -10,7 +10,7 @@ @pytest.fixture def setup(scope='module'): - cwd = Path(__file__).parents[0].resolve().as_posix() + cwd = str(Path(__file__).parents[0].resolve()) test_db = cwd + '/test_db.h5' ref_db = cwd + '/tap_reference_db.h5' tol = 1e-9 diff --git a/tests/integration_tests/run_no_reprocessing/test.py b/tests/integration_tests/run_no_reprocessing/test.py index fbc1c8f15..fb78e7c5c 100644 --- a/tests/integration_tests/run_no_reprocessing/test.py +++ b/tests/integration_tests/run_no_reprocessing/test.py @@ -13,7 +13,7 @@ @pytest.fixture def setup(): - cwd = Path(__file__).parents[0].resolve().as_posix() + cwd = str(Path(__file__).parents[0].resolve()) main_input = cwd + '/test_input.json' input_path, process_input_file, path_input_file, object_input = \ diff --git a/tests/unit_tests/test_app.py b/tests/unit_tests/test_app.py index ab4a5bcf2..e7cac6104 100644 --- a/tests/unit_tests/test_app.py +++ b/tests/unit_tests/test_app.py @@ -13,7 +13,7 @@ def test_read_main_input(cwd, codename, ext): data_path = codename + '_data' data_path = cwd / data_path - main_input = (data_path / 'tap_input.json').as_posix() + main_input = str(data_path / 'tap_input.json') out = read_main_input(main_input) input_path, process_input_file, path_input_file, object_input = out depcode_input, simulation_input, reactor_input = object_input @@ -22,10 +22,10 @@ def test_read_main_input(cwd, codename, ext): assert depcode_input['codename'] == codename assert depcode_input['geo_file_paths'][0] == \ - (data_path / ('tap_geometry_base' + ext)).as_posix() + str(data_path / ('tap_geometry_base' + ext)) assert simulation_input['db_name'] == \ - (data_path / '../temp_data/db_saltproc.h5').resolve().as_posix() + str((data_path / '../temp_data/db_saltproc.h5').resolve()) assert simulation_input['restart_flag'] is False np.testing.assert_equal( From 660e88f97a73f8086882813709a15da11bb52103 Mon Sep 17 00:00:00 2001 From: yardasol Date: Wed, 30 Nov 2022 14:55:45 -0600 Subject: [PATCH 31/34] set uniqueItems=false for geo_file_paths --- saltproc/input_schema.json | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/saltproc/input_schema.json b/saltproc/input_schema.json index 6e5e15f98..995557c15 100644 --- a/saltproc/input_schema.json +++ b/saltproc/input_schema.json @@ -41,7 +41,7 @@ "type": "array", "items": { "type": "string"}, "minItems": 1, - "uniqueItems": true + "uniqueItems": false } }, "allOf": [ @@ -100,7 +100,6 @@ "items": { "type": "string", "pattern": "^(.\\/)*(.*)\\.xml$"}, "minItems": 1, - "uniqueItems": true, "default": ["geometry.xml"] } } From 8396c2bad87f3973399f87ad2099d2c5501343b2 Mon Sep 17 00:00:00 2001 From: yardasol Date: Thu, 1 Dec 2022 10:23:42 -0600 Subject: [PATCH 32/34] fix typo in file_interface_openmc --- tests/integration_tests/file_interface_openmc/test.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tests/integration_tests/file_interface_openmc/test.py b/tests/integration_tests/file_interface_openmc/test.py index 53d5265bd..c5e056967 100644 --- a/tests/integration_tests/file_interface_openmc/test.py +++ b/tests/integration_tests/file_interface_openmc/test.py @@ -76,8 +76,8 @@ def test_write_depletion_settings(openmc_depcode, msr): openmc_depcode.write_depletion_settings(msr, 0) with open(openmc_depcode.runtime_inputfile['depletion_settings']) as f: j = json.load(f) - assert j['directory'] == Path( - str(openmc_depcode.runtime_inputfile['settings']).parents[0]) + assert j['directory'] == str(Path( + openmc_depcode.runtime_inputfile['settings']).parents[0]) assert j['timesteps'][0] == msr.dep_step_length_cumulative[0] assert j['operator_kwargs']['chain_file'] == \ openmc_depcode.template_input_file_path['chain_file'] From 4a49c11d5d35f28ecd1e4f8197df3da409758f39 Mon Sep 17 00:00:00 2001 From: Olek <45364492+yardasol@users.noreply.github.com> Date: Mon, 5 Dec 2022 13:40:49 -0600 Subject: [PATCH 33/34] Apply suggestions from @abachma2 code review Co-authored-by: Amanda Bachmann --- doc/releasenotes/v0.5.0.rst | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index 73433cc32..d823581e9 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -116,7 +116,7 @@ Python API Changes - ``template_inputfile_path`` → ``template_input_file_path`` - Removed default values for `geo_files` - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters - - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of + - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of parameters - ``read_depcode_info()`` → ``read_step_metadata()`` - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` @@ -134,7 +134,7 @@ Python API Changes - ``template_inputfile_path`` → ``template_input_file_path`` - Removed default values for `exec_path`, `template_input_file_path`, `geo_files` - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters - - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of + - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of parameters - ``read_depcode_info()`` → ``read_depletion_step_metadata()`` - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` From ae1a740e4f9aba4872cf7646a270e62360c1f271 Mon Sep 17 00:00:00 2001 From: Olek <45364492+yardasol@users.noreply.github.com> Date: Mon, 5 Dec 2022 13:40:49 -0600 Subject: [PATCH 34/34] Apply suggestions from @abachma2 code review Co-authored-by: Amanda Bachmann --- doc/releasenotes/v0.5.0.rst | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/doc/releasenotes/v0.5.0.rst b/doc/releasenotes/v0.5.0.rst index 73433cc32..d823581e9 100644 --- a/doc/releasenotes/v0.5.0.rst +++ b/doc/releasenotes/v0.5.0.rst @@ -116,7 +116,7 @@ Python API Changes - ``template_inputfile_path`` → ``template_input_file_path`` - Removed default values for `geo_files` - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters - - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of + - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of parameters - ``read_depcode_info()`` → ``read_step_metadata()`` - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()`` @@ -134,7 +134,7 @@ Python API Changes - ``template_inputfile_path`` → ``template_input_file_path`` - Removed default values for `exec_path`, `template_input_file_path`, `geo_files` - Changed `iter_inputfile`, `iter_matfile` to be attributes instead of parameters - - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of + - Changed `npop`, `active_cycles`, `inactive_cycles` to be attributes instead of parameters - ``read_depcode_info()`` → ``read_depletion_step_metadata()`` - ``sim_info`` → ``step_metadata`` - ``read_depcode_step_param()`` → ``read_neutronics_parameters()``