Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Random Ray Transport #2823

Merged
merged 188 commits into from
Apr 18, 2024
Merged
Show file tree
Hide file tree
Changes from 172 commits
Commits
Show all changes
188 commits
Select commit Hold shift + click to select a range
d76033a
first commit. File layout, classes, source region init.
jtramm Jun 12, 2023
c2fa6aa
added source update function
jtramm Jun 12, 2023
dc30912
added high level control function
jtramm Jun 12, 2023
31609b0
added cell normalization routine
jtramm Jun 12, 2023
0e2dcec
added add source to flux function
jtramm Jun 12, 2023
7db4a7d
added k-eff update function
jtramm Jun 12, 2023
a782fa4
basic iteration code is in.
jtramm Jun 12, 2023
785c4d6
adding ray methods.
jtramm Jun 12, 2023
2ccc838
adding more ray methods.
jtramm Jun 12, 2023
168ca04
whitespace fixes
jtramm Jun 12, 2023
2c45008
working on debugging the compile. All basic pieces in place though, s…
jtramm Jun 12, 2023
003c646
continued debugging
jtramm Jun 13, 2023
f232980
Compile-time bug fixes and refactoring to use particle_data accessors.
jtramm Jun 13, 2023
04e7e12
assed basic printout. Results look decent.
jtramm Jun 13, 2023
d66cdbb
removed tallying (besides basic things like k-eff)
jtramm Jun 13, 2023
588f1ce
added clean timing/result output function.
jtramm Jun 13, 2023
442153c
added the basics of clean tally-based output
jtramm Jun 13, 2023
baf1f5a
fixed first tally init issue that was causing seg fault. Getting 0 va…
jtramm Jun 13, 2023
2c2770b
ensured that all active tallies are used, not just analog
jtramm Jun 13, 2023
e785b26
generic tally solution working. A little slow
jtramm Jun 14, 2023
9566890
added energy integrated version. About 2x fast, but still too slow. W…
jtramm Jun 14, 2023
7646594
added tally mapper, but now there is a problem where what if we did n…
jtramm Jun 14, 2023
7b46663
Added ability for tally conversion to run multiple times if not all F…
jtramm Jun 14, 2023
f28d655
minor cleanup of tally task conversion code
jtramm Jun 14, 2023
2b43008
moved tallying and tally conversion functions into separate file
jtramm Jun 14, 2023
5548628
added some comments
jtramm Jun 14, 2023
7503eb6
moved initialization of tally task array to where other cell-wise arr…
jtramm Jun 14, 2023
1eb5eec
parallelized flux/volume zeroing routines. Streamlined instability an…
jtramm Jun 14, 2023
958a73a
added more output metrics
jtramm Jun 14, 2023
ec78527
changed parallelization scheme for normalization routines. Removed ta…
jtramm Jun 14, 2023
eeda6ab
first commit. File layout, classes, source region init.
jtramm Jun 12, 2023
6a6d100
added source update function
jtramm Jun 12, 2023
34c35db
added high level control function
jtramm Jun 12, 2023
e19e3e3
added cell normalization routine
jtramm Jun 12, 2023
68af51e
added add source to flux function
jtramm Jun 12, 2023
7673afb
added k-eff update function
jtramm Jun 12, 2023
cfab02a
basic iteration code is in.
jtramm Jun 12, 2023
f40f807
adding ray methods.
jtramm Jun 12, 2023
c373560
adding more ray methods.
jtramm Jun 12, 2023
ebee0ef
whitespace fixes
jtramm Jun 12, 2023
25f1fcc
working on debugging the compile. All basic pieces in place though, s…
jtramm Jun 12, 2023
aa9b732
continued debugging
jtramm Jun 13, 2023
a3ed5dd
Compile-time bug fixes and refactoring to use particle_data accessors.
jtramm Jun 13, 2023
e9708d6
assed basic printout. Results look decent.
jtramm Jun 13, 2023
8d22e78
removed tallying (besides basic things like k-eff)
jtramm Jun 13, 2023
247e8df
added clean timing/result output function.
jtramm Jun 13, 2023
9610a2d
added the basics of clean tally-based output
jtramm Jun 13, 2023
84cfdaa
fixed first tally init issue that was causing seg fault. Getting 0 va…
jtramm Jun 13, 2023
d74781e
ensured that all active tallies are used, not just analog
jtramm Jun 13, 2023
68bee19
generic tally solution working. A little slow
jtramm Jun 14, 2023
a3c9804
added energy integrated version. About 2x fast, but still too slow. W…
jtramm Jun 14, 2023
0c5200b
added tally mapper, but now there is a problem where what if we did n…
jtramm Jun 14, 2023
4b60bd5
Added ability for tally conversion to run multiple times if not all F…
jtramm Jun 14, 2023
64a6d6e
minor cleanup of tally task conversion code
jtramm Jun 14, 2023
b1167d9
moved tallying and tally conversion functions into separate file
jtramm Jun 14, 2023
6566cdc
added some comments
jtramm Jun 14, 2023
738910a
moved initialization of tally task array to where other cell-wise arr…
jtramm Jun 14, 2023
1d9254e
parallelized flux/volume zeroing routines. Streamlined instability an…
jtramm Jun 14, 2023
d998d06
added more output metrics
jtramm Jun 14, 2023
58d516b
changed parallelization scheme for normalization routines. Removed ta…
jtramm Jun 14, 2023
7ffb30d
allowed for different cell instances to be given different material t…
jtramm Jun 16, 2023
5ff2be8
fixed fast forward issue
jtramm Oct 3, 2023
69abd98
updated to use zero temp and angle indices when accessing XS data. Ad…
jtramm Oct 3, 2023
2cb971c
used OpenMC init sim
jtramm Nov 21, 2023
504cb54
using init and finalize batch
jtramm Nov 21, 2023
a6a00b3
using generations now as well
jtramm Nov 21, 2023
ecc0087
using integrated keff tally
jtramm Nov 21, 2023
f363645
commented out unneeded init statements
jtramm Nov 21, 2023
c5fbb4c
set weight to 1.0
jtramm Nov 21, 2023
56e84f7
Switched random ray enum check to use a new solver type variable inst…
jtramm Nov 21, 2023
bbd325d
removed duplicate timer
jtramm Nov 21, 2023
2854d51
figured out bug -- was due to actual bug in openmc where it is revert…
jtramm Nov 22, 2023
8e91d50
input validation is well along -- maybe complete?
jtramm Nov 22, 2023
94705ef
added fixed source checking
jtramm Nov 22, 2023
54f39de
refactor from Ray to RandomRay
jtramm Nov 28, 2023
b3ea0f6
added source validation
jtramm Nov 29, 2023
2d90cd4
refactored to use settings/globals directly rather than passing as ar…
jtramm Nov 29, 2023
872ff56
adding comments, and switched to setting to previous source instead o…
jtramm Nov 29, 2023
39cdd66
moved validation code to end of file
jtramm Nov 29, 2023
43df38a
partial addition of docs and python interface
jtramm Dec 1, 2023
6cf75a6
finished up python interface?
jtramm Dec 1, 2023
dad86a0
fixed issue with int vs real in python interface, and added check for…
jtramm Dec 1, 2023
f7e0400
partial domain replication. Need to not print double, and need to red…
jtramm Dec 1, 2023
6eb99bd
fixed issue with tallies in mpi mode. Issue was solely with the cell …
jtramm Dec 4, 2023
b4fffb8
added more comments
jtramm Dec 4, 2023
ed34ab2
added reduction of intersection counts
jtramm Dec 4, 2023
fe4194d
added timer for source reductions, and added warning about slow reduc…
jtramm Dec 4, 2023
bec2b82
removed extra comment
jtramm Dec 4, 2023
1fbd373
added lots of comments
jtramm Dec 5, 2023
027653b
fixed comment issue
jtramm Dec 5, 2023
1789d41
removed assert statements and replaced with errors
jtramm Dec 5, 2023
fefe9aa
added vtk plotter
jtramm Dec 5, 2023
3bf3134
added FSR and material plots, but FSR plot is weird.
jtramm Dec 5, 2023
811c399
FSRs appear much better as floats rather than modulused ints, for som…
jtramm Dec 5, 2023
95ebeed
simplified plotting routine a bit
jtramm Dec 5, 2023
b3a38e0
parallelized plotter
jtramm Dec 5, 2023
00f0e4c
using plot.xml inputs for plots
jtramm Dec 5, 2023
4939ceb
plotter is using xml input fname
jtramm Dec 5, 2023
bce3b70
added nice output before plotting, and enforcement of acceptable plot…
jtramm Dec 5, 2023
8704ee7
only plot if there is a plotting xml file
jtramm Dec 5, 2023
98f0696
added storage of accumulated final flux and plotting at the end
jtramm Dec 5, 2023
3254e3b
added first try at tolerant testing harness
jtramm Dec 6, 2023
a7d90df
tweaks to tolerant testing. Report k-eff simulation for k-eff combine…
jtramm Dec 6, 2023
54d0a71
added random ray pincell example
jtramm Dec 6, 2023
8a49e5d
removed unneeded headers
jtramm Dec 6, 2023
1419f39
added endianness flipping function, ability to output multiple plots …
jtramm Dec 6, 2023
dd90d63
adjusted comment
jtramm Dec 6, 2023
1818989
fixed merge issue
jtramm Jan 8, 2024
cf0f69b
improved pincell example
jtramm Jan 8, 2024
2248ec4
ran git clang-format develop
jtramm Jan 8, 2024
8216a6c
Added a loop before plotting to change filenames first, so the plot s…
jtramm Jan 8, 2024
735fcfd
ran git clang-format develop
jtramm Jan 8, 2024
33c333b
updated test to use RectangularPrism instead of rectangular_prism`
jtramm Jan 10, 2024
0b0dc42
Revert "fixed fast forward issue"
jtramm Jan 10, 2024
12f24f0
ran clang-format on settings.h
jtramm Jan 10, 2024
69ae4f4
added back in comment
jtramm Jan 10, 2024
99a34cc
removed comments/debugging code
jtramm Jan 10, 2024
a07c534
ran git clang-format develop
jtramm Jan 10, 2024
e0b62a7
Update src/random_ray/iteration.cpp
jtramm Jan 10, 2024
63857aa
incorporation of @gridley review comments
jtramm Jan 11, 2024
57dad69
Merge branch 'random_ray_merge' of github.com:jtramm/openmc into rand…
jtramm Jan 11, 2024
d3cfd4b
Merge branch 'develop' of github.com:openmc-dev/openmc into random_ra…
jtramm Jan 17, 2024
ead8cfa
added random_ray.rst methods file and updated index
jtramm Jan 17, 2024
561d8fa
fixed over/underbars
jtramm Jan 25, 2024
bb24326
added random ray user guide
jtramm Jan 26, 2024
a060d4e
added lots more documentation to theory section
jtramm Jan 26, 2024
a42e0eb
added compressed image files to random ray documentation
jtramm Jan 26, 2024
53d3a5e
continued work on docs
jtramm Jan 28, 2024
74d7ac7
continued work on docs
jtramm Jan 28, 2024
2893ecf
continued updated to docs
jtramm Jan 28, 2024
872bcfe
continued work on docs
jtramm Jan 28, 2024
32c65d8
updating random ray docs
jtramm Jan 29, 2024
66387b4
More random ray docs. Fixed equation notation, added more references,…
jtramm Jan 29, 2024
2ec33be
Added random_ray_source option to IndependentSource to flag source as…
jtramm Feb 6, 2024
5c63a31
ran git clang-format HEAD~1
jtramm Feb 6, 2024
4a0500f
Refactored random ray source indicator to use particle type rather th…
jtramm Feb 6, 2024
4727569
ran git clang-format HEAD~1
jtramm Feb 6, 2024
f20bc1e
removed the rest of old random_ray_source source field.
jtramm Feb 6, 2024
98b65d1
removed unneeded lines throughout
jtramm Feb 6, 2024
916b2bd
updated docs to account for new random ray source specification inter…
jtramm Feb 6, 2024
524f2b4
added accessors for cell material/temperature fields to abstract logi…
jtramm Feb 7, 2024
f122ef0
ran git clang-format HEAD~1
jtramm Feb 7, 2024
4a92297
Merge branch 'develop' into random_ray_merge
jtramm Feb 12, 2024
3821eb2
fixed bug in Cell::sqrtkT accessor return type
jtramm Feb 12, 2024
00d07dc
incorporation of review comments
jtramm Feb 13, 2024
14faa19
refactor into classes mostly complete. Just some cleanup remaining.
jtramm Feb 13, 2024
5555dd9
refactor into classes complete and working (still needs cleanup)
jtramm Feb 14, 2024
28942b9
refactor of random ray filenames
jtramm Feb 14, 2024
383bd31
code cleanup, comments, formatting
jtramm Feb 14, 2024
e3bc76a
ran git clang-format develop
jtramm Feb 14, 2024
e5cdc3e
changed include guard names
jtramm Feb 14, 2024
eb66a04
ran git clang-format develop
jtramm Feb 14, 2024
b715f03
added comment for TolerantPyAPITestHarness class
jtramm Feb 15, 2024
b4ad777
enabled tracklength and collision tallies. Fixed vacuum BC bug where …
jtramm Feb 15, 2024
2d7eec3
updated documents and example to remove the requirement of analog tal…
jtramm Feb 15, 2024
ef0fdca
Remove docs for random_ray_source option that was removed from python…
jtramm Feb 16, 2024
30d0d1d
added TODO item on inheriting from GeometryState instead of Particle.
jtramm Feb 16, 2024
7de305b
Changed random ray interface on python side.
jtramm Feb 16, 2024
007a935
refactor C++ random ray interface to use random_ray object
jtramm Feb 16, 2024
15e6bec
updated docs, examples, and tests to use new interface. Also added va…
jtramm Feb 16, 2024
591d0e2
updated docs
jtramm Feb 16, 2024
1d8722f
ran git clang-format develop
jtramm Feb 16, 2024
a58be8c
removed random ray particle type from C++ and python
jtramm Feb 16, 2024
3d2eab9
ran git clang-format develop
jtramm Feb 16, 2024
982272c
fixed bug with outputting empty random ray dictionary
jtramm Feb 16, 2024
43b842d
simplified docs example slightly
jtramm Feb 16, 2024
4819aaa
incorporation of @gridley docs review comments
jtramm Feb 18, 2024
c9c691d
Line spacing in random ray documentation
paulromano Mar 5, 2024
03333d2
Small changes in user's guide random ray section
paulromano Mar 5, 2024
e8ff8f5
Edits in random ray methods docs
paulromano Mar 5, 2024
0d94bbe
Small changes and updates
paulromano Mar 5, 2024
66b4a3d
Fix XML roundtrip of settings.random_ray
paulromano Mar 5, 2024
06d4343
incorporation of @promano review comments pt 1
jtramm Mar 6, 2024
3c13dd2
changed \vec to \mathbf in random ray docs
jtramm Mar 6, 2024
433b000
incorporation of @promano review comments pt 2
jtramm Mar 6, 2024
3f585ef
changed dV to d\mathbf{r}
jtramm Mar 6, 2024
cb813ce
incorporation of @promano review comments pt3
jtramm Mar 6, 2024
fa0b844
incorporation of @promano review comments pt 4
jtramm Mar 6, 2024
45e3bc9
ran git clang-format develop
jtramm Mar 6, 2024
de456e0
updated random ray test expected results due to bug fix with ray term…
jtramm Mar 6, 2024
936d703
removed unneeded vector header
jtramm Mar 6, 2024
d426075
Small fix in random_ray.rst
paulromano Mar 22, 2024
efe6353
marked random_ray_tally as const, and removed unneeded prototype
jtramm Mar 29, 2024
581229e
updated docs comment
jtramm Mar 29, 2024
d60c3c0
incorporation of @yardasol review comments
jtramm Apr 3, 2024
93bb5b2
Merge branch 'develop' into random_ray_merge
jtramm Apr 4, 2024
c8ffddb
Merge branch 'develop' into pr/jtramm/2823
paulromano Apr 18, 2024
f3dec7d
Small fixes in docstring
paulromano Apr 18, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -382,6 +382,9 @@ list(APPEND libopenmc_SOURCES
src/progress_bar.cpp
src/random_dist.cpp
src/random_lcg.cpp
src/random_ray/random_ray_simulation.cpp
src/random_ray/random_ray.cpp
src/random_ray/flat_source_domain.cpp
src/reaction.cpp
src/reaction_product.cpp
src/scattdata.cpp
Expand Down
Binary file added docs/source/_images/2x2_fsrs.jpeg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/source/_images/2x2_materials.jpeg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
26 changes: 26 additions & 0 deletions docs/source/io_formats/settings.rst
gridley marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -398,6 +398,32 @@ or sub-elements and can be set to either "false" or "true".

.. note:: This element is not used in the multi-group :ref:`energy_mode`.

------------------------
``<random_ray>`` Element
------------------------

The ``<random_ray>`` element enables random ray mode and contains a number of
settings relevant to the solver. Tips for selecting these parameters can be
found in the :ref:`random ray user guide <random_ray>`.

:distance_inactive:
The inactive ray length (dead zone length) in [cm].

*Default*: None

:distance_active:
The active ray length in [cm].

*Default*: None

:source:
Specifies the starting ray distribution, and follows the format for
gridley marked this conversation as resolved.
Show resolved Hide resolved
:ref:`source_element`. It must be uniform in space and angle and cover the
full domain. It does not represent a physical neutron or photon source -- it
is only used to sample integrating ray starting locations and directions.

*Default*: None

----------------------------------
``<resonance_scattering>`` Element
----------------------------------
Expand Down
1 change: 1 addition & 0 deletions docs/source/methods/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -20,3 +20,4 @@ Theory and Methodology
energy_deposition
parallelization
cmfd
random_ray
798 changes: 798 additions & 0 deletions docs/source/methods/random_ray.rst
gridley marked this conversation as resolved.
Show resolved Hide resolved

Large diffs are not rendered by default.

2 changes: 2 additions & 0 deletions docs/source/usersguide/data.rst
Original file line number Diff line number Diff line change
Expand Up @@ -279,6 +279,8 @@ The `official ENDF/B-VII.1 HDF5 library
multipole library, so if you are using this library, the windowed multipole data
will already be available to you.

.. _create_mgxs:

-------------------------
Multigroup Cross Sections
-------------------------
Expand Down
2 changes: 2 additions & 0 deletions docs/source/usersguide/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -26,3 +26,5 @@ essential aspects of using OpenMC to perform simulations.
parallel
volume
troubleshoot
random_ray
jtramm marked this conversation as resolved.
Show resolved Hide resolved
jtramm marked this conversation as resolved.
Show resolved Hide resolved

534 changes: 534 additions & 0 deletions docs/source/usersguide/random_ray.rst

Large diffs are not rendered by default.

203 changes: 203 additions & 0 deletions examples/pincell_random_ray/build_xml.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,203 @@
import numpy as np
import openmc
import openmc.mgxs

###############################################################################
# Create multigroup data

# Instantiate the energy group data
group_edges = [1e-5, 0.0635, 10.0, 1.0e2, 1.0e3, 0.5e6, 1.0e6, 20.0e6]
groups = openmc.mgxs.EnergyGroups(group_edges)

# Instantiate the 7-group (C5G7) cross section data
uo2_xsdata = openmc.XSdata('UO2', groups)
uo2_xsdata.order = 0
uo2_xsdata.set_total(
[0.1779492, 0.3298048, 0.4803882, 0.5543674, 0.3118013, 0.3951678,
0.5644058])
uo2_xsdata.set_absorption([8.0248e-03, 3.7174e-03, 2.6769e-02, 9.6236e-02,
3.0020e-02, 1.1126e-01, 2.8278e-01])
scatter_matrix = np.array(
[[[0.1275370, 0.0423780, 0.0000094, 0.0000000, 0.0000000, 0.0000000, 0.0000000],
[0.0000000, 0.3244560, 0.0016314, 0.0000000, 0.0000000, 0.0000000, 0.0000000],
[0.0000000, 0.0000000, 0.4509400, 0.0026792, 0.0000000, 0.0000000, 0.0000000],
[0.0000000, 0.0000000, 0.0000000, 0.4525650, 0.0055664, 0.0000000, 0.0000000],
[0.0000000, 0.0000000, 0.0000000, 0.0001253, 0.2714010, 0.0102550, 0.0000000],
[0.0000000, 0.0000000, 0.0000000, 0.0000000, 0.0012968, 0.2658020, 0.0168090],
[0.0000000, 0.0000000, 0.0000000, 0.0000000, 0.0000000, 0.0085458, 0.2730800]]])
scatter_matrix = np.rollaxis(scatter_matrix, 0, 3)
uo2_xsdata.set_scatter_matrix(scatter_matrix)
uo2_xsdata.set_fission([7.21206e-03, 8.19301e-04, 6.45320e-03,
1.85648e-02, 1.78084e-02, 8.30348e-02,
2.16004e-01])
uo2_xsdata.set_nu_fission([2.005998e-02, 2.027303e-03, 1.570599e-02,
4.518301e-02, 4.334208e-02, 2.020901e-01,
5.257105e-01])
uo2_xsdata.set_chi([5.8791e-01, 4.1176e-01, 3.3906e-04, 1.1761e-07, 0.0000e+00,
0.0000e+00, 0.0000e+00])

h2o_xsdata = openmc.XSdata('LWTR', groups)
h2o_xsdata.order = 0
h2o_xsdata.set_total([0.15920605, 0.412969593, 0.59030986, 0.58435,
0.718, 1.2544497, 2.650379])
h2o_xsdata.set_absorption([6.0105e-04, 1.5793e-05, 3.3716e-04,
1.9406e-03, 5.7416e-03, 1.5001e-02,
3.7239e-02])
scatter_matrix = np.array(
[[[0.0444777, 0.1134000, 0.0007235, 0.0000037, 0.0000001, 0.0000000, 0.0000000],
[0.0000000, 0.2823340, 0.1299400, 0.0006234, 0.0000480, 0.0000074, 0.0000010],
[0.0000000, 0.0000000, 0.3452560, 0.2245700, 0.0169990, 0.0026443, 0.0005034],
[0.0000000, 0.0000000, 0.0000000, 0.0910284, 0.4155100, 0.0637320, 0.0121390],
[0.0000000, 0.0000000, 0.0000000, 0.0000714, 0.1391380, 0.5118200, 0.0612290],
[0.0000000, 0.0000000, 0.0000000, 0.0000000, 0.0022157, 0.6999130, 0.5373200],
[0.0000000, 0.0000000, 0.0000000, 0.0000000, 0.0000000, 0.1324400, 2.4807000]]])
scatter_matrix = np.rollaxis(scatter_matrix, 0, 3)
h2o_xsdata.set_scatter_matrix(scatter_matrix)

mg_cross_sections_file = openmc.MGXSLibrary(groups)
mg_cross_sections_file.add_xsdatas([uo2_xsdata, h2o_xsdata])
mg_cross_sections_file.export_to_hdf5()

###############################################################################
# Create materials for the problem

# Instantiate some Materials and register the appropriate macroscopic data
uo2 = openmc.Material(name='UO2 fuel')
uo2.set_density('macro', 1.0)
uo2.add_macroscopic('UO2')

water = openmc.Material(name='Water')
water.set_density('macro', 1.0)
water.add_macroscopic('LWTR')

# Instantiate a Materials collection and export to XML
materials_file = openmc.Materials([uo2, water])
materials_file.cross_sections = "mgxs.h5"
materials_file.export_to_xml()

###############################################################################
# Define problem geometry

# The geometry we will define a simplified pincell with fuel radius 0.54 cm
# surrounded by moderator (same as in the multigroup example).
# In random ray, we typically want several radial regions and azimuthal
# sectors in both the fuel and moderator areas of the pincell. This is
# due to the flat source approximation requiring that source regions are
# small compared to the typical mean free path of a neutron. Below we
# sudivide the basic pincell into 8 aziumthal sectors (pizza slices) and
# 5 concentric rings in both the fuel and moderator.

# TODO: When available in OpenMC, use cylindrical lattice instead to
# simplify definition and improve runtime performance.

pincell_base = openmc.Universe()

# These are the subdivided radii (creating 5 concentric regions in the
# fuel and moderator)
ring_radii = [0.241, 0.341, 0.418, 0.482, 0.54, 0.572, 0.612, 0.694, 0.786]
fills = [uo2, uo2, uo2, uo2, uo2, water, water, water, water, water]

# We then create cells representing the bounded rings, with special
# treatment for both the innermost and outermost cells
cells = []
for r in range(10):
cell = []
if r == 0:
outer_bound = openmc.ZCylinder(r=ring_radii[r])
cell = openmc.Cell(fill=fills[r], region=-outer_bound)
elif r == 9:
inner_bound = openmc.ZCylinder(r=ring_radii[r-1])
cell = openmc.Cell(fill=fills[r], region=+inner_bound)
else:
inner_bound = openmc.ZCylinder(r=ring_radii[r-1])
outer_bound = openmc.ZCylinder(r=ring_radii[r])
cell = openmc.Cell(fill=fills[r], region=+inner_bound & -outer_bound)
pincell_base.add_cell(cell)

paulromano marked this conversation as resolved.
Show resolved Hide resolved
# We then generate 8 planes to bound 8 azimuthal sectors
azimuthal_planes = []
for i in range(8):
angle = 2 * i * openmc.pi / 8
normal_vector = (-openmc.sin(angle), openmc.cos(angle), 0)
azimuthal_planes.append(openmc.Plane(a=normal_vector[0], b=normal_vector[1], c=normal_vector[2], d=0))

# Create a cell for each azimuthal sector using the pincell base class
azimuthal_cells = []
for i in range(8):
azimuthal_cell = openmc.Cell(name=f'azimuthal_cell_{i}')
azimuthal_cell.fill = pincell_base
azimuthal_cell.region = +azimuthal_planes[i] & -azimuthal_planes[(i+1) % 8]
azimuthal_cells.append(azimuthal_cell)

# Create the (subdivided) geometry with the azimuthal universes
pincell = openmc.Universe(cells=azimuthal_cells)

# Create a region represented as the inside of a rectangular prism
pitch = 1.26
box = openmc.model.RectangularPrism(pitch, pitch, boundary_type='reflective')
shimwell marked this conversation as resolved.
Show resolved Hide resolved
pincell_bounded = openmc.Cell(fill=pincell, region=-box, name='pincell')

# Create a geometry (specifying merge surfaces option to remove
# all the redundant cylinder/plane surfaces) and export to XML
geometry = openmc.Geometry([pincell_bounded], merge_surfaces=True)
geometry.export_to_xml()

###############################################################################
# Define problem settings

# Instantiate a Settings object, set all runtime parameters, and export to XML
settings = openmc.Settings()
settings.energy_mode = "multi-group"
settings.batches = 600
settings.inactive = 300
settings.particles = 50

# Create an initial uniform spatial source distribution for sampling rays.
# Note that this must be uniform in space and angle.
lower_left = (-pitch/2, -pitch/2, -1)
upper_right = (pitch/2, pitch/2, 1)
uniform_dist = openmc.stats.Box(lower_left, upper_right)
settings.random_ray['ray_source'] = openmc.IndependentSource(space=uniform_dist)
settings.random_ray['distance_inactive'] = 40.0
settings.random_ray['distance_active'] = 400.0

settings.export_to_xml()

###############################################################################
# Define tallies

# Create a mesh that will be used for tallying
mesh = openmc.RegularMesh()
mesh.dimension = (2, 2)
mesh.lower_left = (-pitch/2, -pitch/2)
mesh.upper_right = (pitch/2, pitch/2)

# Create a mesh filter that can be used in a tally
mesh_filter = openmc.MeshFilter(mesh)

# Let's also create a filter to measure each group
# indepdendently
energy_filter = openmc.EnergyFilter(group_edges)

# Now use the mesh filter in a tally and indicate what scores are desired
tally = openmc.Tally(name="Mesh and Energy tally")
tally.filters = [mesh_filter, energy_filter]
tally.scores = ['flux', 'fission', 'nu-fission']

# Instantiate a Tallies collection and export to XML
tallies = openmc.Tallies([tally])
tallies.export_to_xml()

###############################################################################
# Exporting to OpenMC plots.xml file
###############################################################################

plot = openmc.Plot()
plot.origin = [0, 0, 0]
plot.width = [pitch, pitch, pitch]
plot.pixels = [1000, 1000, 1]
plot.type = 'voxel'

# Instantiate a Plots collection and export to XML
plots = openmc.Plots([plot])
plots.export_to_xml()
1 change: 1 addition & 0 deletions include/openmc/boundary_condition.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ namespace openmc {

// Forward declare some types used in function arguments.
class Particle;
class RandomRay;
class Surface;

//==============================================================================
Expand Down
36 changes: 36 additions & 0 deletions include/openmc/cell.h
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,42 @@ class Cell {
std::unordered_map<int32_t, vector<int32_t>> get_contained_cells(
int32_t instance = 0, Position* hint = nullptr) const;

//! Determine the material index corresponding to a specific cell instance,
//! taking into account presence of distribcell material
//! \param[in] instance of the cell
//! \return material index
int32_t material(int32_t instance) const
{
jtramm marked this conversation as resolved.
Show resolved Hide resolved
// If distributed materials are used, then each instance has its own
// material definition. If distributed materials are not used, then
// all instances used the same material stored at material_[0]. The
// presence of distributed materials is inferred from the size of
// the material_ vector being greater than one.
if (material_.size() > 1) {
jtramm marked this conversation as resolved.
Show resolved Hide resolved
return material_[instance];
} else {
return material_[0];
}
}

//! Determine the temperature index corresponding to a specific cell instance,
//! taking into account presence of distribcell temperature
//! \param[in] instance of the cell
//! \return temperature index
double sqrtkT(int32_t instance) const
{
// If distributed materials are used, then each instance has its own
// temperature definition. If distributed materials are not used, then
// all instances used the same temperature stored at sqrtkT_[0]. The
// presence of distributed materials is inferred from the size of
// the sqrtkT_ vector being greater than one.
if (sqrtkT_.size() > 1) {
return sqrtkT_[instance];
} else {
return sqrtkT_[0];
}
}

protected:
//! Determine the path to this cell instance in the geometry hierarchy
//! \param[in] instance of the cell to find parent cells for
Expand Down
2 changes: 2 additions & 0 deletions include/openmc/constants.h
Original file line number Diff line number Diff line change
Expand Up @@ -340,6 +340,8 @@ enum class RunMode {
VOLUME
};

enum class SolverType { MONTE_CARLO, RANDOM_RAY };
gridley marked this conversation as resolved.
Show resolved Hide resolved

//==============================================================================
// Geometry Constants

Expand Down
3 changes: 2 additions & 1 deletion include/openmc/mgxs.h
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@ class Mgxs {
int num_delayed_groups; // number of delayed neutron groups
vector<XsData> xs; // Cross section data
// MGXS Incoming Flux Angular grid information
bool is_isotropic; // used to skip search for angle indices if isotropic
int n_pol;
int n_azi;
vector<double> polar;
Expand Down Expand Up @@ -85,6 +84,8 @@ class Mgxs {
std::string name; // name of dataset, e.g., UO2
double awr; // atomic weight ratio
bool fissionable; // Is this fissionable
bool is_isotropic {
jtramm marked this conversation as resolved.
Show resolved Hide resolved
true}; // used to skip search for angle indices if isotropic
jtramm marked this conversation as resolved.
Show resolved Hide resolved

Mgxs() = default;

Expand Down
6 changes: 5 additions & 1 deletion include/openmc/output.h
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,10 @@ void print_runtime();
//! Display results for global tallies including k-effective estimators
void print_results();

//! Display timing results and global statistics for random ray simulations
void print_results_random_ray(uint64_t total_geometric_intersections,
double avg_miss_rate, int negroups, int64_t n_source_regions);

paulromano marked this conversation as resolved.
Show resolved Hide resolved
void write_tallies();

} // namespace openmc
Expand All @@ -80,4 +84,4 @@ struct formatter<std::array<T, 2>> {
}
};

} // namespace fmt
} // namespace fmt
1 change: 1 addition & 0 deletions include/openmc/plot.h
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,7 @@ class PlottableInterface {
virtual void print_info() const = 0;

const std::string& path_plot() const { return path_plot_; }
std::string& path_plot() { return path_plot_; }
jtramm marked this conversation as resolved.
Show resolved Hide resolved
int id() const { return id_; }
int level() const { return level_; }

Expand Down
Loading
Loading