This repository has been archived by the owner on Aug 15, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #69 from fusion-energy/adding_test_for_2d_mesh_tally
added 2d mesh tally test
- Loading branch information
Showing
2 changed files
with
96 additions
and
18 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
|
||
import tarfile | ||
import unittest | ||
import urllib.request | ||
from pathlib import Path | ||
|
||
import openmc | ||
import openmc_dagmc_wrapper as odw | ||
from openmc_plasma_source import FusionRingSource | ||
|
||
|
||
class TestMeshTally2D(unittest.TestCase): | ||
"""Tests the MeshTally2D class functionality""" | ||
|
||
def setUp(self): | ||
|
||
if not Path("tests/v0.0.2.tar.gz").is_file(): | ||
url = "https://github.com/fusion-energy/neutronics_workflow/archive/refs/tags/v0.0.2.tar.gz" | ||
urllib.request.urlretrieve(url, "tests/v0.0.2.tar.gz") | ||
|
||
tar = tarfile.open("tests/v0.0.2.tar.gz", "r:gz") | ||
tar.extractall("tests") | ||
tar.close() | ||
|
||
self.h5m_filename_smaller = "tests/neutronics_workflow-0.0.2/example_01_single_volume_cell_tally/stage_2_output/dagmc.h5m" | ||
self.h5m_filename_bigger = "tests/neutronics_workflow-0.0.2/example_02_multi_volume_cell_tally/stage_2_output/dagmc.h5m" | ||
|
||
def test_incorrect_mesh_tally_2d(self): | ||
"""Set a mesh_tally_2d that is not accepted which should raise an | ||
error""" | ||
def incorrect_mesh_tally_2d(): | ||
odw.MeshTally2D("coucou", plane="xy") | ||
|
||
self.assertRaises(ValueError, incorrect_mesh_tally_2d) | ||
|
||
def test_incorrect_mesh_tally_2d_type(self): | ||
"""Set a mesh_tally_2d that is the wrong type which should raise an | ||
error""" | ||
def incorrect_mesh_tally_2d_type(): | ||
odw.MeshTally2D(1, plane="xy") | ||
|
||
self.assertRaises(TypeError, incorrect_mesh_tally_2d_type) | ||
|
||
def test_shape_of_resulting_png(self): | ||
"""Runs a simulation with a 2d mesh tally and checks png images are | ||
produced""" | ||
|
||
geometry = odw.Geometry(h5m_filename=self.h5m_filename_smaller) | ||
materials = odw.Materials( | ||
h5m_filename=self.h5m_filename_smaller, | ||
correspondence_dict={ | ||
"mat1": "Be", | ||
}, | ||
) | ||
tally1 = odw.MeshTally2D( | ||
tally_type="flux", | ||
plane="xy", | ||
bounding_box=self.h5m_filename_smaller, | ||
mesh_resolution=(10, 200) | ||
) | ||
tally2 = odw.MeshTally2D( | ||
tally_type="flux", | ||
plane="xz", | ||
bounding_box=self.h5m_filename_smaller, | ||
mesh_resolution=(20, 100) | ||
) | ||
tally3 = odw.MeshTally2D( | ||
tally_type="flux", | ||
plane="yz", | ||
bounding_box=self.h5m_filename_smaller, | ||
mesh_resolution=(30, 500) | ||
) | ||
|
||
tallies = openmc.Tallies([tally1, tally2, tally3]) | ||
|
||
settings = odw.FusionSettings() | ||
settings.batches = 2 | ||
settings.particles = 100 | ||
settings.photon_transport = False | ||
settings.source = FusionRingSource(fuel="DT", radius=1) | ||
|
||
my_model = openmc.Model( | ||
materials=materials, | ||
geometry=geometry, | ||
settings=settings, | ||
tallies=tallies) | ||
statepoint_file = my_model.run() | ||
|
||
odw.process_results(statepoint_file, fusion_power=1e9) | ||
|
||
assert Path('flux_on_2D_mesh_xy.png').exists() | ||
assert Path('flux_on_2D_mesh_xz.png').exists() | ||
assert Path('flux_on_2D_mesh_yz.png').exists() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters