This Python library downloads atomic data from OpenADAS, performs simple calculations and stores the result as a NetCDF file for use in other programs.
radas
is on PyPi. You should be able to install it using
pip install radas
Once you've installed radas
into your environment, you should be able to run
radas --help
to get an overview of the CLI options. Every option has a sensible default, so you can just run radas
at the command line and it will generate a processed NetCDF for every species that has data_files
defined in config.yaml
. This can take some time (especially for high-Z impurities such as tungsten). If you'd just like to run a few species, you can specify these on the command line like
radas -s hydrogen -s helium -s lithium
If you want to change the years of the databases downloaded, you will need to change the config.yaml
file. To get a copy of this, run radas_config
to get a copy of the config.yaml
file in your current working directory. You can edit this file (see the configuration section below) and then use it by passing it as the -c
or --config
argument to radas
(i.e. radas -s hydrogen -c ./config.yaml
).
If you want to develop radas
, excellent! For contributing to radas
, we ask that you
- use Issues to ask questions, request features and discuss planned improvements,
- use Pull Requests to merge code into
main
(mark work-in-progress withdraft
in the title), - write
pytest
tests for new functionality (ideally aiming to cover all new lines of code).
- Python 3.9 or later
- The
poetry
packaging and dependency manager
The project is installed using poetry. If you haven't already installed poetry, the installation instructions can be found here.
Once you have poetry installed, you can install radas
by running
poetry install
Because we've added in-project = true
in poetry.toml
, the project will install in the .venv
in the repository directory.
Once you have installed radas
, you should be able to run the following snippet
poetry run radas --species=hydrogen --plot
where --species
can be
- a specific species such as
hydrogen
ortungsten
all
which runs all species which have available datanone
which doesn't perform any analysis, but can be combined with--plot
to generate the output plots from existing NetCDF files
If anything goes wrong, the script will drop into an ipdb
interpreter so you can debug any issues.
The above snippet executes run_radas_cli
in radas/cli.py
, which performs the following steps
- Connect to OpenADAS
- Download the datasets listed in
radas/config.yaml
underspecies:hydrogen:data_files
(where the values are the years to download) and store them inradas/.data_files
. - Process the downloaded data files and store them in xarray Dataset (in
read_rate_coeffs.py
). - Calculate the fractional abundance of each charge state according to the coronal approximation (in
coronal_equilibrium.py
). - Calculate the coronal mean charge (
$\langle Z \rangle$ ) and radiated power coefficient ($L_z$ ) as a function of the plasma temperature and density (incli.py
for the mean charge and inradiated_power.py
for the radiated power). - Time-integrate equations for the abundance of each charge state to give the fractional abundance as a function of time
$n_z(t)$ for different refuelling rates (characterized by$n_e \tau$ where$\tau$ is a particle residence time, intime_evolution.py
). - Calculate the equilibrium (
$t \to \infty$ ) mean charge ($\langle Z \rangle$ ) and radiated power coefficient ($L_z$ ) as a function of the plasma temperature and density (reusing the same functions as for the coronal values). - Store all of the results in a NetCDF in the
output
folder and make a figure comparing the computed curves to data from Mavrin, J. Fus. Eng., 2017 (where available).
radas
is configured using the config.yaml
file provided in the radas
source repository. You can edit this file directly, or can point the CLI to another configuration YAML file using the --config
argument. Regardless of which approach you choose, the config.yaml
file must have the following structure
globals:
evolution_start:
value: <Time to start time-evolution>
units: "s"
evolution_stop:
value: <Time to stop time-evolution>
units: "s"
ne_tau:
value: <Values of ne * tau to generate output for>
units: "m^-3 s"
data_file_config:
adf11: #or other reader class, but usually we want ADF11
<what to call the dataset in the output>:
prefix: <letters used to identify the dataset>
code: <code used to identify the dataset for the ADAS reader>
stored_units: "cm**3 / s"
desired_units: "m**3 / s"
species:
<species name>:
atomic_symbol: <symbol>
atomic_number: <atomic number>
data_files:
<dataset matching "what to call the dataset in the output" above>: <year to download>
To make sure everything is working, run
poetry run pytest
to execute all of the tests in the tests
folder.
To update the version of radas
at pypi.org/project/radas/, you should edit pyproject.toml
and set version="YYYY.MM.V"
, where YYYY
is the year, MM
is the month and V
is a version tag (reset at zero each month). Then, tag a new release and Github Actions will automatically push this to pypi.