Learn R Programming

⚠️There's a newer version (2.5.3) of this package.Take me there.

mizer

Mizer is an R package to run dynamic multi-species size-spectrum models of fish communities. The package has been developed to model marine ecosystems that are subject to fishing. However, it may also be appropriate for other ecosystems.

The package contains routines and functions to allow users to set up an ecosystem model, and then project it through time under different fishing strategies. Methods are included to explore the results, including plots and calculation of community indicators such as the slope of the size spectrum. Size-based models can be complicated so mizer contains many default options that can be easily changed by the user.

Mizer has been supporting research in marine ecology and fisheries science since 2014 (see publications). It is still under active development. The new version 2.0 has increased the user-friendliness and the flexibility of the framework. Contributions from the user community are very welcome. There is a sister package called mizerExperimental where user contributions can be checked out and receive feedback from the community. Example mizer models can be contributed to mizerExamples.

Does your project or publication use mizer? If so, we would love to know. You can also join our Google Discussion group here: https://groups.google.com/forum/#!forum/size-spectrum-models

Recent work on mizer was funded by the European Commission Horizon 2020 Research and Innovation Programme under Grant Agreement No 634495 for the project MINOUW (http://minouw-project.eu/) and the Australian Research Council Discovery Project Rewiring Marine Food Webs.

Installation

The package is on CRAN and therefore available from R’s built-in package manager.

# Install release version from CRAN
install.packages("mizer")

# Alternatively, install development version from GitHub
devtools::install_github("sizespectrum/mizer")

Example

The following code loads the mizer package, loads some information about species in the North Sea that comes as an example with the package, sets up the parameters for the mizer model, and runs a simulation for 10 years.

library(mizer)
params <- newMultispeciesParams(NS_species_params, inter)
sim <- project(params, t_max = 10, effort = 0)

The results of the simulation can then be analysed, for example via plots:

plot(sim)

See the accompanying Get started page for more details on how the package works, including detailed examples.

Dynamic multi-species size-spectrum models

A mizer model captures the interactions between multiple species. The growth rates of fish are determined by the availability of prey and the death rates are influenced by the abundance of predators, as well as fishing. The model starts with the individual-level physiological rates for each species, as well as the predation preferences, and deduces the population-level dynamics from these. Thus quantities like fish diets and fisheries yields emerge dynamically and can be projected into the future.

Because a mizer model tracks the size of individuals as they grow up over several orders of magnitude from their egg size to their maximum size, it correctly tracks the ontogenetic diet shifts. An individual typically moves through several trophic levels during its life time. This is often not correctly captured in other multi-species models.

A mizer model can be set up with only a small amount of information because it uses allometric scaling relations and size-based feeding rules to choose sensible defaults for unknown parameters.

Setting up a new multi-species mizer model is a two-step process, similar to what may be familiar from Ecopath with Ecosym: First one calibrates the model to describe a steady state that is in agreement with current observations (as in Ecopath), then one chooses the additional parameters that determine the dynamics away from the steady state (as in Ecosym). This model can then be used to investigate future effects of changes in fishing policy or of environmental stressors.

Modelling environmental change

A mizer model is a good tool for studying the effect of environmental changes, like climate change, because it is a mechanistic model that can deduce the complex population-level changes that one is interested in from the simpler changes in the physiological rates and feeding interactions of individual fish species.

Smooth traffic on the biomass highway

It is interesting to think of the marine ecosystem as a transport system that moves biomass from the size of primary producers (mostly unicellular plankton) up to the sizes of fish that humans like to consume. Each fish that grows up from egg size to maturity by eating smaller individuals is like a car on this biomass highway. The yield of our fisheries depend on this traffic flowing smoothly and without traffic jams.

In road traffic, if traffic density gets too high in a section of the highway, drivers slow down, which leads to a pile-up producing even higher traffic density, leading to further slow-down in a potentially vicious cycle known as a traffic jam. Traffic management that ignores how the traffic density affects traffic speed fails. Luckily our mathematical understanding of transport equations has made practical contributions to managing traffic in ways that produce smoother traffic flow and hence higher throughput.

Mizer implements the transport equations for marine ecosystems. The potential for traffic jams is the same: if for example there is a high density of predators of a particular size, which all have preference for prey of a particular smaller size, then due to competition for that prey the growth of those predators slows down, leading to a pile-up which leads to further depletion of prey, leading to further slow-down, in a potentially vicious cycle.

Luckily the natural ecosystem has evolved to facilitate very smooth traffic on the biomass highway with resultant high productivity. This state is characterised by an approximate power-law shape of the biomass size spectrum. The purpose of mizer is to allow us to understand how various stressors, like fishing or climate change, affect the size spectrum and hence flow of biomass and the productivity and resilience of the marine ecosystem. Mizer allows us to investigate how size-based fisheries management strategies can be used to keep the ecosystem close to its natural productive state.

A model one can understand

One big advantage of a mizer model is that it is based on a strong mathematical foundation. This allows a degree of a priori understanding of the behaviour of the model that is absent in many other multi-species model. This theoretical foundation is well presented in the book “Fish Ecology, Evolution, and Exploitation” by Ken Andersen.

Copy Link

Version

Install

install.packages('mizer')

Monthly Downloads

397

Version

2.0.3

License

GPL-3

Issues

Pull Requests

Stars

Forks

Maintainer

Gustav Delius

Last Published

July 28th, 2020

Functions in mizer (2.0.3)

MizerSim

Constructor for the MizerSim class
NS_species_params_gears

Example species parameter set based on the North Sea with different gears
NS_species_params

Example species parameter set based on the North Sea
MizerParams

Alias for set_multispecies_model
MizerSim-class

A class to hold the results of a simulation
NOther

Time series of other components
BevertonHoltRDD

Beverton Holt function to calculate density-dependent reproduction rate
box_pred_kernel

Box predation kernel
MizerParams-class

A class to hold the parameters for a size based model.
constantRDD

Give constant reproduction rate
constant_other

Helper function to keep other components constant
finalNOther

Values of other ecosystem components at end of simulation
getERepro

Get energy rate available for reproduction
finalN

Size spectra at end of simulation
getEGrowth

Get energy rate available for growth
emptyParams

Create empty MizerParams object of the right size
double_sigmoid_length

Length based double-sigmoid selectivity function
N

Time series of size spectra
NS_params

Example MizerParams object for the North Sea example
RickerRDD

Ricker function to calculate density-dependent reproduction rate
SheperdRDD

Sheperd function to calculate density-dependent reproduction rate
getCommunitySlope

Calculate the slope of the community abundance
getCriticalFeedingLevel

Get critical feeding level
default_pred_kernel_params

Set defaults for predation kernel parameters
getMeanMaxWeight

Calculate the mean maximum weight of the community
getEReproAndGrowth

Get energy rate available for reproduction and growth
getDiet

Get diet of predator at size, resolved by prey species
getEffort

Fishing effort used in simulation
getEncounter

Get encounter rate
getBiomass

Calculate the total biomass of each species within a size range at each time step.
getFeedingLevel

Get feeding level
getBiomassFrame

Get data frame of biomass of species through time, ready for ggplot2
getGrowthCurves

Get growth curves giving weight as a function of age
getComponent

Get information about other ecosystem components
getM2Background

Alias for getResourceMort
getM2

Alias for getPredMort
getESpawning

Alias for getERepro
getFMortGear

Get the fishing mortality by time, gear, species and size
getFMort

Get the total fishing mortality rate from all fishing gears by time, species and size.
get_gamma_default

Get default value for gamma
getProportionOfLargeFish

Calculate the proportion of large fish
getZ

Alias for getMort
getYieldGear

Calculate the total yield per gear and species
getPredRate

Get predation rate
getMort

Get total mortality rate
getN

Calculate the number of individuals within a size range
getPredKernel

Get predation kernel
getPredMort

Get total predation mortality rate
getParams

Extract the parameter object underlying a simulation
getMeanWeight

Calculate the mean weight of the community
indicator_functions

Description of indicator functions
idxFinalT

Time index at end of simulation
mizerEReproAndGrowth

Get energy rate available for reproduction and growth needed to project standard mizer model
getTimes

Times for which simulation results are available
get_required_reproduction

Determine reproduction rate needed for initial egg abundance
getSSB

Calculate the SSB of species
get_phi

Get values from feeding kernel function
getResourceMort

Get predation mortality rate for resource
mizerFMort

Get the total fishing mortality rate from all fishing gears by time, species and size needed to project standard mizer model
mizerFMortGear

Get the fishing mortality by time, gear, species and size needed to project standard mizer model
getRDD

Get density dependent reproduction rate
getYield

Calculate the total yield of each species
get_h_default

Get default value for h
mizerPredMort

Get total predation mortality rate needed to project standard mizer model
getPhiPrey

Get available energy
get_initial_n

Calculate initial population abundances for the community populations
mizerRates

Get all rates needed to project standard mizer model
mizerEncounter

Get encounter rate needed to project standard mizer model
mizerRDI

Get density-independent rate of reproduction needed to project standard mizer model
initialNResource<-

Initial value for resource spectrum
getRDI

Get density independent rate of egg production
get_ks_default

Get default value for ks
initialN<-

Initial values for fish spectra
get_size_range_array

Get size range array
initialNOther<-

Initial values for other ecosystem components
plotGrowthCurves

Plot growth curves giving weight as a function of age
plotFeedingLevel

Plot the feeding level of species by size
lognormal_pred_kernel

Lognormal predation kernel
mizer-package

mizer: Multi-species size-based modelling in R
mizerEGrowth

Get energy rate available for growth needed to project standard mizer model
get_time_elements

Get_time_elements
mizerResourceMort

Get predation mortality rate for resource needed to project standard mizer model
newCommunityParams

Set up parameters for a community-type model
mizerERepro

Get energy rate available for reproduction needed to project standard mizer model
plotM2

Alias for plotPredMort
mizerPredRate

Get predation rate needed to project standard mizer model
reexports

Objects exported from other packages
inter

Example interaction matrix for the North Sea example
mizerMort

Get total mortality rate needed to project standard mizer model
mizerFeedingLevel

Get feeding level needed to project standard mizer model
plotPredMort

Plot predation mortality rate of each species against size
plotSpectra

Plot the abundance spectra
project

Project size spectrum forward in time
resource_constant

Keep resource abundance constant
setExtMort

Set external mortality rate
plotYield

Plot the total yield of species through time
project_simple

Project abundances by a given number of time steps into the future
setFishing

Set fishing parameters
setInitialValues

Set initial values to final values of a simulation
summary,MizerSim-method

Summarize MizerSim object
setReproduction

Set reproduction parameters
setResource

Set up resource
setInteraction

Set species interaction matrix
setRateFunction

Set own rate function to replace mizer rate function
setPredKernel

Set predation kernel
plotDiet

Plot diet
plotFMort

Plot total fishing mortality of each species by size
sigmoid_length

Length based sigmoid selectivity function
plot,MizerSim,missing-method

Summary plot for MizerSim objects
sigmoid_weight

Weight based sigmoidal selectivity function
resource_encounter

Dummy function used during testing only
knife_edge

Weight based knife-edge selectivity function
w

Size bins
validate_effort_vector

Check that an effort vector is specified correctly
newTraitParams

Set up parameters for a trait-based model
noRDD

Give density-independent reproduction rate
log_breaks

Helper function to produce nice breaks on logarithmic axes
newMultispeciesParams

Set up parameters for a general multispecies model
resource_semichemostat

Project resource using semichemostat model
plotting_functions

Description of the plotting functions
plotBiomass

Plot the biomass of species through time
power_law_pred_kernel

Power-law predation kernel
setLinetypes

Set linetypes to be used in mizer plots
summary_functions

Description of summary functions
setRmax

Set maximum reproduction rate
setMaxIntakeRate

Set maximum intake rate
setSearchVolume

Set search volume
set_species_param_default

Set a species parameter to a default value
set_trait_model

Deprecated function for setting up parameters for a trait-based model
plotYieldGear

Plot the total yield of each species by gear through time
setColours

Set line colours to be used in mizer plots
semichemostat

Dummy function used during testing only
retune_erepro

Retune reproduction efficiency to maintain initial egg abundances
setComponent

Add a dynamical ecosystem component
setMetabolicRate

Set metabolic rate
species_params

Species parameters
set_multispecies_model

Deprecated obsolete function for setting up multispecies parameters
steady

Set initial values to a steady state for the model
set_community_model

Deprecated function for setting up parameters for a community-type model
summary,MizerParams-method

Summarize MizerParams object
upgradeParams

Upgrade MizerParams object from earlier mizer versions
truncated_lognormal_pred_kernel

Truncated lognormal predation kernel
test_dyn

Dummy function used during testing only
validGearParams

Check validity of gear parameters and set defaults
validSpeciesParams

Validate species parameter data frame
upgradeSim

Upgrade MizerSim object from earlier mizer versions