_ _
(_) | |
_ __ ___ _ ___| |_ _ __ __ _
| '_ ` _ \| / __| __| '__/ _` |
| | | | | | \__ \ |_| | | (_| |
|_| |_| |_|_|___/\__|_| \__,_|
Mistra is a one dimensional chemical model of the Marine Boundary layer.
The MistraModel version in this repository is similar -- with small, and mostly cosmetic, differences -- to the Mistra-UEA version. It is released under an open source license (GPLv2, see the LICENSE
file), as agreed by the majority of the Mistra contributors.
For information about authorship, credits, acknowledgements, and funding, see the CREDITS.md
file.
Warning
Note that the Mistra-UEA version of the model was published [Bock et al., Geosci. Model Dev., 2022] without the knowledge or approval of most of the Mistra contributors, and under a licence which was not agreed upon by them. For more information, see the open discussion and the editor comments during the peer-review of the paper on the GMD website: https://gmd.copernicus.org/articles/15/5807/2022/gmd-15-5807-2022-discussion.html
Therefore, the use of the Mistra model in publications is discouraged until all the authorship and licensing issues are resolved. However, the model code is open source and can be reused in other projects under the terms of the GPLv2 license.
The following packages are required:
-
a Fortran compiler. The default is GNU
gfortran
. Use the commandgfortran --version
to check the compiler version. Alternatively the Intelifort
compiler can be used. -
the NetCDF Fortran development library. On Debian (and Debian derivatives) the package is called
libnetcdff-dev
. Depending on the distribution, it may have a different name. Use the commandlocate netcdf.inc
to check that the library is installed and its location. -
the C shell (or the tcsh shell).
-
optional: the plotting software Ferret (https://ferret.pmel.noaa.gov/Ferret/) to use the scripts in the
scripts/
directory.
-
Install KPP-Mistra. Refer to the
README.md
file in the KPP-Mistra repository for instructions. -
Start the C shell (or the tcsh shell).
-
Generate the mechanism files: in
./src/mech/
, executemake
. -
Edit
./src/Makefile
to set the path to the NetCDF library (netcdf.inc
, see above) and the NetCDF compilation flags (-lnetcdf
or-lnetcdff
or-lnetcdf -lnetcdff
). Change the Fortran compiler if needed (the default isgfortran
). -
Compile the code: in
./src/
, executemake
. -
In the
param/param_...
file, set the appropriate path to the Mistra input files. It is advised to use a directory that will not be duplicated for each version the user will run, but choose a generic directory instead. Set the appropriate path to parent output directory, to the executable, and set the namelist to be used. Run theparam_...
file to run the model.
For more information, see the manual (manual_Mistra_v9.0.pdf
) in the doc/
directory.