(airglow viewed aboard the ISS)
pyglow is a Python module that wraps several upper atmosphere climatoglogical models written in FORTRAN, such as the Horizontal Wind Model (HWM), the International Geomagnetic Reference Field (IGRF), the International Reference Ionosphere (IRI), and the Mass Spectrometer and Incoherent Scatter Radar (MSIS).
It includes the following upper atmospheric models:
- HWM 2014
- HWM 2007
- HWM 1993
- IGRF 12
- IGRF 11
- IRI 2016
- IRI 2012
- MSIS 2000
pyglow also provides access to the the following geophysical indices:
- AP
- Kp
- F10.7
- DST
- AE
pyglow offers access to these models & indices in a convenient, high-level object-oriented interface within Python.
First, checkout the repository:
$ git clone git://github.com/timduly4/pyglow.git;
Change directories into the repository folder and run the installation script:
$ cd pyglow/
$ ./pyglow_install.sh
If you have troubles, follow the individual installation steps:
(1) Download the package:
$ git clone git://github.com/timduly4/pyglow.git
$ cd pyglow/
(2) Download the climatological models and wrap them with f2py:
$ cd ./pyglow/models/
$ make all
-
If successful, there should be a
*.so
file in each of the./models/dl_models/<model>/
directories:$ find . -name "*.so" ./dl_models/hwm07/hwm07py.so ./dl_models/hwm93/hwm93py.so ./dl_models/hwm14/hwm14py.so ./dl_models/igrf11/igrf11py.so ./dl_models/igrf12/igrf12py.so ./dl_models/iri12/iri12py.so ./dl_models/iri16/iri16py.so ./dl_models/msis/msis00py.so
(3) Install the python package
$ cd ../../ # get back to root directory
$ python ./setup.py install --user
- On a mac, the folder
pyglow
and*.so
files from./models/dl_models/<model>/
should be in/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages
- If you are denied permission, I recommend adding
--user
flag in command
(4) Download the geophysical indices
$ cd ~/
$ python -c "from pyglow import pyglow; pyglow.update_indices()"
- In Python, run:
from pyglow.pyglow import Point
from datetime import datetime
dn = datetime(2011, 3, 23, 9, 30)
lat = 0.
lon = -80.
alt = 250.
pt = Point(dn, lat, lon, alt)
print "Before running any models:"
print pt
pt.run_igrf()
pt.run_hwm93()
pt.run_msis()
pt.run_iri()
print "After running models:"
print pt
- The output should be as follows:
Before running any models:
dn = 2011-03-23 09:30:00
(lat, lon, alt) = (0.00, -80.00, 250.00)
Geophysical Indices:
---------------------
kp = 2.70
ap = 12.00
f107a = 110.47
From IGRF:
-----------
(Bx, By, Bz) = ( nan, nan, nan)
B = nan
dip = nan
From HWM:
------------
hwm version = nan
(u, v) = ( nan, nan)
After running models:
dn = 2011-03-23 09:30:00
(lat, lon, alt) = (0.00, -80.00, 250.00)
Geophysical Indices:
---------------------
kp = 2.70
ap = 12.00
f107a = 110.47
From IGRF:
-----------
(Bx, By, Bz) = (2.448e-05, -6.449e-07, 9.932e-06)
B = 2.642e-05
dip = 22.08
From HWM:
------------
hwm version = 93
(u, v) = (14.07, 12.18)
- Use tab completion in ipython to view the full set of member data and variables available in the Point class.
- For example, in the test code, run
pt.<TAB><TAB>
and class information will be listed.
- You'll need to download the geophysical indices as they become available. The
update_indices()
function is available in pyglow that enables you do this:
from pyglow.pyglow import update_indices
update_indices([2012, 2013]) # grabs indices for 2012 and 2013
update_indices() # grabs all indices starting from 1932 to the current year
- Only need to run this function when you would like to update the indices.
- The install directory for pyglow is outputted when you run the
python ./setup.py install
command. For example, on a mac this is usually in/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/site-packages
. - Simply remove the
*.so
climatological models in this directory, as well as thepyglow
andpyglow_trash
folders.