Skip to content

This notebook demonstrates the process of running calculations for the Molten Salt Reactor Experiment (MSRE) directly from a Computer-Aided Design (CAD) drawing.

Notifications You must be signed in to change notification settings

eealanoca/molten_salt_reactor_experiment_sim

Repository files navigation

MSRE Simulation Notebook

This notebook demonstrates the process of running calculations for the Molten Salt Reactor Experiment (MSRE) directly from a Computer-Aided Design (CAD) drawing. The model is generated from the original drawings obtained from Oak Ridge National Lab.

The simulation backend utilizes the Open Source Monte Carlo particle transport code OpenMC (OpenMC Website) through its Python interface.

Materials Definition

The first step involves defining the materials that constitute the MSRE core. This includes materials like graphite, hastelloy, fuel salt, helium, inconel, and inor. The material properties and compositions are set accordingly.

# Python code for materials definition

# ... (previous material definitions)

# Plot the geometry to verify
xwidth = 350
yheight = 350
material_colors = {salt: 'red', inor: 'lightblue', inconel: 'blue', helium: 'white', graphite: 'gray'}

# Create plots
p1 = openmc.Plot()
# ... (additional plot settings)

plots = openmc.Plots([p1, p2])
openmc.plot_inline(plots)

MSRE Core Slices

MSRE Core Slices

Geometry Definition

Next, the geometry of the MSRE core is defined using the DAGMCUniverse and exported to an XML file.

# Python code for geometry definition

# ... (geometry definition code)

# Plot the geometry to verify
plots = openmc.Plots([p1, p2, p3])
openmc.plot_inline(plots)

MSRE Core Geometry

MSRE Core Geometry

Settings and Simulation

After defining materials and geometry, settings for the Monte Carlo simulation are specified. This includes neutron source definition, settings for the computation, and exporting to an XML file.

# Python code for simulation settings

# ... (settings and source definition)

# Export settings to XML
settings = openmc.Settings()
settings.source = source
settings.batches = 20
settings.inactive = 5
settings.particles = 20000
settings.export_to_xml()

# Run the simulation
openmc.run()

Data Extraction and Visualization

Post-simulation, data is extracted from the statepoint file to analyze neutron flux using tallies.

# Python code for data extraction and visualization

# ... (data extraction code)

# Plot neutron flux maps
import matplotlib.pyplot as plt
import numpy as np
fig, (ax1, ax2) = plt.subplots(ncols=2, figsize=(20, 16), constrained_layout=True)

# ... (flux map plotting code)

# Similarly, plot fission reactions
# ... (fission map plotting code)

# Energy spectrum analysis
# ... (energy spectrum plotting code)

Neutron Flux Map

Neutron Flux Map

Fission Reactions Map

Fission Reactions Map

Energy Spectrum

Energy Spectrum

Control Rods and Modified Geometry

To account for control rods in the reactor model, modify the geometry file and add the corresponding materials. Then, run the simulation again.

# Python code for control rods and modified geometry

# ... (geometry modification code)

# ... (materials modification code)

# Plot the modified geometry
plots = openmc.Plots([p1, p2, p3])
openmc.plot_inline(plots)

# Run the simulation with control rods
os.system("rm -f summary.h5 statepoint.20.h5")
openmc.run()

Modified Geometry with Control Rods XZ

Modified Geometry with Control Rods XZ

Modified Geometry with Control Rods XY

Modified Geometry with Control Rods XY

Modified Geometry with Control Rods XY * 10

Modified Geometry with Control Rods XY * 10

Absorptions Maps

Absorptions Maps

Contact Information

For any inquiries or issues, please contact Elmer E. Alanoca C. at [email protected].

About

This notebook demonstrates the process of running calculations for the Molten Salt Reactor Experiment (MSRE) directly from a Computer-Aided Design (CAD) drawing.

Topics

Resources

Stars

Watchers

Forks