Skip to main content

Package performing spectral diagnostics and radiative transfer calculations

Project description

github

DIPPERpy: Diagnostics Inferring the Physics of Plasma and Emitted Radiation in python

Author: Philip G. Judge

Contact: judge@ucar.edu ; mauricew@ucar.edu

Summarizing if DIPPERpy is right for you

Targeted problems
tenuous plasma, "low energy" regime
LTE to optically thin plasmas
compilation of needed rate coefficients
teaching/learning spectroscopy
simple statistical equilibrium calculations
$\quad\quad$- including escape probabilities
simple non-equilibrium calculations
$\quad\quad$- evolution of atomic systems
provide "building blocks" of data and code to permit the user to make more sophisticated calculations
$\quad\quad$- e.g, detailed radiative transfer or radiation hydrodynamics
Limitations
elements lighter than Zn (nuclear charge 30)
principal quantum numbers < 10
incomplete databases
photoionization data are summed over final states, and are split approximately over fine structure
no impact line broadening
no hyperfine structure
no configuration mixing
Cannot handle
non-Maxwellian particle distributions
inner shell excitations (high energy phenomena)
atomic and spectral polarization
molecules
accurate radiative transfer

What makes DIPPERpy unique?

  • It is based upon the fast, flexible database software system written by D. Lindler for IDL, and takes some advantage of this system.
  • It works with quantum numbers for atomic levels, enabling it to perform tasks otherwise difficult or very tedious, including a variety of data checks, calculations based upon the atomic numbers, and searching and manipulating data based upon these quantum numbers.
  • In principle, DIPPERpy can handle conditions from LTE to coronal-like conditions.
  • There is some capability for estimating data for which no accurate parameters are available, and for accounting for the effects of missing atomic levels.


Requirement

  • A database of atomic quantum states and transition rates is needed. The CHIANTI atomic database has been re-organized and reformatted into an assortment of database files that is convenient for the DIPPERpy code to access it for education and research purposes.
  • The database file sizes are too large to include in this repository.
  • The files are within a tar archive compressed with gzip that can be downloaded here: DIPPERpy_dbase.tar.gz
  • Unpack the file and make note of the path location for the unpacked "dbase" directory.
$ tar -xvz -f DIPPERpy_dbase.tar.gz
    dbase/
    dbase/ar85ci.dat
    dbase/ar85ct.dat
    dbase/Barklem_dfdata.dat
    dbase/Barklem_pddata.dat
    dbase/Barklem_spdata.dat
    dbase/bass5250.txt
    dbase/bass6302.txt
    dbase/bbsql.db
    dbase/bfsql.db
    dbase/cbbsql.db
    dbase/cbfsql.db
    dbase/ctab.dat
    dbase/fal.pickle
    dbase/htab.dat
    dbase/lvlsql.db
    dbase/mooreip.dat
    dbase/pf_Kurucz.input
    dbase/rh_atoms.pickle
    dbase/shull82.dat
    dbase/shull82changes.txt
    dbase/shull82changes.txt.gz


Setting Conda Environment

It is useful to create a conda environment first, like so:

$ conda create --name dipperpy
$ conda activate dipperpy
$ conda install python numpy astropy scipy matplotlib numba
$ pip install specutils


Recommended Option: Direct Installation

$ conda install -c mauricewilson dipperpy

or, use pip instead...

$ pip install dipperpy 

Alternative Option: Download/clone the repository and execute (offline) installation

The DIPPERpy package can be installed via a terminal (for macOS or Linux) or command prompt (for Windows) by running the following lines of code:

$ git clone https://github.com/MWilson1/dipperpy.git
$ cd dipperpy
$ pip install dist/dipperpy-1.0.1.tar.gz


Acknowledgment

DIPPERpy is the python version of the original HAOS-DIPER code written in IDL. HAOS-DIPER grew out of a need to work with and manipulate data for neutral atoms and atomic ions to understand radiation emitted by some space plasmas, notably the solar atmosphere and stellar atmospheres. An early version was described by Judge and Meisner (1994). This IDL code can be found at www.hao.ucar.edu/modeling/haos-diper/.


Most of the radiative transfer functionality comes from Lightspinner. This Lightspinner code is a pure python, stripped-down version of the Lightweaver code, which is detailed in the Osborne and Milic (2021) paper. Both software, as well as DIPPERpy, use a copy of the 'witt.py' code written by Alexander Wittmann and translated into python by Jaime de la Cruz Rodriguez, albeit inspired by Dimitri Mihalas' Stellar Atmospheres textbook. Lastly, these codes also use the atomic data archived within the RH code. See the Uitenbroek (2001) and Rybicki and Hummer (1992) papers for further elaboration regarding the methodology of the RH code.

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

dipperpy-1.0.5.tar.gz (81.1 kB view details)

Uploaded Source

Built Distribution

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

dipperpy-1.0.5-py3-none-any.whl (84.7 kB view details)

Uploaded Python 3

File details

Details for the file dipperpy-1.0.5.tar.gz.

File metadata

  • Download URL: dipperpy-1.0.5.tar.gz
  • Upload date:
  • Size: 81.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for dipperpy-1.0.5.tar.gz
Algorithm Hash digest
SHA256 9d1f88d13ed36e76c0eb8eed012e507f9c88a2e99e21098a216362741aeada6f
MD5 79952851c9d50b1b02eb6de846f332ab
BLAKE2b-256 717173313ea911b113e9cc1ad9f5c0d1708042d5606b2eeb9f9c8b481b3a7516

See more details on using hashes here.

File details

Details for the file dipperpy-1.0.5-py3-none-any.whl.

File metadata

  • Download URL: dipperpy-1.0.5-py3-none-any.whl
  • Upload date:
  • Size: 84.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for dipperpy-1.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 5e68855d4d8e738fd1638e1271f58b6b0d9f8578ba48955a7ea55bedb93f902d
MD5 b5d03d9dd01a9d91b9931137f6c3a837
BLAKE2b-256 574e81f80c9df0c31cd3dde6735665066d60c715e499335cfd0fefa0425d4f4b

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