utils

The utils module contains functions to parse nuclide strings and manipulate lists and dictionaries.

The docstring code examples assume that radioactivedecay has been imported as rd:

>>> import radioactivedecay as rd
exception radioactivedecay.utils.NuclideStrError(nuclide: str, additional_message: str, *args)

Custom exception class for invalid nuclide strings.

Parameters:
  • nuclide (str) – Nuclide string.

  • additional_message (str) – Message with additional error context.

radioactivedecay.utils.Z_to_elem(Z: int) str

Converts atomic number to element symbol.

Parameters:

Z (int) – Atomic number.

Returns:

Element string.

Return type:

str

Examples

>>> rd.utils.Z_to_elem(1)
'H'
>>> rd.utils.Z_to_elem(35)
'Br'
radioactivedecay.utils.add_dictionaries(dict_a: dict[str, float | Expr], dict_b: dict[str, float | Expr]) dict[str, float | Expr]

Adds together two dictionaries of nuclide strings and associated quantities. Supports both floats or SymPy quantities.

Parameters:
  • dict_a (dict) – First dictionary containing nuclide strings as keys and quantitites as values.

  • dict_b (dict) – Second dictionary containing nuclide strings as keys and quantitites as values.

Returns:

Combined dictionary containing the nuclides in both dict_a and dict_b, where the quantities have been added together when a nuclide is present in both input dictionaries.

Return type:

dict

Examples

>>> dict_a = {'Pm-141': 1.0, 'Rb-78': 2.0}
>>> dict_b = {'Pm-141': 3.0, 'Rb-90': 4.0}
>>> rd.utils.add_dictionaries(dict_a, dict_b)
{'Pm-141': 4.0, 'Rb-78': 2.0, 'Rb-90': 4.0}
radioactivedecay.utils.build_id(Z: int, A: int, state: str = '') int

Builds a canonical nuclide id from atomic number, atomic mass, and and energy state.

Parameters:
  • Z (int) – Atomic number.

  • A (int) – Atomic mass.

  • state (str) – energy state.

Returns:

Canonical nuclide id.

Return type:

int

Raises:

ValueError – If the input energy state is invalid.

Examples

>>> rd.utils.build_id(1,2)
10020000
>>> rd.utils.build_id(28,56,'m')
280560001
radioactivedecay.utils.build_nuclide_string(Z: int, A: int, meta_state: str = '') str

Builds a nuclide string from given atomic mass and number.

Parameters:
  • Z (int) – Atomic number.

  • A (int) – Atomic mass.

  • meta_state (str, optional) – Metastable state indicator character, ex. ‘m’ for the first atomic metastable state.

Returns:

Nuclide string built in symbol - mass number format.

Return type:

str

Raises:

ValueError – If the input atomic number is invalid.

Examples

>>> rd.utils.build_nuclide_string(26, 56)
'Fe-56'
>>> rd.utils.build_nuclide_string(28, 56, 'm')
'Fe-56m'
radioactivedecay.utils.elem_to_Z(sym: str) int

Converts element symbol to atomic number.

Parameters:

sym (str) – Element string.

Returns:

Atomic number.

Return type:

int

Examples

>>> rd.utils.elem_to_Z('H')
1
>>> rd.utils.elem_to_Z('Br')
35
radioactivedecay.utils.get_metastable_chars() list[str]

Returns list of allowed metastable state characters. Currently up to sixth metastable state is supported, based on the existence of sixth metastable state isomers in NUBASE2020, e.g. Lu-174x.

Note metastable state chars are “m”, “n”, “p”, “q”, “r”, “x” for the first to sixth metastable state, respectively, i.e. “o” is not a metastable state char, nor letters between “r” and “x”. See NUBASE2020 paper (F.G. Kondev et al 2021 Chinese Phys. C 45 030001) for more details.

radioactivedecay.utils.parse_id(input_id: int) str

Parses a nuclide canonical id in zzzaaammmm format into symbol - mass number format.

Parameters:

input_id (int) – Nuclide in canonical id format.

Returns:

Nuclide string parsed in symbol - mass number format.

Return type:

str

Examples

>>> rd.utils.parse_id(190400000)
'K-40'
>>> rd.utils.parse_id(280560001)
'Ni-56m'
radioactivedecay.utils.parse_nuclide(input_nuclide: str | int, nuclides: ndarray, dataset_name: str) str

Parses a nuclide string or canonical id into symbol - mass number format and checks whether the nuclide is contained in the decay dataset.

Parameters:
  • input_nuclide (str or int) – Nuclide name string or canonical id in zzzaaammmm format.

  • nuclides (numpy.ndarray) – List of all the nuclides in the decay dataset.

  • dataset_name (str) – Name of the decay dataset.

Returns:

Nuclide string parsed in symbol - mass number format.

Return type:

str

Raises:
  • ValueError – If the input nuclide string or id is invalid or the nuclide is not contained in the decay dataset.

  • TypeError – If the input is an invalid type, a string or integer is expected.

Examples

>>> rd.utils.parse_nuclide('222Rn', rd.DEFAULTDATA.nuclides, rd.DEFAULTDATA.dataset_name)
'Rn-222'
>>> rd.utils.parse_nuclide('Ba137m', rd.DEFAULTDATA.nuclides, rd.DEFAULTDATA.dataset_name)
'Ba-137m'
>>> rd.utils.parse_nuclide(280560001, rd.DEFAULTDATA.nuclides, rd.DEFAULTDATA.dataset_name)
'Ni-56m'
radioactivedecay.utils.parse_nuclide_str(nuclide: str) str

Parses a nuclide string from e.g. ‘241Pu’ or ‘Pu241’ format to ‘Pu-241’ format. Note this function works for both radioactive and stable nuclides.

Parameters:

nuclide (str) – Nuclide string.

Returns:

Nuclide string parsed in symbol - mass number format.

Return type:

str

Raises:

NuclideStrError – If the input nuclide string is invalid.

Examples

>>> rd.utils.parse_nuclide_str('222Rn')
'Rn-222'
>>> rd.utils.parse_nuclide_str('Ca40')
'Ca-40'
radioactivedecay.utils.sort_dictionary_alphabetically(input_inv_dict: dict[str, float | Expr]) dict[str, float | Expr]

Sorts a dictionary alphabetically by its keys.

Parameters:

input_inv_dict (dict) – Dictionary containing nuclide strings or Nuclide objects as keys and numbers as values.

Returns:

Inventory dictionary which has been sorted by the nuclides alphabetically.

Return type:

dict

Examples

>>> rd.utils.sort_dictionary_alphabetically({'U-235': 1.2, 'Tc-99m': 2.3, 'Tc-99': 5.8})
{'Tc-99': 5.8, 'Tc-99m': 2.3, 'U-235': 1.2}
radioactivedecay.utils.sort_list_according_to_dataset(input_list: list[str], key_dict: dict[str, int]) list[str]

Sorts a list of nuclides based on their order of appearence in the decay dataset.

Parameters:
  • input_list (list) – List of nuclide strings to be sorted.

  • key_dict (dict) – Dictionary from the decay dataset with nuclide strings as keys and their position (integers) in the decay dataset.

Returns:

Sorted nuclide list.

Return type:

list

Examples

>>> rd.utils.sort_list_according_to_dataset(['Tc-99', 'Tc-99m'], rd.DEFAULTDATA.nuclide_dict)
['Tc-99m', 'Tc-99']