Description of methods to access CGS models results using kaipy and tiegcmpy
This repository provides basic instructions for setting up and using the kaipy and tiegcmpy packages for accessing results from the MAGE models. At the moment these software package are in beta phase as we would appreciate feedback on the tools as well as contributions. Questions and feedback can be directed to Michael Wiltberger via email to [email protected].
The tools for accessin MAGE model data are bulit upon Python so a working knowledge of python is requried to use them. You will also need an installation of python that allows you to install packages. While technically not required JupyterLab will also be helpful since we will be providing notebooks that provide examples of ways to plot and access the model results.
We have made kaipy and tiegcmpy installable via pip from the PyPi index. We are currently working a more tight integration with conda, but for now pip is the prefered method doing installations.
First step is to create virtual python environment to use with the installation of the tools. You may chose any name for the environment we are going to use cgs-mage-tools
for this tutorial. Using the conda package manmager
()$ conda create -n cgs-mage-tools python=3.8
()$ conda activate cgs-mage-tools
(cgs-mage-tools)$ pip install kaipy
The tiegcmpy package utilizes Cartopy for adding contentianal information to the plots. Since installing the dependices for Cartopy can be tricky we've found it helpful to install via the conda-forge channels before installing tiegcmpy into your environment.
(cgs-mage-tools)$ conda install -c conda-forge cartopy
(cgs-mage-tools)$ pip install tiegcmpy
After completing this step you will have a conda virtual environment that has the kaipy and tiegcm packages as well as some scirpts for producing quicklook plots and conducting analysis of MAGE model results.
If you want to use this environment with JupyterLab you need to use ipykernels to make it available to JupyterLab. Starting by installing nb_conda_kernels
into your base conda virtual environment.
(base)$ conda install -c conda-forge nb_conda_kernels
and then we can make the kernel available JupyterLab via
(base)$ conda activate cgs-mage-tools
(cgs-mage-tools)$ conda install ipykernel
(cgs-mage-tools)$ conda deactivate
One last thing before we leave the installation step, making note of where python has installed the analysis scripts and notebooks will be helpful a little later on in this tutorial. The following command will get the location of the directory from the pip command.
(cgs-mage-tools)$ pip show -f kaipy | grep Location | awk '{print $2"/kaipy"}'
making note of this directory or storing it in an environment variable will be helpful. If you are using csh the following command will save it into environment variable
(cgs-mage-tools)$ setenv CGSKAIPY `pip show -f kaipy | grep Location | awk '{print $2"/kaipy"}'`
Simulation data can get quite large and that is certainly the case with the MAGE model components. We are using Globus for sharing access to simulation results. You will need to sign up for a free account at Globus.org.
Once you login into the website you can use the file manager to search for the "GAMERA Parallel Test" collection and download the files to your local machine for data processing. The files can also be accessed by clicking here
To gain access to sample results from the TIEGCM search for "TIEGCM Benchmark 2.0" collection and download the files to your machine. You can access these files by clicking here
Now we will use the data you downloaded from globus to be the data you can use within a Jupyter Notebook for data visualization and analysis.
After starting your JupyterLab server you will need to open the KaijuExamplePlot notebook file in the $CGSKAIPY/tutorial/
directory.
In cell number two you will need to set the fdir
variable to location of the GAMERA files on your computer before executing the notebook.
Once you execute the notebook you will see this image in cell number 6
The notebook provides the basic instructions for accessing both magnetospheric and ionospheric data. Where you go from there is entirely up to you!
We have also made available a variety of python scripts for quick look plots, movies, and more robust data analysis. These files are available in the $CGSKAIPY/scripts directory Here is an incomplete listing of the some of the routines
- msphpic.py – image the magnetosphere
- gamspVid.py - movie of the magnetosphere
- mixpic.py – image of ionospheric data
- cda2wind.py – create solar wind input from CDAWeb
- genmpiXDMF.py – create XDMF file from parallel run for import into paraview
The mixpic script will produce the following image from the Gamera parallel data set.
As part of the SPLASH simulation toolkit we are investigating cloud based access to simulation results. Using the Paraview web visualizer running on a Amazon Cloud instance users will be able to interact in real-time with 3D datasets.
Working with Austrian Open Science Center we have begun efforts to create cloud based instances of JupyterLab with the kiapy analysis tools collocated with simulation results.