Skip to main content

Python library for calculating doses and fluxes at a particular altitude given an input spectrum

Project description

atmosphericRadiationDoseAndFlux

A calculation toolkit for determining radiation dose rates in the atmosphere due to an incoming spectrum of particles from space.

Installation

Requires Python 3.9 or later.

Install from PyPI:

pip install atmosphericRadiationDoseAndFlux

Or, after cloning this repository, create and activate a virtual environment, then install from the cloned directory:

pip install .

For development (including running tests):

pip install -e ".[test]"

Usage

Calculating dose rates from an input spectrum as a function

Radiation dose rates that aircraft experience are dependent on the incoming radiation spectrum from space for each incoming particle type, altitude above ground level and the 'vertical cut-off rigidity' (which is a function of latitude and longitude).

You can directly calculate radiation dose rates from an incoming rigidity spectrum using the calculate_from_rigidity_spec function. calculate_from_rigidity_spec takes in an input rigidity specrum as a Python function, as well as an altitude or a list of altitudes, and outputs the dose rates aircraft will experience at that altitude. You can optionally also include a vertical cut-off rigidity (the default vertical cut-off rigidity is set to 0.0 GV).

The usage of calculate_from_rigidity_spec is:

calculate_from_rigidity_spec(rigiditySpectrum:Function, 
                             altitudesInkm:float|list, 
                             particleName="proton", 
                             inputRigidityBins=None,
                             verticalCutOffRigidity=0.0)

where the input parameters are:

parameter description
rigiditySpectrum callable function: must be specified in units of particles/cm2/sr/GV/s, and as a function of rigidity in GV. rigiditySpectrum can be specified as any callable single argument function, representing an incoming particle spectrum with any distribution. You may wish to use Python's lambda function to do this.
altitudesInkm float or list: if specified as a list, calculations will be performed in a loop over each of the specified altitudes and returned in the output Pandas DataFrame.
particleName str: must be either "proton" or "alpha". Currently using the setting "alpha" actually calculates dose rates associated with all particles species with atomic numbers 2 and greater rather than just for alpha particles. Default = "proton".
inputRigidityBins list: an optional input parameter, do not use unless experienced with using this library. Setting this parameter to a value overrides this module's internal application of the rigiditySpectrum parameter to an internal default set of energy bins for the purpose of calculating dose rates and fluxes.
verticalCutOffRigidity float: units of gigavolts (GV). Default = 0.0.

For example, after importing the module using

from atmosphericRadiationDoseAndFlux import doseAndFluxCalculator as DAFcalc

and defining an input rigidity spectrum as a function;

testA = 2.77578789
testmu = 2.82874076

testRigiditySpectrum = lambda x:testA*(x**(-testmu))

running

DAFcalc.calculate_from_rigidity_spec(testRigiditySpectrum, 
                                    particleName="proton",altitudesInkm=18.5928, verticalCutOffRigidity=0.0)

will return

   altitude (km)      edose      adose      dosee        tn1       tn2  \
0        18.5928  62.219856  41.774429  34.169926  12.323553  7.639987   

        tn3           SEU           SEL  
0  5.108492  7.639987e-13  7.639987e-08 

as a Pandas DataFrame. Here testRigiditySpectrum is a power law distribution in rigidity, with a spectral index of testmu and a value at x = 1 of testA.

The outputted dose rate (or flux) labels represent the following dose rate/flux types:

label dose rate/flux type
adose ambient dose equivalent in µSv/hr
edose effective dose in µSv/hr
dosee dose equivalent in µSv/hr
tn1 >1 MeV neutron flux, in n/cm2/s
tn2 >10 MeV neutron flux, in n/cm2/s
tn3 >60 MeV neutron flux, in n/cm2/s
SEU single event upset rate for an SRAM device in upsets/second/bit
SEL single event latch-up rate for an SRAM device in latch-ups/second/device

Dose rates can also be generated from an energy spectrum using calculate_from_energy_spec, which has the same syntax as calculate_from_rigidity_spec, but where the incoming spectrum (now in units of particles/cm2/sr/MeV/s) must be specified in terms of energy in MeV instead of rigidity and the optional inputRigidityBins parameter is instead inputEnergyBins in MeV.

Calculating dose rates from an input spectrum as an array

While it is recommended that the user uses functions as the method of inputting spectra, you can also use the calculate_from_rigidity_spec_array and calculate_from_energy_spec_array functions to calculate dose rates directly from an array of spectral flux values and energy bins.

The general syntax for inputs to these are:

calculate_from_rigidity_spec_array(
                            inputRigidityBins:list,
                            inputFluxesGV:list, 
                            altitudesInkm:list, 
                            particleName="proton",
                            verticalCutOffRigidity = 0.0)

where inputRigidityBins is the full list of rigidity bin edge locations in GV that the input fluxes specified by inputFluxesGV are specified for. As inputRigidityBins represent the bin edge locations for inputFluxesGV, the length of inputRigidityBins must therefore be exactly 1 greater than the length of inputFluxesGV.

calculate_from_energy_spec_array has a nearly identical syntax to calculate_from_rigidity_spec_array, where the only difference is that the first argument of calculate_from_energy_spec_array must be specified in MeV instead of GV, and the second argument is the energy spectrum in particles/cm2/sr/MeV/s instead of the rigidity spectrum in particles/cm2/sr/GV/s.

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

atmosphericradiationdoseandflux-1.0.15.tar.gz (188.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

atmosphericradiationdoseandflux-1.0.15-py3-none-any.whl (197.8 kB view details)

Uploaded Python 3

File details

Details for the file atmosphericradiationdoseandflux-1.0.15.tar.gz.

File metadata

File hashes

Hashes for atmosphericradiationdoseandflux-1.0.15.tar.gz
Algorithm Hash digest
SHA256 2ba983d04eaba5afdeac36b07e3f6b7739647f32cb462af3450d1839636be834
MD5 ab2bb761ffea10dab6c3852326d9a5c5
BLAKE2b-256 b71af3103647361169e4dfdc8c7d858f014f381415977aad4438190bdb1055e7

See more details on using hashes here.

File details

Details for the file atmosphericradiationdoseandflux-1.0.15-py3-none-any.whl.

File metadata

File hashes

Hashes for atmosphericradiationdoseandflux-1.0.15-py3-none-any.whl
Algorithm Hash digest
SHA256 1444f067b83a0d4c736b69ce725cc301628637486af38754af250dea2c2824ec
MD5 0c2919191bbd87247bd1cd8ee0b46e16
BLAKE2b-256 3497888e5e9e037283d4a43bd3faa1aef5a927c8a4d9e0ac25949a2e57aa101d

See more details on using hashes here.

Supported by

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