nuclide
The nuclide module defines the Nuclide
class. Each Nuclide
instance
represents one nuclide, and can be contructed from a nuclide string or
zzzaaassss canonical id. The class properties provide an easy way of
extracting atomic number and mass information, as well as a clean name string.
Furthermore, additional methods provide an access point for mass data of
nuclides, and the decay data of radionuclides, if present in a specified
dataset. The default decay dataset used if none is supplied to the constructor
is rd.DEFAULTDATA.
The docstring code examples assume that radioactivedecay
has been imported
as rd
:
>>> import radioactivedecay as rd
Nuclide
- class radioactivedecay.nuclide.Nuclide(nuclide: str | int, decay_data: ~radioactivedecay.decaydata.DecayData = Decay dataset: icrp107_ame2020_nubase2020, contains SymPy data: True)
Nuclide
instances serve as name and atomic number/mass parsing objects for any nuclide or element.- Parameters:
nuclide (str or int) – Specify the nuclide with either a name string (e.g. ‘H-3’, ‘H3’ or ‘3H’) or a canonical id (zzzaaassss format).
decay_data (DecayData, optional) – Decay dataset (default is the ICRP-107 dataset).
- nuclide
Nuclide name string.
- Type:
str
Examples
>>> rd.Nuclide('K-40') Nuclide: K-40, decay dataset: icrp107_ame2020_nubase2020 >>> rd.Nuclide('K40') Nuclide: K-40, decay dataset: icrp107_ame2020_nubase2020 >>> rd.Nuclide(190400000) Nuclide: K-40, decay dataset: icrp107_ame2020_nubase2020 >>> rd.Nuclide(280560001) Nuclide: Ni-56m, decay dataset: icrp107_ame2020_nubase2020
- property A: int
Returns the mass number of the nuclide.
- Returns:
Mass number of the nuclide.
- Return type:
int
Examples
>>> H3 = rd.Nuclide('H-3') >>> H3.A 3
- property Z: int
Returns the atomic number of the nuclide.
- Returns:
Atomic number of the nuclide.
- Return type:
int
Examples
>>> H3 = rd.Nuclide('H-3') >>> H3.Z 1
- property atomic_mass: float
Returns the atomic mass of the nuclide, in g/mol.
- Returns:
Atomic mass of the nuclide in g/mol.
- Return type:
float
Examples
>>> H3 = rd.Nuclide('H-3') >>> H3.atomic_mass 3.01604928132 >>> Ba137m = rd.Nuclide('Ba-137m') >>> Ba137m.atomic_mass 136.9065375271172
- branching_fractions() list[float]
Returns the branching fractions to the direct progeny of a radionuclide.
- Returns:
List of branching fractions.
- Return type:
list
Examples
>>> K40 = rd.Nuclide('K-40') >>> K40.branching_fractions() [0.8914, 0.1086]
- decay_modes() list[str]
Returns the decay modes for a radionuclide, as defined in the decay dataset. Note: the decay mode strings returned are not lists of all the different radiation types emitted during the parent to progeny decay processes. They are the labels defined in the decay dataset to classify the parent to progeny decay type (e.g. ‘α’, ‘β-’ or ‘IT’).
- Returns:
List of decay modes.
- Return type:
list
Examples
>>> K40 = rd.Nuclide('K-40') >>> K40.decay_modes() ['β-', 'β+ & EC']
- half_life(units: str = 's') float | str
Returns the half-life of a nuclide as a float in your chosen units, or as a human-readable string with appropriate units.
- Parameters:
units (str, optional) – Units for half-life. Options are ‘ps’, ‘ns’, ‘μs’, ‘us’, ‘ms’, ‘s’, ‘m’, ‘h’, ‘d’, ‘y’, ‘ky’, ‘My’, ‘By’, ‘Gy’, ‘Ty’, ‘Py’, and common spelling variations. Default is ‘s’, i.e. seconds. Use ‘readable’ to get a string of the half-life in human-readable units.
- Returns:
Half-life of the nuclide.
- Return type:
float or str
Examples
>>> K40 = rd.Nuclide('K-40') >>> K40.half_life('y') 1251000000.0 >>> K40.half_life('readable') '1.251 By' >>> Fe56 = rd.Nuclide('Fe-56') >>> Fe56.half_life('readable') 'stable'
- property id: int
Returns the canonical nuclide id, in zzzaaassss form. Ground state is 0000, first excited state (“m”) is 0001, second (“n”) is 0002, etc.
- Returns:
Canonical id of the nuclide.
- Return type:
int
Examples
>>> H3 = rd.Nuclide('H-3') >>> H3.id 10030000 >>> Ba137m = rd.Nuclide('Ba-137m') >>> Ba137m.id 561370001
- plot(label_pos: float = 0.5, fig: Figure | None = None, axes: Axes | None = None, kwargs_draw: dict[str, Any] | None = None, kwargs_edge_labels: dict[str, Any] | None = None) tuple[Figure, Axes]
Plots a diagram of the decay chain of a radionuclide. Then creates a NetworkX DiGraph and plot of it using NetworkX’s Matplotlib-based plotting functionality.
Some of the NetworkX default plotting parameters are changed to produce nice decay chain diagrams. However, users retain control over these parameters via kwargs_draw and kwargs_edge_labels. For more information on the various NetworkX plotting parameters, refer to its documentation.
- Parameters:
label_pos (float, optional) – Position of labels along edges. Default is 0.5. If you find that edge labels are overlapping in the decay chain diagram, try increasing this parameter to e.g. 0.66.
fig (None or matplotlib.figure.Figure, optional) – matplotlib figure object to use, or None makes
radioactivedecay
create one (default is None).axes (None or matplotlib.axes.Axes, optional) – matplotlib axes object to use, or None makes
radioactivedecay
create one (default is None).**kwargs_draw – Keyword arguments for networkx.draw().
optional – Keyword arguments for networkx.draw().
**kwargs_edge_labels – Keyword arguments for networkx.draw_networkx_edge_labels().
optional – Keyword arguments for networkx.draw_networkx_edge_labels().
- Returns:
fig (matplotlib.figure.Figure) – matplotlib figure object used to plot the decay chain.
ax (matplotlib.axes.Axes) – matplotlib axes object used to plot the decay chain.
- progeny() list[str]
Returns list of the direct progeny of the nuclide.
- Returns:
List of the direct progeny of the nuclide, ordered by decreasing branching fraction.
- Return type:
list
Examples
>>> K40 = rd.Nuclide('K-40') >>> K40.progeny() ['Ca-40', 'Ar-40']
- property state: str
Returns the metastable state character, i.e. ‘’ for ground state, ‘m’ for first metastable state, ‘n’ for second metastable state, etc..
- Returns:
Metastable state character.
- Return type:
str
Examples
>>> H3 = rd.Nuclide('H-3') >>> H3.state '' >>> Ba137m = rd.Nuclide('Ba-137m') >>> Ba137m.state 'm'