Learn R Programming

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

DLMtool

DLMtool is a R package for management strategy evalaution and implementation of data-limited fishery stock assessment methods.

Find more information about DLMtool at http://datalimitedtoolkit.org/.

Installation

The released version of DLMtool can be downloaded from CRAN:

install.packages("DLMtool")

This GitHub repository contains the development version of DLMtool. The development version may be unstable, and it is not recommended for analyses.

User Guide and Documentation

A DLMtool User Guide and documentation for the DLMtool package are now available: https://dlmtool.github.io/DLMtool/.

Bugs and Issues

Please report any bugs or issues through GitHub or the DLMtool website.

Copy Link

Version

Install

install.packages('DLMtool')

Monthly Downloads

389

Version

4.4.1

License

GPL-2

Maintainer

Tom Carruthers

Last Published

August 3rd, 2017

Functions in DLMtool (4.4.1)

BlankSelPlot

Internal function to create a blank plot for mapping selectivity at length
Blow_opt

Blow internal parallel optimization function
AvC

Average Catch
BK

Beddington and Kirkwood life-history MP (simple version)
Blue_shark

Blue_shark Stock
Bluefin_tuna

Bluefin_tuna Stock
BK_CC

Beddington and Kirkwood life-history method combined with catch curve analysis
BK_ML

Beddington and Kirkwood life-history analysis with mean-length estimator of current abundance
Albacore

Albacore Stock
Atlantic_mackerel

Atlantic_mackerel Data
CC1

Constant catch management procedure of Geromont and Butterworth (2014)
CC4

Constant catch management procedure of Geromont and Butterworth (2014)
ChooseM

Manually map natural mortality at age or size.
CSRAfunc

Optimization function for CSRA
CalcInput

Apply input control recommendations and calculate population dynamics
ChkObj

Check that a DLM object is valid
ChooseEffort

Manually map the historical relative fishing effort trajectory.
DBSRA

Depletion-Based Stock Reduction Analysis
DBSRA4010

Depletion-Based Stock Reduction Analysis paired with 40-10 harvest control rule
DDe75

Effort control version of DD - Delay - Difference Stock Assessment with UMSY and MSY leading that fishes at 75 per cent of FMSY
DDes

Effort searching version of DD - Delay - Difference Stock Assessment with UMSY and MSY leading that fishes at 75 per cent of FMSY
CalcOutput

Apply output control recommendations and calculate population dynamics
Can

What data-limited methods can be applied to this Data object?
Cobia

Cobia Data
Bluefin_tuna_WAtl

Bluefin_tuna_WAtl Stock
Butterfish

Butterfish Stock
Cant

What methods can't be applied to this DLM data object
CheckConverg

MSE convergence diagnostic
Data_xl

Read in Data object from Excel spreadsheet
DecE_Dom

DecE_Dom Fleet
FMSYref50

A reference FMSY method that fishes at half of FMSY (uses perfect information about FMSY)
FMSYref75

A reference FMSY method that fishes at three quarters of FMSY (uses perfect information about FMSY)
COSEWIC_plot

COSEWIC forward projection plot
CSRA

Catch at size reduction analysis
China_rockfish

China_rockfish Data
ChkDatNA

Check Data object is valid for a MP
ChooseSelect

Manually choose the historical selectivity pattern
Cplot

Plot the median biomass and yield relative to last historical year
DAAC

Depletion Adjusted Average Catch
DD

Delay - Difference Stock Assessment with UMSY and MSY leading
DD4010

Delay - Difference Stock Assessment with UMSY and MSY leading coupled with a 40-10 harvest control rule
DOM

How dominant is an MP?
DTe40

Effort searching MP aiming for 40 per cent stock depletion
FMSYopt

Internal function FMSY and related metrics
Feasibility2

Feasibility2 Fease
FlatE_Dom

FlatE_Dom Fleet
Fleet-class

Class 'Fleet'
FMSYref

A reference FMSY method (uses perfect information about FMSY)
Fease_xl

Read in feasibility parameters from Excel spreadsheet
Feasibility

Feasibility Fease
Fratio

An FMSY/M ratio method
DCAC

Depletion Corrected Average Catch
DCAC4010

Depletion Corrected Average Catch paired with the 40-10 rule
DCAC_40

Depletion Corrected Average Catch assuming 40 per cent stock depletion
DCAC_ML

Depletion-Based Stock Reduction Analysis using mean-length estimator of current depletion
ForceCor

Forces correlation among operating model parameters for M, K, Linf and L50
Generic_DecE

Generic_DecE Fleet
Generic_FlatE

Generic_FlatE Fleet
CompSRA

Age-composition-based estimate of current stock depletion given constant Z linked to an FMSY estimate to provide OFL
DBSRA_40

Depletion-Based Stock Reduction Analysis assuming 40 per cent stock depletion
DBSRA_ML

Depletion-Based Stock Reduction Analysis using mean length estimator of stock depletion
DD_R

Internal optimization function for delay-difference MPs
ITM

Index Target based on natural mortality rate
ITe10

Index Target Effort-Based 10
Islope4

A management procedure that incrementally adjusts the TAC to maintain a constant CPUE or relative abundance index
Itarget1

A management procedure that incrementally adjusts the TAC (starting from reference level that is a fraction of mean recent catches) to reach a target CPUE / relative abundance index
ItargetE4

A management procedure that incrementally adjusts the Effort to reach a target CPUE / relative abundance index
Jplot

Joint probability plot
LSRA_opt

Internal estimation function for LSRA and LSRA2 functions
DFO_proj

Deparment of Fisheries and Oceans projection plot
DecE_HDom

DecE_HDom Fleet
DecE_NDom

DecE_NDom Fleet
DDe

Effort control version of DD - Delay - Difference Stock Assessment with UMSY and MSY leading
DTe50

Effort searching MP aiming for 50 per cent stock depletion
Data-class

Class 'Data'
DepF

Depletion Corrected Fratio
DFO_plot2

Deparment of Fisheries and Oceans default plot 2
DynF

Dynamic Fratio MP
Fadapt

An adaptive MP that uses trajectory in inferred suplus production and fishing mortality rate to update a TAC
Fdem

Demographic FMSY method
Fratio_CC

A data-limited method that uses FMSY/M ratio and a naive catch-curve estimate of recent Z
LSRA_opt_cpp

Internal estimation function for LSRA and LSRA2 functions
LtargetE1

A management procedure that incrementally adjusts the Effort to reach a target mean length in catches.
LtargetE4

A management procedure that incrementally adjusts the Effort to reach a target mean length in catches.
ML2D

Depletion and F estimation from mean length of catches
MPStats

Calculate Statistics for MP Performance
OM_xl

Read in operating model parameters from Excel spreadsheet
Obs-class

Class 'Obs'
Red_snapper

Red_snapper Data
Replace

Replace an existing Stock, Fleet, Obs, or Imp object
Fratio_ML

An FMSY/M ratio MP that uses a mean length estimator of recent Z
GB_target

Geromont and Butterworth target CPUE and catch MP
Gcontrol

G-control MP
ICI2

Less Precautionary Index Confidence Interval (ICI) MP by Jardim et al. (2015)
SPMSY

Catch trend Surplus Production MSY MP
SPSRA

Surplus Production Stock Reduction Analysis
SelectFun

Selectivity at length function
Sense

Sensitivity analysis
Fdem_CC

Demographic FMSY method using catch-curve analysis to estimate recent Z
Fdem_ML

Demographic FMSY method that uses mean length data to estimate recent Z
FlatE_HDom

FlatE_HDom Fleet
FlatE_NDom

FlatE_NDom Fleet
Generic_obs

Generic_obs Obs
GetMoreData

Load more data from DLMdata package
ITe5

Index Target Effort-Based 5
Fratio4010

An FMSY/M ratio method paired with the 40-10 rule
Gulf_blue_tilefish

Gulf_blue_tilefish Data
HDAAC

Hybrid Depletion Adjusted Average Catch
Herring

Herring Stock
ICI

Index Confidence Interval (ICI) MP by Jardim et al. (2015)
Iratio

Mean index ratio MP from Jardim et al. 2015
Islope1

A management procedure that incrementally adjusts the TAC to maintain a constant CPUE or relative abundance index
L95target

A management procedure that adjusts the TAC up/down from reference (target) level (that is a fraction of mean recent premanagement catches) to reach a target mean length of fish caught.
StochasticSRA

Stochastic SRA construction of operating models
StochasticSRA2

Stochastic SRA construction of operating models
TAC

Calculate TAC recommendations for more than one MP
TACfilter

TAC Filter
YPR_ML

Yield Per Recruit analysis to get FMSY proxy F01 paired with a mean-length estimate of current stock size
CompSRA4010

Age-composition-based estimate of current stock depletion given constant Z linked to an FMSY estimate to provide OFL (with a 40-10 rule)
Converge

Check Convergence
DFO_hist

Deparment of Fisheries and Oceans historical plot
DFO_plot

Deparment of Fisheries and Oceans trade-off plot
alphaconv

Calculate alpha parameter for beta distribution from mean and standard deviation
betaconv

Calculate beta parameter for beta distribution from mean and standard deviation
boxplot.Data

Boxplot of TAC recommendations
doprojPI_cpp

Rcpp version of the Projection function for calculating Reference Yield
IOTC_plot

Indian Ocean Tuna Commission trade-off plot
Imprecise_Biased

Imprecise_Biased Obs
Imprecise_Unbiased

Imprecise_Unbiased Obs
DLMDataDir

Directory of the installed package on your computer
DLMtool-package

Data-Limited Methods Toolkit
EtargetLopt

Effort MP: adjust effort up/down if mean length above/below Ltarget
Example_datafile

Example_datafile Data
Fease-class

Class 'Fease'
Fease

MP feasibility diagnostic
GB_CC

Geromont and Butterworth Constant Catch Harvest Control Rule
GB_slope

Geromont and Butterworth index slope Harvest Control Rule
Imp-class

Class 'Imp'
Input

Function to run a set of input control methods
InputRec-class

Class 'InputRec'
Itarget4

A management procedure that incrementally adjusts the TAC (starting from reference level that is a fraction of mean recent catches) to reach a target CPUE / relative abundance index
ItargetE1

A management procedure that incrementally adjusts the effort to reach a target CPUE / relative abundance index
LinInterp

Linear interpolation of a y value at level xlev based on a vector x and y
Low_Effort_Non_Target

Low_Effort_Non_Target Fleet
LBSPR_ItEff

Length-based SPR model with HCR that iteratively adjusts Effort
LBSPR_ItSel

Length-based SPR model with HCR that iteratively adjusts Selectivity
Lratio_BHI

Mean length-based indicator MP of Jardim et al. 2015 using Beverton-Holt invariant M/K ratio = 1.5 and assumes FMSY = M.
Lratio_BHI2

The more general version of the mean length-based indicator MP of Jardim et al. 2015.
Ltarget1

A management procedure that incrementally adjusts the TAC to reach a target mean length in catches.
Ltarget4

A management procedure that incrementally adjusts the TAC to reach a target mean length in catches.
NFref

No Fishing Reference MP
NOAA_plot

National Oceanographic and Atmospheric Administration default plot 1
Generic_IncE

Generic_IncE Fleet
Generic_fleet

Generic_fleet Fleet
IT10

Index Target 10
IT5

Index Target 5
Needed

Data needed to get MPs running
OM-class

Class 'OM'
Required

What methods need what data
Rockfish

Rockfish Stock
LstepCC1

A management procedure that incrementally adjusts the TAC according to the mean length of recent catches.
LstepCC4

A management procedure that incrementally adjusts the TAC according to the mean length of recent catches.
MPclass

Return class of MP from MP name
fetch.file.names

Reads iSCAM Data, Control and Projection files
getFMSY2

Calculate FMSY and related metrics using Rcpp code
getFMSY3

Calculate FMSY and related metrics using Rcpp code
hist2

Wrapper for histogram function
SPSRA_ML

Surplus Production Stock Reduction Analysis using a mean-length estimate of current stock depletion
SPmod

Surplus production based catch-limit modifier
iSCAM2DLM

Reads MLE estimates from iSCAM file structure into an operating model
makePerf

Convert a OM object to one without observation or process error
makeTransparent

Make colors transparent
movdistil

Simplified a multi-area transition matrix into the best 2 x 2 representation
movfit

Optimization function that returns the squared difference between user specified and calculated movement parameters. (deprecated: now in Rcpp)
plotFun

Print out plotting functions
plotM

Plot M-at-Age and Size
popdynOneTScpp

Population dynamics model for one annual time-step
SampleFleetPars

Sample Fleet Parameters
projOpt_cpp

Rcpp version of the Projection Optimizer
read.report.file

Reads iSCAM Rep file
replic8

Enlarge (replicate) a DLM data object to create an additional dimension for simulation / sensitivity testing
sample_steepness2

Sample steepness given mean and cv
LBSPR

Apply the Length-based SPR model to DLMtool Data Object
LBSPR_ItTAC

Length-based SPR model with HCR that iteratively adjusts TAC
LSRA

Estimates R0 using SRA to match current F estimates and avoid penalities for low stock sizes
LstepCE1

A management procedure that incrementally adjusts the TAC according to the mean length of recent catches.
sampy

Sample vector
MRnoreal

An marine reserve in area 1 with no spatial reallocation of fishing effort
Perfect_Imp

Perfect_Imp Imp
Perfect_Info

Perfect_Info Obs
Pplot2

A projection by projection plot of F/FMSY, B/BMSY, B/B0, and yield
Precise_Biased

Precise_Biased Obs
SampleImpPars

Sample Implementation Error Parameters
Stock-class

Class 'Stock'
Sub

Subset MSE object by management procedure (MP) or simulation.
Target_All_Fish

Target_All_Fish Fleet
LstepCE2

A management procedure that incrementally adjusts the Effort according to the mean length of recent catches.
Mackerel

Mackerel Stock
NAor0

Is a value NA or zero.
Porgy

Porgy Stock
Targeting_Small_Fish

Targeting_Small_Fish Fleet
VOI2

Calculate Value Of Information 2
VOIplot

Yet another Value of Information Plot
compplot

Generic comparison plot for simulation testing of Stochastic SRA method
SRAsim

Simulates catch at age and catch history data for testing SRA methods
SRopt

Function that returns a stochastic estimate of steepness given observed stock recruitment data
Sam

Conduct stock assessment
condmet

Condition met?
getBH

Predict Beverton-Holt recruitment and return fit to S-R observations
getBlow

Blow parallel optimization function
getFref

Internal Get Reference F
getFref2

Internal Get Reference F using Rcpp
getroot

Calculate slope from ageM and age95
gettempvar

Creates a time series per simulation that has gradient grad and random normal walk with sigma
matlenlim

A data-limited method in which fishing retention is set according to the maturity curve
matlenlim2

A data-limited method in which fishing vulnerability is set slightly higher than the maturity curve
optBH

Wrapper for estimating stock recruitment parameters from resampled stock-recruitment data
optF

Internal function to optimize for F
optQ_cpp

Rcpp version of the q Optimizer
ourReefFish

Example data object
Pplot

A projection by projection plot of F/FMSY and B/BMSY
Precise_Unbiased

Precise_Unbiased Obs
Range

Standardize values
SPslope

Slope in surplus production MP
SRAcomp

Plot simulation test of Stochastic SRA method
SampleObsPars

Sample Observation Parameters
SampleStockPars

Sample Stock parameters
SetRecruitCycle

Function to calculate cyclic recruitment pattern given user-specified values of period and amplitude.
SampleCpars

Sample custom pars
SketchFun

Manually map the historical relative fishing effort trajectory.
Snapper

Snapper Stock
SubCpars

Subset an OM cpars slot
IncE_HDom

IncE_HDom Fleet
IncE_NDom

IncE_NDom Fleet
Kplot

KOBE plot: a projection by projection plot of F/FMSY and B/BMSY
L2A

Length to age conversion
popdynCPP

Population dynamics model in CPP
popdynOneTS

Population dynamics model for one annual time-step
read.par.file

Reads iSCAM parameter file
read.projection.file

Reads iSCAM projection file
LSRA2

Alternative version of LSRA that's a wrapper for LSRA_opt to return the right type of output (mode) using sapply
LSRA_MCMC_sim

Internal SRA MCMC CPP code
MCD

Mean Catch Depletion
MCD4010

Mean Catch Depletion
MRreal

An marine reserve in area 1 with full reallocation of fishing effort
MSE-class

Class 'MSE'
OneRep

Make stochastic variables certain for only one rep
Simulation_1

Simulation_1 Data
Toothfish

Toothfish Stock
Tplot

A trade-off plot for an MSE object
avail

What objects of this class are available
sdconv

Get log normal standard deviation from transformed space mean and standard deviation
setup

Setup parallel processing
userguide

Open the DLMtool User Guide
validcpars

Valid custom parameters (cpars)
Overages

Overages Imp
Rcontrol

Harvest Control Rule using prior for intrinsic rate of increase
Rcontrol2

MP using prior for intrinsic rate of increase with a quadratic approximation to surplus production
SBT1

SBT simple MP
SubOM

Subset a Stock, Fleet, Obs, or Imp object from an OM object
TwoSidedFun

Internal Two sided selectivity curve
VOI

Calculate Value Of Information
curE75

Fishing at 75 per cent of current effort levels
barplot.MSE

Plot a barplot of MSE results
boxplot.MSE

Boxplot of MP performance from MSE object
checkMSE

Check that MSE object includes all slots
derive_beta_par

This function reduces the CV by 5 per cent until steepness values can be sampled without error
cv

Calculate CV from vector of values
getEffhist

Calculate historical fishing mortality
getSlope2

Internal function to calculate slope
doprojPI

Internal Projection Function
getFref3

Calculate Reference Yield
getFs

Internal function to calculate F-at-age given catch and biomass
getq2

Optimization function that find the catchability (q where F=qE) value required to get to user-specified stock depletion (current biomass / unfished biomass) modified for Rcpp
getq3

optimize for catchability (q)
iSCAM2Data

Reads data from iSCAM file structure into a DLMtool Data object
iSCAMcomps

Combines all iSCAM age composition data across fleets
movfit_Rcpp

Rcpp version of the Optimization function that returns the squared difference between user specified and calculated movement parameters.
getFMSY

Calculate FMSY and related metrics
SBT2

SBT complex MP
SS2DLM

Reads MLE estimates from Stock Synthesis file structure into an operating model using package r4ss
SS2Data

Reads data Stock Synthesis file structure into an data object using package r4ss
Sole

Sole Stock
Splot

Scatter plot of B/BMSY or B/B0 and F/FMSY for lastYrs
Tplot2

A shorter version of the plot method for MSEs that just shows the overall trade-offs
TradePlot

Generic Trade-off Plot
YPR

Yield Per Recruit analysis to get FMSY proxy F01
negcorlogspace

A function that samples multivariate normal (logspace) variables
plotImp

Plot the Implementation object parameters
plot,MSE,ANY-method

Plot MSE object
plotStock

Plot the Stock object parameters
popdyn

Population dynamics model
read.data.file

Reads iSCAM dat file
read.mcmc

Reads iSCAM mcmc output files
simYears

Simulate population dynamics for historical years
slotlim

An data-limited method which sets a slot limit
getSlopeFun

Internal function to calculate slope
getclass

get object class
getmov

Optimization function to find a movement model that matches user specified movement characteristics.
iSCAMinds

Combines indices into a single index using linear modelling
trlnorm

Generate log-normally distributed random numbers
updateMSE

Update an MSE object with new slots
initialize-methods

~~ Methods for Function initialize ~~
optMSY

Optimize yield for a single simulation
optQ

Optimize q for a single simulation
plot,Data,ANY-method

Plot Data object
YPR_CC

Yield Per Recruit analysis to get FMSY proxy F01 paired to a naive catch curve estimate of recent Z
cparscheck

Internal function of runMSE for checking that the OM slot cpars slot is formatted correctly
curE

Fishing at current effort levels
plotFleet

Plot the Fleet object parameters
qopt

Internal optimization function that find the catchability (q where F=qE) value required to get to user-specified stock depletion (current biomass / unfished biomass)
read.control.file

Reads iSCAM control file
runMSEnomsg

runMSE with no messages - for testing
runMSErobust

Run a Management Strategy Evaluation
summary,Data-method

Summary of Data object
summary,MSE-method

Summary of MSE object
genLenComp

Generate length composition of catch
getAFC

Calculate age at first capture from length at first capture and growth
getGpars

Extracts growth parameters from a SS3 r4ss replist
getSlope1

Internal function to calculate ascending slope of selectivity curve
getmov2

Optimization function to find a movement model that matches user specified movement characteristics modified for Rcpp.
getq

Optimization function that find the catchability (q where F=qE) value required to get to user-specified stock depletion (current biomass / unfished biomass)
joinMSE

Join multiple MSE objects together
load.iscam.files

Reads iSCAM files into a hierarchical R list object
mconv

Get log normal mean from transformed space mean and standard deviation
minlenLopt1

This input control sets the minimum length of fish caught to a fraction of the length that maximises the biomass, Lopt.
plot.OM

Plot the operating model (OM) object parameters
plotObs

Plot the Observation object parameters
plotOFL

A generic OFL plot for NOAA use
plotSelect

Plot the vulnerability and retention curves
runInMP

Runs input control MPs on a Data object.
runMSE

Run a Management Strategy Evaluation
tdlnorm

Calculate density of log-normally distributed random numbers
testOM

testOM OM
wormplot

Biomass wormplot
writeCSV

Internal function to write CSVs for objects