Skip to main content

Convert OpenMC tallies into user friendly units

Project description

This Python package aims to help convert OpenMC tallies to user specified units.

Installation

pip install openmc_tally_unit_converter

Usage

OpenMC tally results are save into a statepoint h5 file without units.

This package ascertains the base units of common tallies by inspecting their tally filters and scores.

The following worked example is for a heating tally. Other supported tallies are heating-local, flux, effective dose and damage-energy (used to find DPA) tallies are also supported.

import openmc_tally_unit_converter as otuc
import openmc

# loads up tally from an openmc statepoint output file
statepoint = openmc.StatePoint(filepath="statepoint.2.h5")
my_tally = statepoint.get_tally(name="my_cell_heating_tally")

# gets the base units of the tally
tally = otuc.process_tally(tally=my_tally)
print(tally)
>>> 218559.22320927 electron_volt / source_particle

The package then allows users to scale the base tally units to different units. For example the package can easily convert cm to meters or electron volts to joules.

converted_tally = otuc.process_tally(
    tally=my_tally,
    required_units = "joules / source_particle"
)

print(converted_tally)
>>> 3.50170481e-14 Joules / source_particle

Additional inputs can be applied to normalize the the tallies and convert the units further:

  • The source strength of the source in particles per second can be specified with the strength_strength argument. This allows the tally results to be converted from the units of score per simulated particle to score per unit time (e.g seconds, hours, days etc).
converted_tally = otuc.process_tally(
    tally=my_tally,
    source_strength=1e20,  # input units for this argument are particles per second
    required_units = "joules / minute"
)

print(converted_tally)
>>> 2.10102288e+08 joules / source_particle
  • The volume of the cell in cm3 can also be specified with the volume argument. This allows the tally result to be converted from the base units to base units per unit volume.
converted_tally = otuc.process_tally(
    tally=my_tally,
    source_strength=13458.3,  # input units for this argument are particles per second
    volume=12,  # input units are in cm3
    required_units = "joules / second / meter **3"
)

print(converted_tally)
>>> 3.92724948e-05 Joules / meter ** 3 / second

:point_right: Further examples

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

openmc_tally_unit_converter-0.3.1.tar.gz (8.2 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file openmc_tally_unit_converter-0.3.1.tar.gz.

File metadata

  • Download URL: openmc_tally_unit_converter-0.3.1.tar.gz
  • Upload date:
  • Size: 8.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1

File hashes

Hashes for openmc_tally_unit_converter-0.3.1.tar.gz
Algorithm Hash digest
SHA256 55efb2001b3d271f133bf8e33cf6c6e3741b80c8aabb5bd5aaada27b0e5ef734
MD5 159f4c1d53318679fba4ba77d2a5432a
BLAKE2b-256 2c3f90a979829b045d00bdd2654bf86ae88a9791a7fa04b8d6eb133e01fc810f

See more details on using hashes here.

File details

Details for the file openmc_tally_unit_converter-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: openmc_tally_unit_converter-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1

File hashes

Hashes for openmc_tally_unit_converter-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 10f9d94fa4dddc1d9ab2cfcbe539e94b357eff4c54ed5f26efc2fcf46c7f7f7e
MD5 8ff0f0ca8c2d3baeb120c33382293648
BLAKE2b-256 c9568efd6f941f9a8f717510c20743726229cec68cb61aabbe8230810d202d63

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page