-
Notifications
You must be signed in to change notification settings - Fork 53
Surplus production
VAST
includes features to track fishing mortality F_ct
for each category and year. A 1st order autoregressive process using a log-link (or Poisson-linked delta model) is equivalent to Gompertz density dependence, and it is then possible to track the net effect of past and present fishing mortality on current biomass, as well as calculate biomass and fishing mortality reference points (the latter using "spawning potential ratio" F_%SPR metrics).
We show this process in an example below for Gulf of Alaska pollock. We note that initial fits yielded an implausible value for autocorrelation (and resulting fishing mortality targets). We have therefore taken the F_40% = 0.281 from the 2019 stock assessment and back-calculated the resulting magnitude of first-order autocorrelation, Rho = 0.69. We then fixed this value during model fits.
This approach could be substantially extended in future applications. For example:
- The current approach inputs a fishing mortality
F_ct
, e.g., from a time-series of fishing effort and assumed catchability coefficient within an area-swept estimator. Future developments could instead fit to annual catch data. - The software implementation does not allow autocorrelation in both intercepts
beta
and spatio-temporal variationepsilon
, but this could easily be changed.
For more details see e.g.
- An extended version with movement
- An extended multi-species version
library(VAST)
example = load_example( "GOA_MICE_example" )
# Get settings
settings = make_settings( n_x=50,
purpose="MICE",
Region=example$Region,
n_categories = 1,
max_cells = 5000 )
# Modify defaults
settings$VamConfig['Rank'] = 0 # Reduce to single axis of ratio-dependent interactions
# Subset MICE-in-space example data
sampling_data = subset(example$sampling_data, spp=="Gadus_chalcogrammus")
sampling_data$spp = droplevels(sampling_data$spp)
F_ct = example$F_ct['POLLOCKWCWYK2016',,drop=FALSE]
# Build initial model
# May take many hours, even given informative starting value
Inputs = fit_model( settings = settings,
Lat_i = sampling_data[,'Lat'],
Lon_i = sampling_data[,'Lon'],
b_i = sampling_data[,'Catch_KG'],
a_i = sampling_data[,'AreaSwept_km2'],
v_i = as.numeric(sampling_data[,'Vessel']),
t_i = sampling_data[,'Year'],
F_ct = F_ct,
build_model = FALSE )
# Map off 1st order autocorrelation
# F_40 = 0.281
Map = Inputs$tmb_list$Map
Map$Epsilon_rho1_f = factor(NA)
Params = Inputs$tmb_list$Parameters
Params$Epsilon_rho1_f = 1 - (0.281 / (-1 * log(0.4)))
# Run initial model
# May take many hours, even given informative starting value
Fit = fit_model( settings = settings,
Lat_i = sampling_data[,'Lat'],
Lon_i = sampling_data[,'Lon'],
b_i = sampling_data[,'Catch_KG'],
a_i = sampling_data[,'AreaSwept_km2'],
v_i = as.numeric(sampling_data[,'Vessel']),
t_i = sampling_data[,'Year'],
F_ct = F_ct,
Map = Map,
Parameters = Params,
getsd = TRUE )
# Fix issue in auto-generated plot labels
Fit$year_labels = c( 1975, Fit$year_labels )
Fit$years_to_plot = 1:length(Fit$year_labels) # Plot all years, not just years with samples
# Plots
plot_results( fit = Fit,
settings = settings,
projargs = '+proj=natearth +lon_0=-170 +units=km',
check_residuals = FALSE,
country = "united states of america" )
Example applications:
- Index standardization
- Empirical Orthogonal Functions
- Ordination using joint species distribution model
- End-of-century projections
- Expand length and age-composition samples
- Combine condition and biomass data
- Expand stomach content samples
- Combine presence/absence, counts, and biomass data
- Seasonal and annual variation
- Combine acoustic and bottom trawl data
- Surplus production models
- Multispecies model of biological interactions
- Stream network models
Usage demos:
- Adding covariates
- Visualize covariate response
- Percent deviance explained
- Create a new extrapolation grid
- Custom maps using ggplot
- Modify axes for distribution metrics
- K-fold crossvalidation
- Simulating new data
- Modify defaults for advanced users
Project structure and utilities: