MAGE - Without TIEGCM (GR) Quick Start ========================================== These instructions illustrate the process of running a geospace simulation using the MAGE model without coupling with TIEGCM. We call this version of the model "GR" ("GAMERA-RAIJU") for brevity. Before you begin -------------------------------------------- *Source* (not *run*) the environment setup scripts for the ``kaiju`` software. For example: .. code-block:: bash source /path/to/your/kaiju/scripts/setupEnvironment.sh Running a geospace simulation with MAGE -------------------------------------------- The MAGE software needs several files in order to run. The detailed steps for creating these files have been combined into a script called ``makeitso.py``. The script is provided in the ``kaiju`` code repository. More information on ``makeitso.py`` is available :doc:`here `. You can see the options supported by ``makeitso.py`` by running it with the ``--help`` or ``-h`` command-line option. .. code-block:: bash makeitso.py --help usage: makeitso.py [-h] [--clobber] [--debug] [--mode MODE] [--options_path OPTIONS_PATH] [--verbose] Interactive script to prepare a MAGE geospace model run. optional arguments: -h, --help show this help message and exit --clobber Overwrite existing options file (default: False). --debug, -d Print debugging output (default: False). --mode MODE User mode (BASIC|INTERMEDIATE|EXPERT) (default: BASIC). --options_path OPTIONS_PATH, -o OPTIONS_PATH Path to JSON file of options (default: None) --verbose, -v Print verbose output (default: False). For this example, we will run the code on ``derecho``, and use the default ``BASIC`` mode, which requires the minimum amount of input from the user. At each prompt, you can either type in a value, or hit the :kbd:`Return` key to accept the default value (shown in square brackets at the end of the prompt). To get started, load the CDF library (needed for fetching solar wind data) and run ``makeitso.py`` with no arguments: .. code-block:: bash source /path/to/your/cdf/bin/definitions.B $KAIJUHOME/scripts/makeitso/makeitso.py Name to use for PBS job(s) [geospace]: Do you have an existing boundary condition file to use? (Y|y|N|n) [N]: Start date for simulation (yyyy-mm-ddThh:mm:ss) [2001-06-01T23:00:00]: Stop date for simulation (yyyy-mm-ddThh:mm:ss) [2001-06-02T01:00:00]: Do you want to split your job into multiple segments? (Y|y|N|n) [N]: GAMERA grid type (D|Q|O|H) [Q]: Name of HPC system (derecho|aitken) [aitken]: derecho PBS account name []: Run directory [.]: Path to kaiju installation []: Path to kaiju build directory []: PBS queue name (develop|main|preempt) [main]: Job priority (regular|economy) [economy]: WARNING: You are responsible for ensuring that the wall time is sufficient to run a segment of your simulation! Requested wall time for each PBS job segment (HH:MM:SS) [01:00:00]: 12:00:00 (GAMERA) Relative path to HDF5 file containing solar wind boundary conditions [bcwind.h5]: (VOLTRON) File output cadence in simulated seconds [60.0]: After these inputs, the script fetches data from CDAWeb for the specified time range to use in the solar wind boundary condition file, and generates XML and PBS files for the run, as well as a grid file for use in the model. You should see output similar to this: .. code-block:: bash Generating Quad LFM-style grid ... Output: lfmQ.h5 Size: (96,96,128) Inner Radius: 2.000000 Sunward Outer Radius: 30.000000 Tail Outer Radius: 322.511578 Low-lat BC: 45.000000 Ring params: Writing to lfmQ.h5 /glade/u/home/ewinter/miniconda3/envs/kaiju-3.12/lib/python3.12/site-packages/spacepy/time.py:2367: UserWarning: Leapseconds may be out of date. Use spacepy.toolbox.update(leapsecs=True) warnings.warn('Leapseconds may be out of date.' Retrieving f10.7 data from CDAWeb Retrieving solar wind data from CDAWeb Using Bx fields Bx Fit Coefficients are [4.00339086 -0.20513105 -0.33969058] Saving "OMNI_HRO_1MIN.txt_bxFit.png" Converting to Gamera solar wind file Found 21 variables and 120 lines Offsetting from LFM start ( 0.00 min) to Gamera start ( 0.00 min) Saving "OMNI_HRO_1MIN.txt.png" Writing Gamera solar wind to bcwind.h5 Making new raijuconfig.h5, destroying pre-existing file if there Stamping file with git hash and branch, and script args Adding waveModel to raijuconfig.h5 Reading /glade/derecho/scratch/ewinter/cgs/aplkaiju/kaipy-private/dev_312/kaipy-private/kaipy/raiju/waveModel/chorus_polynomial.txt Adding Species to raijuconfig.h5 Adding params used to generate lambda distribution as root attribute Template creation complete! The PBS scripts ['./geospace-00.pbs'] have been created, each with a corresponding XML file. To submit the jobs with the proper dependency (to ensure each segment runs in order), please run the script geospace_pbs.sh like this: bash geospace_pbs.sh You should now see the following files in your run directory: .. code-block:: bash ls bcwind.h5 geospace.json OMNI_HRO_1MIN.txt_bxFit.png geospace-00.pbs geospace_pbs.sh OMNI_HRO_1MIN.txt.png geospace-00.xml lfmQ.h5 raijuconfig.h5 The image files are summaries of the CDAWeb data used in the initial condition file (``bcwind.h5``). Those plots should look similar to this: .. image:: Bx_fit_gr.png .. image:: sw_gr.png Finally, submit the model run using the script generated by ``makeitso.py``. You will see the resulting PBS job ID (your job ID will differ from what is shown below). .. code-block:: bash bash geospace_pbs.sh 7808651.desched1 Once the job is started in the queue, it should take about 80 minutes to run (on ``derecho``). When complete, you will see many new HDF5 files in your run directory, along with PBS housekeeping files and logs. The most important files are (repeated upper-case letters in the names represent integer strings): * ``geospace_LLLLL_MMMMM_NNNNN_IIIII_JJJJJ_KKKKK.gam.h5`` These files contain the core MHD variables from the simulation, computed by the GAMERA portion of the MAGE model. The strings ``LLLLL``, ``MMMMM``, and ``NNNNN`` contain the number of subsections of the ``X``, ``Y``, and ``Z`` dimensions used to divide the domain among MPI ranks. The strings ``IIIII``, ``JJJJJ``, and ``KKKKK`` represent the MPI rank index along each dimension. * ``geospace.mix.h5`` This file contains the results from the `REMIX `_ portion of the `MAGE `_ model. * ``geospace.raiju.h5`` This file contains the results from the RAIJU portion of the `MAGE `_ model. * ``geospace.volt.h5`` This file contains the results from the VOLTRON portion of the `MAGE `_ model. * ``*Cpl*.h5`` Data used in coupling the different members of the model suite. * ``*.Res.RRRRR.h5`` These are checkpoint files generated during the simulation which can be used as restart points for future simulations. Visualizing the results ----------------------- Now perform a quick visualization of the results from your model using the ``msphpic.py`` script, provided in the ``kaipy`` package. .. code-block:: bash msphpic.py -id geospace This script will create a file called ``qkmsphpic.png``, which should look similar to this: .. image:: qkmsphpic_gr.png