A collection of useful utilities for the Spyral analysis framework
Project description
spyral-utils
spyral-utils is a utility library that contains some of the core functionality of Spyral. These utilities were found to be useful not just within Spyral but also continuing analysis after using Spyral. Some key utilities include:
- Nuclear masses from the AMDC AME 2020 masses
- Some histogramming and gating/cuting tools that are plotting backend agnostic
- Energy loss analysis for gas and solid targets using pycatima
- 4-vector analysis through the vector package
See the documentation for more details.
Installation
spyral-utils can be installed using pip install spyral-utils
System requirements
spyral-utils requires Python >= 3.10 and < 3.13
spyral-utils is cross-platform and tested for MacOS 14, Windows 11, and Ubuntu 22.04.
Formats
Several parts of the utilities allow for saving and creating objects from JSON. Below is an outline of the expected formats for each of these
Targets
The JSON description of a target is as follows:
For a gas target:
{
"compound": [
[1, 1, 2]
],
"pressure(Torr)": 300.0,
"thickness(ug/cm^2)": null
}
For a solid target:
{
"compound": [
[6, 12, 1]
],
"pressure(Torr)": null,
"thickness(ug/cm^2)": 50.0
}
The indication of a null
pressure or thickness tells spyral-utils if that JSON is for a solid or gas target. Compound specifications are lists of elements where each element is an array of [Z, A, S]
. S
is the stoichiometry of that particular element in the compound. spyral-utils does not support target layers at this time (but layered targets can be built from the building blocks provided by spyral-utils). In the above examples the gas target is for 1H2 gas at 300 Torr pressure and the solid target is for 12C1 foil with a thickness of 50 μg/cm2.
2D-Cuts
The JSON description of a 2D-Cut (or 2D-gate) on data is as follows:
{
"name": "test_cut",
"vertices": [
[0.0, 0.0],
[1.0, 0.0],
[1.0, 1.0],
[0.0, 1.0],
[0.0, 0.0]
]
}
name
is a identifier given for that particular cut. verticies
is a list of [x,y]
coordinates which define the polygon. Note that the polygon must be closed (the final vertex must be the same as the first vertex). You can also add the xaxis
and yaxis
keywords to specify the names of the axes of the cut (i.e. the column names of a dataframe).
{
"name": "test_cut",
"xaxis": "my_x",
"yaxis": "my_y",
"vertices": [
[0.0, 0.0],
[1.0, 0.0],
[1.0, 1.0],
[0.0, 1.0],
[0.0, 0.0]
]
}
Particle ID
The JSON description of a particle ID gate is as follows:
{
"name": "test_cut",
"vertices": [
[0.0, 0.0],
[1.0, 0.0],
[1.0, 1.0],
[0.0, 1.0],
[0.0, 0.0]
],
"Z": 6,
"A": 12
}
The name
and vertices
fields are the same as those used by a Cut2D. The particle ID has the additional data Z
and A
which are the element and mass number of the associated nucleus. Like in a Cut2D you can also specify the axis names of the cut
{
"name": "test_cut",
"xaxis": "my_x",
"yaxis": "my_y",
"vertices": [
[0.0, 0.0],
[1.0, 0.0],
[1.0, 1.0],
[0.0, 1.0],
[0.0, 0.0]
],
"Z": 6,
"A": 12
}
References
- CAtima/pycatima
- AMDC Mass Evaluation: W.J. Huang et al 2021 Chinese Phys. C 45 030002
- scipy
- numpy
- shapely
- polars
- vector
For documentation we use
For testing we use
Authors
- Gordon McCann
- Nathan Turi
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file spyral_utils-1.1.0.tar.gz
.
File metadata
- Download URL: spyral_utils-1.1.0.tar.gz
- Upload date:
- Size: 55.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: pdm/2.15.4 CPython/3.10.12 Linux/6.5.0-1021-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a21d7791d5340b4f36f6be496f2281fdedab8c109675fdfb98004478ee906b69 |
|
MD5 | 838acab3221f4c218b287fba1f723bc2 |
|
BLAKE2b-256 | a9bd30586abf49067e18ed11645fb044a64c96045d043b342013531a1947e515 |
File details
Details for the file spyral_utils-1.1.0-py3-none-any.whl
.
File metadata
- Download URL: spyral_utils-1.1.0-py3-none-any.whl
- Upload date:
- Size: 53.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: pdm/2.15.4 CPython/3.10.12 Linux/6.5.0-1021-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2cd38f77da1e9ba801dfdae702c893f9a6983639d88b06eb837082c099af19c3 |
|
MD5 | feb923cd702404eb196e3b14f758db49 |
|
BLAKE2b-256 | 4a46cb6887e5b27fb90889e8cbbc48c2a34c48d3e429e5f819595687225bbe12 |