Skip to content

Commit

Permalink
Relax Error Check for 1D cylindrical collection (terrapower#1347)
Browse files Browse the repository at this point in the history
Co-authored-by: Chris Keckler <kecklerct@gmail.com>
  • Loading branch information
mgjarrett and keckler committed Aug 9, 2023
1 parent 491bd47 commit 666a28e
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 1 deletion.
8 changes: 7 additions & 1 deletion armi/physics/neutronics/crossSectionGroupManager.py
Original file line number Diff line number Diff line change
Expand Up @@ -540,6 +540,9 @@ def _checkComponentConsistency(b, repBlock):
f"Blocks {b} and {repBlock} have differing number "
f"of components and cannot be homogenized"
)
# Using Fe-56 as a proxy for structure and Na-23 as proxy for coolant is undesirably SFR-centric
# This should be generalized in the future, if possible
consistentNucs = {"PU239", "U238", "U235", "U234", "FE56", "NA23", "O16"}
for c, repC in zip(sorted(b), sorted(repBlock)):
compString = (
f"Component {repC} in block {repBlock} and component {c} in block {b}"
Expand All @@ -552,7 +555,10 @@ def _checkComponentConsistency(b, repBlock):

theseNucs = set(c.getNuclides())
thoseNucs = set(repC.getNuclides())
diffNucs = theseNucs.symmetric_difference(thoseNucs)
# check for any differences between which `consistentNucs` the components have
diffNucs = theseNucs.symmetric_difference(thoseNucs).intersection(
consistentNucs
)
if diffNucs:
raise ValueError(
f"{compString} are in the same location, but nuclides "
Expand Down
20 changes: 20 additions & 0 deletions armi/physics/neutronics/tests/test_crossSectionManager.py
Original file line number Diff line number Diff line change
Expand Up @@ -380,8 +380,28 @@ def test_checkComponentConsistency(self):
nucDiffBlock.add(clad)
nucDiffBlock.add(coolant)

# additional non-important nuclides
negligibleNucDiffBlock = HexBlock("blockNegligibleNucDiff")
negligibleNuc = {"N14": 1.0e-5}
modControl = baseComponents[0].getNumberDensities()
modClad = baseComponents[2].getNumberDensities()
modCoolant = baseComponents[4].getNumberDensities()
modControl.update(negligibleNuc)
modClad.update(negligibleNuc)
modCoolant.update(negligibleNuc)
mixedDensities = {
"control": modControl,
"clad": modClad,
"coolant": modCoolant,
}
control, clad, coolant = self._makeComponents(7, mixedDensities)
negligibleNucDiffBlock.add(control)
negligibleNucDiffBlock.add(clad)
negligibleNucDiffBlock.add(coolant)

blockCollection._checkComponentConsistency(refBlock, matchingBlock)
blockCollection._checkComponentConsistency(refBlock, unsortedBlock)
blockCollection._checkComponentConsistency(refBlock, negligibleNucDiffBlock)
for b in (nonMatchingMultBlock, nonMatchingLengthBlock, nucDiffBlock):
with self.assertRaises(ValueError):
blockCollection._checkComponentConsistency(refBlock, b)
Expand Down
6 changes: 6 additions & 0 deletions doc/release/0.2.rst
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,12 @@ Release Date: TBD

What's new in ARMI
------------------
#. The Spent Fuel Pool (``sfp``) was moved from the ``Core`` out to the ``Reactor``. (`PR#1336 <https://github.com/terrapower/armi/pull/1336>`_)
#. Broad cleanup of ``Parameters``: filled in all empty units and descriptions, removed unused params. (`PR#1345 <https://github.com/terrapower/armi/pull/1345>`_)
#. Removed redundant ``Material.name`` variable. (`PR#1335 <https://github.com/terrapower/armi/pull/1335>`_)
#. Added SHA1 hashes of XS control files to the welcome text. (`PR#1334 <https://github.com/terrapower/armi/pull/1334>`_)
#. Put back ``avgFuelTemp`` block parameter. (`PR#1362 <https://github.com/terrapower/armi/pull/1362>`_)
#. Make cylindrical component block collection less strict about pre-homogenization checks. (`PR#1347 <https://github.com/terrapower/armi/pull/1347>`_)
#. TBD

Bug fixes
Expand Down

0 comments on commit 666a28e

Please sign in to comment.