Parameterization for Unified Microphysics Across Scales
This repository contains the open source code for most versions of the Morrison-Gettleman (MG) microphysics as well as the version which includes a unified ice closure and is now called the Parameterization for Unified Microphysics Across Scales, or PUMAS.
The code in this repository is not sufficient for completing a simulation outside of the included Kidd emulator. For instructions on running with Kidd, see below. To run within the Community Atmosphere Model (CAM), you will need to either check out a branch of CAM that has the appropriate modifiecations to support this PUMAS build structure, or checkout a version and make those modifications.
These are instructions for checking out a branch of CAM that already includes the modifications. These could be used as an example for modification of other CAM source to include PUMAS.
-
Clone a repository that contains a PUMAS-adapted CAM source tree. ::
git clone https://github.com/Katetc/CAM.git Github_CAM_PUMAS_Clone
This will create a directory
Github_CAM_PUMAS_Clone
in your current working directory. -
Go into the newly created directory and checkout the PUMAS adapted branch. ::
cd Github_CAM_PUMAS_Clone git checkout cam_pumas_development
-
Run the script manage_externals/checkout_externals. ::
./manage_externals/checkout_externals
The checkout_externals script is a package manager that will populate the cesm directory with the relevant versions of each of the components along with the CIME infrastructure code.
At this point you have all of the code needed for CAM and CESM, with the PUMAS microphysics available.
-
To run a single column (SCAM) test, copy the script ::
Github_CAM_PUMAS_Clone/src/physics/pumas/cesm_test_scripts/scam6-mgX.test.csh
to another local directory. Edit or change the paths and script options as needed and then call that script from the command-line. ::
cd test_scripts/ ./scam6-mgX.test.csh
-
To run a global (F2000climo) test, copy the script ::
Github_CAM_PUMAS_Clone/cesm_test_scripts/F2000_mgX_globalcesm_test.csh
to another local directory. Edit or change the paths and script options as needed and then call that script from the command-line. ::
cd test_scripts/ ./F2000_mgX_globalcesm_test.csh
-
To make changes to PUMAS, first create a branch for your work in the ESCOMP/PUMAS Github repository by clicking on the "Branch:master" drop down box on the middle left part of the main page (just below the purble line), and type the name of your new branch into the "Find or create a branch..." text area.
For new branch names, it is generally a good idea to put your Github name first, and then the goal of the branch after a slash. So, a name for a branch to fix conservation bugs might be "katetc/graupel_consv_fix". Hit enter, and your new branch is now shown in Github.
-
The second step for making changes in PUMAS is to update the source code in the pumas subdirectory to work with this branch. For various reasons, we are not going to use manage_externals for this. Just cd into the pumas subdirectory and checkout your remote branch. ::
cd Github_CAM_PUMAS_Clone/src/physics/pumas git checkout -b katetc/graupel_consv_fix
Note: Doing this is incompatible with manage_externals. If you need to run manage_externals to checkout other externals, you will probably need to repoint your pumas branch back to your development branch manually afterwards.
-
Once you have your own branch checked out, you can make local changes to the code. When it's time to commit them, you will need to ::
git add filename.F90 git commit -m "Commit message" git push
This will push your changes to your remote branch. When you have finished with ALL of your changes (can be multiple commits), then it will be time to merge your branch changes back to the master branch in the ESCOMP/PUMAS repo. You can do this by clicking "Pull requests" in the PUMAS github repo main page, and then the big green "New Pull Request" button. In the gray bar, for the "compare" pull down, click and select your branch. This will show all of the differences between your branch and the master PUMAS branch. If you are happy with these changes, click the green "Create pull request" button again, and that will take you to a pull request form. Fill out a description of your changes and issue the pull request. This request will be reviewed by a software engineer and then merged into the main branch. Your development branch can then be deleted, and you can start a new one for the next issue.
Instructions to be added soon!
Gettelman, A., H. Morrison, K. Thayer‐Calder, and C. M. Zarzycki. 2019. The Impact of Rimed Ice Hydrometeors on Global and Regional Climate. Journal of Advances in Modeling Earth Systems. https://doi.org/10.1029/2018MS001488.
Gettelman, A. and H. Morrison, Advanced Two-Moment Microphysics for Global Models. Part I: Off line tests and comparisons with other schemes. J. Climate, 28, 1268-1287. doi: 10.1175/JCLI-D-14-00102.1, 2015.
Gettelman, A., H. Morrison, S. Santos, P. Bogenschutz and P. H. Caldwell. Advanced Two-Moment Microphysics for Global Models. Part II: Global model solutions and Aerosol-Cloud Interactions. J. Climate, 28, 1288-1307. doi:10.1175/JCLI-D-14-00103.1 , 2015.