/gmse

An R package for simulating Generalised Management Strategy Evaluation

Primary LanguageTeX

Generalised Management Strategy Evaluation

The GMSE package integrates game theory and ecological theory to construct social-ecological models that simulate the management of populations and stakeholder actions. These models build off of a previously developed management strategy evaluation (MSE) framework to simulate all aspects of management: population dynamics, manager observation of populations, manager decision making, and stakeholder responses to management decisions. The newly developed generalised management strategy evaluation (GMSE) framework uses genetic algorithms to mimic the decision-making process of managers and stakeholders under conditions of change, uncertainty, and conflict. Simulations can be run using gmse(), gmse_apply(), and gmse_gui() functions. For more, see the GMSE website.


This project has received funding from the European Union's Horizon 2020 research and innovation programme under grant agreement No 679651 to Nils Bunnefeld. Package maintainer Brad Duthie has been funded by a Leverhulme Trust ECF.


Installation

Install from CRAN

To install this package from CRAN.

install.packages("GMSE")

Install with GitHub

To install this package from GitHub, make sure that the devtools library is installed.

install.packages("devtools")
library(devtools)

Use install_github to install using devtools.

install_github("ConFooBio/GMSE")

Running a simulation

To run a simulation, use the gmse() function.

sim <- gmse();

Optional arguments taken by gmse() are used to specify simulation parameter values. Simulation results will be plotted automatically given the default plotting = TRUE, but can be plotted again using the plot_gmse_results function.

plot_gmse_results(sim);

Simulations can also be run from a browser-based graphical user interface by running the gmse_gui() function.

gmse_gui();

This function is also available as a standalone application in shiny.

Finally, simulations can be run using gmse_apply(), a function for modellers that allows the integration of custom resource, observation, manager, and user subfunctions into the GMSE framework. The gmse_apply() function simulates a single time step and can incorporate both custom and standard gmse() arguments.

# Example alternative, custom-made, logistic growth resource function
alt_res <- function(X, K = 2000, rate = 1){
    X_1 <- X + rate*X*(1 - X/K);
    return(X_1);
}
# Incorproate into gmse_apply with standard gmse arguments
sim <- gmse_apply(res_mod = alt_res, X = 1000, stakeholders = 6); 

Problems or requests can be introduced on the GMSE GitHub issues page or Wiki, or emailed to Brad Duthie.

Documentation

For additional help in getting started with GMSE, the following vignettes are available.

  • GMSE introduction: A general overview of GMSE, including a short example simulation and how to interpret the output.
  • The genetic algorithm: Further details on what the genetic algorithm is and how it works in GMSE.
  • Use of gmse_apply: An extended introduction to the gmse_apply function, and how to use it to further customise simulations.
  • Example case study: An example case study illustrating how gmse or gmse_gui could be used to simulate a scenario of conflict between farmers and waterfowl conservation.
  • Advanced options: Example use of gmse_apply in the farmer and waterfowl case study demonstrating advanced customisation that is possible in GMSE.
  • Fisheries integration: Introduction to how GMSE could be linked to other packages such as the Fisheries Library in R (FLR) using gmse_apply.
  • Replicate simulations: Introduction to the use of replicate simulatoins for model inference, with an example of how this can be done in GMSE.
  • GMSE data structures: Detailed explanation of key data structures used in GMSE.
  • Adaptive timing of investment strategy: Example in which managers intervene adaptively based on the deviation of a population from its target.
  • The simulated annealing algorithm of GMSE: Explanation of the simulated annealing algorithm, which functions as an alternative to the genetic algorithm for agent decision-making in GMSE.

Descriptions of individual GMSE functions are provided in the GMSE documentation available on CRAN.

GMSE References

Duthie, A. B., Cusack, J. J., Jones, I. L., Nilsen, E. B., Pozo, R. A., Rakotonarivo, O. S., Moorter, B. Van, & Bunnefeld, N. (2018). GMSE: an R package for generalised management strategy evaluation. Methods in Ecology and Evolution, 9, 2396-2401. https://doi.org/10.1101/221432

Duthie, A. B., A. Bach, & J. Minderman (2021). GMSE: Generalised Management Strategy Evaluation Simulator. R package version 0.7.0.0. https://confoobio.github.io/gmse/

Publications using GMSE

Bach, A., J. Minderman, N. Bunnefeld, A. Mill, A. B. Duthie. (2022). Intervene or wait? Modelling the timing of intervention in conservation conflicts adaptive management under uncertainty. Ecology and Society. In press.

Nilsson, L., Bunnefeld, N., Jeroen, M., & Duthie, A. B. (2021). Effects of stakeholder empowerment on crane population and agricultural population. Ecological Modelling, 440, 109396. https://doi.org/10.1016/j.ecolmodel.2020.109396

Cusack, J. J., Duthie, A. B., Minderman, J., Jones, I. L., Rakotonarivo, O. S., & Bunnefeld, N. (2020). Integrating conflict, lobbying, and compliance to predict the sustainability of natural resource use. Ecology and Society, 25(2), 13.

Bunnefeld, N., Pozo, R.A., Cusack, J.J., Duthie, A.B. & Minderman, J. 2020. Development of a population model tool to predict shooting levels of Greenland barnacle geese on Islay.
Scottish Natural Heritage Research Report No. 1039.