Skip to content

Latest commit

 

History

History

SimplyP

SimplyP (Mobius version)

SimplyP is a parsimonious hydrology, sediment and phosphorus model. The model is dynamic, with a daily time step, and is spatially semi-distributed, i.e. there is the ability to include differences in hydrology, sediment and phosphorus processes between land use types and sub-catchments (with associated stream reaches). Key philosophies behind SimplyP development are:

  1. Process representation should be as simple as possible, only including those processes that appear to dominate the catchment-scale response, whilst maintaining sufficient complexity for the model to be useful in hypothesis and scenario testing.
  2. Process representation should be simple enough to allow parameter values to be constrained using available data. This involves keeping the number of parameters requiring calibration to a minimum, and aiming for as many parameters as possible to be in principle measurable, so their values can be based on observed data (either gathered from the study site or literature-based). We aim for it to be possible to include all uncertain parameters in uncertainty analysis.

Examples of potential model uses include:

  1. Interpolating sparse monitoring data, to provide more ecologically-relevant estimates of in-stream phosphorus concentrations, or more accurate estimates of loads delivered downstream to lakes or estuaries;
  2. Hypothesis testing and highlighting knowledge and data gaps. This in turn could be used to help design monitoring strategies and experimental needs, and prioritise areas for future model development;
  3. Exploring the potential response of the system to future environmental change (e.g. climate, land use and management), including potential storm and low-flow dynamics;
  4. Providing evidence to support decision-making, e.g. to help set water quality and load reduction goals, and advise on means of achieving those goals.

The model was originally developed in Python and is described here:

Jackson-Blake LA, Sample JE, Wade AJ, Helliwell RC, Skeffington RA. 2017. Are our dynamic water quality models too complex? A comparison of a new parsimonious phosphorus model, SimplyP, and INCA-P. Water Resources Research, 53, 5382–5399. doi:10.1002/2016WR020132

Full details of version 0.1 of the model are provided in the Supplementary Information, and the main updates and changes to the model are documented in the change log. The Python version of the model (up to v0.2) is still available.

The Mobius version offers dramatic performance improvements compared to the Python version (run times are at least two orders of magnitude faster). It is now also very easy to make changes to the model and create alternative versions, and we hope that this flexibility will encourage collaborative testing and further model development. The Mobius Python wrapper means the benefits of interacting with the model through Python are still available, and we have already used the wrapper to develop very nice optimization and MCMC procedures for SimplyP (see tutorial 2 below). As with all models coded using Mobius, SimplyP can be run using the Mobius Graphical User Interface (a relatively user-friendly program where you can click to change parameters, run the model and explore the output).

Further development of SimplyP will take place using the Mobius framework. We have yet to shift the known issues and other documentation across from the original Python repository, so please visit the original repository for more information. Please report any bugs either by submitting a pull request via GitHub (in which case, please link to the Simply project), or by emailing Leah Jackson-Blake ([email protected]). Suggested improvements are also very welcome.

Tutorials

Tutorial 1: Quick start - Run the Tarland example using the MobiView graphical user interface

  • Follow the instructions here to:
    • Download MobiView, the graphical user interface that you will use to run the SimplyP model. Download from ftp://mobiserver.niva.no/ (open file explorer on your computer, and copy and paste the ftp server address directly into the address bar). The MobiView executable is in the 'MobiView' folder.
    • Download SimplyP and example datasets: Pre-compiled stable releases of SimplyP are available for download from ftp://mobiserver.niva.no/, in the SimplyP folder, together with some example datasets.
    • Open MobiView.exe and read in:
      • The compiled SimplyP dll
      • An input file, TarlandInputs.dat. Input .dat files for SimplyP must contain precipitation and temperature data to drive the model. In addition, they can optionally include potential evapotranspiration data to drive the model, and observed data to compare model output to. The TarlandInputs.dat file includes observations of stream discharge and concentrations of suspended sediment and various phosphorus species.
      • A parameter file, TarlandParameters_v0-3.dat. The parameter file version must match the model version. This file includes all the model parameters, as well as their units, recommended ranges and parameter descriptions. Parameters may vary over catchment/reach and landscape type (see the parameter file).

More detailed descriptions of the structure of Mobius model input and parameter files are given in the documentation.

  • Run the model and explore the results. More detailed instructions for using MobiView are here
  • Try changing parameter values and re-running the model to see what happens.

If you want to know exactly what the results variables are or how they are calculated, you can look at the model description paper, or directly into the SimplyP.h file (here). Results in MobiView correspond to equations in the SimplyP.h file.

Tutorial 2: Compile SimplyP for yourself

Instead of downloading SimplyP from the ftp server, you can compile it yourself. You will need to be able to this if you want to make any changes to the model equations:

  • If you haven't already, installing a compiler
  • Download/clone the GitHub Mobius repository onto your computer (see instructions here), and familiarize yourself with the basics of the Mobius model building system and the contents of the repository (introductory documentation is here).
  • Compile SimplyP:
    • Open up the command line (Press Windows+R to open the “Run” box. Type “cmd” and then click “OK” to open a regular Command Prompt)
    • From the command line cd into the Mobius GitHub repository Applications/SimplyP folder
    • Run the compile_dll.bat file, by typing it direcly into the command prompt and then hitting enter. simplyp.dll should be created.

Notes:

  • Some people have issues installing software (e.g. the MingW compiler) on their system due to admin rights and/or over-zealous antivirus software. We recommend you beg your IT department to give you full admin rights at least temporarily, and disable your antivirus software during install if you're having troubles.

Tutorial 3: Auto-calibration and uncertainty estimation with the Python wrapper.

An example illustrating how to auto-calibrate SimplyP and explore parametric uncertainty using MCMC.

  • Download/clone the GitHub Mobius repository onto your computer (see instructions here), and familiarize yourself with the basics of the Mobius model building system and the contents of the repository (introductory documentation is here).

  • Work through the example Jupyter notebook in the PythonWrapper/SimplyP folder in the repository. You can do this interactively if you download the Mobius repository. Otherwise, you can just view it online. For instructions on getting started with Python, Jupyter notebooks and the python wrapper, see https://github.com/NIVANorge/Mobius/tree/master/PythonWrapper#python-wrapper.

More coming soon!

Folder contents

  • The main model definition file is not in this folder, but here.

  • Morsa and Tarland folders contain example input files for two catchments, the Tarland catchment in northeast Scotland, and the Morsa (also known as the Vansjø-Hobøl) catchment in southeast Norway. Input files include (1) parameter .dat files, which in this case are rough manually calibrated values for the two catchments, and (2) time series .dat files. The time series files include meteorological data to drive the models, as well as observed data for comparing simulated output to. See the documentation for a further description of input file formats, to help you modify or make your own files.

  • Two .cpp files and accompanying compile.bat files which are used to compile different kinds of model executables (don't worry, compiling is easy, see here for a quick description of why/when you compile, and a walk through of how it's done):

    • simplyp_dll.cpp (compiled using compile_dll.bat): this creates a .dll which is then used by the python wrapper or the MobiView GUI. You shouldn't need to alter this .cpp for different model applications.
    • simplyp_testing.cpp (compiled using compile_testing.bat): this creates a .exe which is useful for testing during model devleopment. This .cpp contains things you should change for different model applications. It also contains flags for doing useful things like creating an .exe which, when run, creates a new parameter file using the structure you define in the .cpp file and the default parameter values defined in the model header file SimplyP.h. This can also be done in MobiView.
  • three .dat files for setting up optimization and uncertainty analysis in C++, i.e. without use of the python wrapper. More info on this will come shortly.