Skip to main content

3-D ionospheric model plotting suite

Project description

PyGemini

ci ci ci ci

A Python interface to Gemini3D, funded in part by NASA HDEE.

Setup

Python ≥ 3.7 is required. We recommend Python ≥ 3.8 in general for full features / robustness.

Setup PyGemini by:

git clone https://github.com/gemini3d/pygemini

pip install -e pygemini

build

Not all users need to run Gemini3D on the same device where PyGemini is installed. PyGemini uses the "build on run" method developed by Michael Hirsch, which allows complex multi-language Python packages to install reliably across operating systems (MacOS, Linux, Windows). Upon the first gemini3d.run(), the underlying Gemini3D code is built, including all necessary libraries.

python -m gemini3d.prereqs

allows manually installing those libraries to save rebuild time, but this is optional as Gemini3D automatically downloads and builds missing libraries.

Developers

For those working with GEMINI Fortran code itself or to work with non-release versions of GEMINI Fortran code:

  1. install PyGemini in development mode as above
  2. set environment variable GEMINI_ROOT to the Gemini3D Fortran code directory, otherwise PyGemini will Git clone a new copy.

Run simulation

  1. make a config.nml with desired parameters for an equilibrium sim.

  2. run the equilibrium sim:

    python -m gemini3d.run /path_to/config_eq.nml /path_to/sim_eq/
    
  3. create a new config.nml for the actual simulation and run

    python -m gemini3d.run /path_to/config.nml /path_to/sim_out/
    

Plots

An important part of any simulation is viewing the output. Because of the large data involved, most plotting functions automatically save PNG stacks to disk for quick flipping through with your preferred image viewing program.

Grid

Help ensure the simulation grid is what you intended by the following, which can be used before or after running the simulation.

import gemini3d.plot

gemini3d.plot.grid("path/to/sim")

simulation outputs

These commands create plots and save to disk under the "plots/" directory under the specified data directory.

command line:

python -m gemini3d.plot path/to/data -save png

or from within Python:

import gemini3d.plot as plot

plot.frame("path/to/data", datetime(2020, 1, 2, 1, 2, 3), saveplot_fmt="png")

# or

plot.plot_all("path/to/data", saveplot_fmt="png")

Convert data files to HDF5

There is a a script to convert data to HDF5, and another to convert grids to HDF5. The scripts convert from {raw, Matlab, NetCDF4} to HDF5. The benefits of doing this are especially significant for raw data, and HDF5 may compress by 50% or more, and make the data self-describing.

python scripts/convert_data.py h5 ~/mysim
python scripts/convert_grid.py h5 ~/mysim/inputs/simgrid.dat

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

gemini3d-1.3.2.tar.gz (71.9 kB view details)

Uploaded Source

File details

Details for the file gemini3d-1.3.2.tar.gz.

File metadata

  • Download URL: gemini3d-1.3.2.tar.gz
  • Upload date:
  • Size: 71.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.25.1 setuptools/47.3.1.post20200622 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.5

File hashes

Hashes for gemini3d-1.3.2.tar.gz
Algorithm Hash digest
SHA256 1b89b9962d26a6d56382c4fa6e0266699f551d2c9ab1b5957b561f0790d351d2
MD5 8018d538a5e0cb809b526f8a52095df6
BLAKE2b-256 d1ee3267f453820e37e59ac0cf61a0803eb0d1b26c5cea6e62a2ec0a628d4d16

See more details on using hashes here.

Supported by

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