Skip to content

Rick-Methot-NOAA/SS-DL-tool

 
 

Repository files navigation

The Stock Synthesis Data-limited Tool (SS-DL tool)

The SS-DL tool was developed by Dr. Jason Cope (NWFSC - NOAA) and use Stock Synthesis (Methot and Wetzel 2013) to implement several standard data-limited assessment methods all in one modeling framework. Under a unified modeling framework, additional data can be added as it becomes available. The tool builds Stock Synthesis files for provided data and life history information. It produces full plots and tables for each model run via the r4ss package and additional screen output for straightforward interpretation. Eidi Kikuchi and Dr. Luis Gustavo Cardoso have assisted with the following user guide.

Installing libraries

packages<-c("devtools","shiny","shinyjs","ggplot2","reshape2","dplyr",
"tidyr","Rcpp","rlist","viridis","shinyWidgets","shinyFiles","plyr","shinybusy",
"truncnorm","ggpubr","flextable","officer","gridExtra","wesanderson",
"data.table","adnuts","shinystan","shinyBS","gt","gtExtras","stringr","ggnewscale")

installed_packages <- packages %in% rownames(installed.packages())
if (any(installed_packages == FALSE)) {
  install.packages(packages[!installed_packages], dependencies = TRUE)
}

Make sure the following packages are using the most recent versions:
library(devtools)
devtools::install_github("shcaba/SSS", build_vignettes = TRUE)

install.packages("remotes")
remotes::install_github("r4ss/r4ss")
remotes::install_github("chantelwetzel-noaa/HandyCode")
remotes::install_github("nwfsc-assess/nwfscDiag")

It is recommended to make sure all additional open windows of R or Rstudio 
(beside the one being used) are closed prior to updating libraries, and that one 
restarts Rstudio after all new installations. 
Many of the errors when running the SS-DL tool arise from keeping libraries updated 
or installed (especially r4ss).

Running the SS-DL tool

Running the tool can be accomplished in the following way:

  1. Access the repository SS-DL-tool
  • In "< > Code" Download the ZIP file

JuveYell

  1. Extract the folder SS-DL-tool-master and open the JuveYell or JuveYellfiles

Obs. Before running the first time, open both server.r and ui.r files to make sure all packages are installed. If any package is not installed, RStudio will signal..

JuveYell

in RStudio and push the "Run App" button

I recommend using the "Run External" option within the "Run App" button (see small arrow in button to change options)

JuveYell

  1. The Shiny will open and you can start the example

Imagem3b

Length-only models

These are akin to LBSPR (Hordyk et al. 2015) and LIME (Rudd and Thorson 2017). Both styles of length-only models can be performed in this tool (determined by the estimation of recruitment), and include a choice between estimating F (this attempts to estimate F based on the length compositions) or constant catch approaches (for stock status only; the estimated F values will not be useful on an absolute scale). These length-only models are still in development, but have been applied many times and provide a solid option for situations with only length, whether a snapshot (1 year) or repeated samples (many years).

Example SS-LO Constant Catch

Using constant catch assumes the same catch in all years in order to fit the length composition data (similar to LBSPR, but the model integrates the fit of each year, not each year separately)

It provides a long-term average response (F) to estimating stock status, and thus useful with non-continuous years of sampling.

Import the Length composition

For the example, import the length composition file "Lengths.csv" that is in the "Example data files" folder of the "SS-DL-tool-master".

JuveYell

Lengths.csv file setup

The csv file must be formatted as follows: Year,Month,Fleet,Sex,Nsamps,(Vector of length bins associated with the length data). As in the example:

Year Month Fleet Sex Nsamps 20 25 30 35 40 45 50 55 60
1993 7 1 1 59 0 4 14 9 35 28 11 5 0
1994 7 1 2 73 0 2 15 35 40 32 20 8 3
1993 7 2 0 42 1 8 24 25 15 10 2 0 0
...

Fleet = sequential number for each fleet
Sex = 0 means combined male and female
Sex = 1 means female only
Sex = 2 means male only

If the file is filled in correctly, the compositions referring to the fleets and sexes will be plotted in the "Data and Parameters".

Imagem4c

In the first fleet the data are separated by sex (sex = 1 for females; sex = 2 for males). In the second fleet the sexes are grouped (set sex = 0)

"Nsamps" is the effective sample size of the biological compositions. Effective sample size is used to provide a measure of independent biological sampling units. When fish are sampled they often are not independent of each other (e.g., similar ages or sizes may congregate together). This is why the number of sample individuals is rarely a good estimate of effective (i.e., independent) sample size. While it is hard to know the exact number of independent samples, using sampling units such as tows, hauls, trips or other aggregated units may give a better approximation of independence. It is recommended then to not use the total number of fish as the inputted effective sample size, but to identify a different sampling unit. Input effective sample size sets the relative weights of each sample strata (e.g., year, fleet, sex), and thus should be chosen thoughtfully.

Approach and data weighting

  1. Setup for the Constant Catch approach

  2. Weight fleet lengths by relative catch The relative catch contribution needs specification with multiple length-only fleets Example: Two fleets, with fleet 2 catching 2 times the amount as fleet 1, the entry would be 1,2. Each entry will be relative to the highest value.

  3. Data-weighting Data weighting balances information content of biological data with model structure Data weighting balances across factors (e.g, fleets, sex, etc.) The default value is equally weighting among fleets based on input effective sample size inputs If using an existing model, chose 'None' to maintain the same weighting as the existing model or choose one of the other weighting options.

JuveYell

Life history inputs

To fill in the life history data use the example of what is in the repository JuveYell

If you do not have separate sex data, it is possible to use only female information.

JuveYell

The parameters will be plotted in the "Data and Parameters"

LHc

Stock-recruitment parameters

Enter the Steepness value

Recruitment can also be estimated

JuveYell

Selectivity

Enter parameter and phase values for each fleet and survey.

Example using 50% selectivity with two fleets: Inputs could be 35,40 and 2,2 for starting values and phases respectively.

The phase input indicates estimated parameters. To fix the parameter, set the phase value to a negative number.

If using a mix of logistic and dome-shaped selectivities, select dome-shaped and fix (i.e., use a negative phase) the provided default values (10000,0.0001,0.9999 for the additonal parameters, respectively) to achieve a logistic shape for any given fleet.

Starting selectivity parameters inputs are also in the repositoryJuveYell

Sel

Additional SS options

A list of additional options can be used in the model, for our example we will select the option “Use only one growth type (default is 5)

The number of platoons within a growth type/morph allows exploration of size-dependent survivorship. A value of 1 will not create additional platoons.

Odd-numbered values (i.e., 3, 5) will break the overall morph into that number of platoons creating a smaller, larger, and mean growth platoon. The higher the number of platoons the slower SS will run.

JuveYell

Final step - Run the model

Choose a name for the scenario and the repository

JuveYell

If all the input data are in agreement the following image will appear JuveYell

Examining the results

After running the model the results will be displayed in your browser with a header for each type of output.

Resultsa

The results and plot files will also be saved in your directory. You can always recover these html plots by going into the "plots" folder of the chosen run and selecting any of the .html files.

JuveYell

If you have not selected a directory, the folder containing the template files will be in the "SS-DL-tool-master > Scenarios > plots"

Length composition adjustment

It is important to check the fit of the data in the models.

In this example be sure to check the fit to the length compositions.

LenComp

Also check to see if the selectivity estimates make sense in the "Sel" tab. Always check to see if the selectivity patterns being applied in the model make sense before looking at model outputs as they can have large influences on those outputs.

Selb

Stock status

Stockstatus

The values used to generate the plots can be obtained from the directory JuveYell

Example SS-LO Estimate F

Fishing rate can also be directly estimated from the length composition with no assumption in catches (similar to the LIME approach).

This approach is a more variable response to estimating stock status, and is best used with continuous years of contemporary data. The values of F can jump around, so take care in interpreting the F values. Multiple F values are provided in the model outputs.

Setup and Running

Let's use exactly the same settings as in the previous example (SS-LO Constant Catch).

We will only change the Setup to the Estimate F approach.

After setting the other parameters of "Life history", "Recruitment", "Selectivity" and "Additional SS options" in the same way as the SS-LO Constant Catch example, just run the model.

JuveYell

Examining the results

As with the previous example, before analyzing the results, be sure to check the fit for the length compositions and also check that the selectivity estimates make sense.

Stock status

Stokstatus2

The F-based approach often results in the very last reported year go to drop to zero or very low biomass. Beware of this behavior and report the depletion value in the year of the last catch.

In our example, the year of the last catch is 2020 and the Fraction Unfished for that year is 0.38

Example Length + catch-based (SS-CL)

Used for estimation o biomass , relative biomass, SPR and F and capture limits

Setup and Running

Let's use exactly the same settings as in the previous example (SS-LO).

We will only include the catch series and additional life history parameters.

Catch

Data can be found in the repository JuveYell

You can use names for the sequential fleets if you want. The csv file must be formatted as follows:

Year Commercial Recreational
1892 0.001663661 0
1893 0.001663661 0
1894 0.001663661 0
...

For the catch and length models (SS-CL) it is necessary to include the length-weight relationship W=aL^b and Length-fecundity relationship F=aL^b parameters. These values are also in the "Example data files" folder > "Life history.xlsx"

JuveYell

Obs. Estimating Life history inputs

We provide the fixed life history option example, which mostly what should be done. But life history parameters can also be estimated in the SS-DL tool, and Rudd et al. (2021) give guidance on when that might happen in SS-DL models.

For example, you can estimate natural mortality internally in the model by setting Yes in the "Estimate parameters?" setting JuveYell. Not all parameters need be estimated. To fix other parameters, such as Linf, just turn the phase to negative phase (e.g., -1)

JuveYell

However for this example we will use all life history parameters in a fixed way. After setting the other parameters of "Recruitment", "Selectivity" and "Additional SS options" in the same way as the SS-LO example, just run the model.

JuveYell

Examining the results

As with the previous example, before analyzing the results, be sure to check the fit for the length compositions and also check that the selectivity estimates make sense.

timeseries-SS-CL

The values used to generate the plots can be obtained from the directory JuveYell

Likelihood profiles

Likelihood profiles are a powerful way to understand the information content of data and sensitivity of models to parameter uncertainty.

A likelihood profile fixes a chosen parameter to a specified set of values in a reference model. The reference model will maintain estimation of any other parameters estimated in the reference model.

JuveYell

For example, Steepness (h) could be profiled over the value 0.5 to 0.9 at steps of 0.05. This creates 10 model runs that fix h to different values while keeping all other specifications the same as the reference model (e.g., SS-CL_Example_V01).

JuveYell

For each model run, the likelihood value and derived outputs are retained for analysis.

Any likelihood values >1.96 units from the minimum value are identify as models statistically less supported by the data.

JuveYell

Plots with the profiled parameter values compared to the likelihood values and derived model outputs indicate how much information is contained in the model for the parameter and how sensitive the model is to parameters values resulting non-statistically different models.

The contribution of each likelihood component to the overall likelihood profile can also be explored. This can show what data types are informing what parameter values.

JuveYell

Sensitivity comparison plots

Comparing models derived outputs offers insight into how changing data or model specification change model outputs.

JuveYell

To make these comparisons, choose first the directory containing models, then the models to compare.

JuveYell

A complete compliment of comparison plots are saved in the chosen directory in a folder labeled

JuveYell

JuveYell

SS-CL_V01 SS-LO_Constant_C_V01 SS-LO_Estimate_F_V01
SB0 / SB2020 0.47 0.35 0.39

References

Cope J.M. (2020). The Stock Synthesis Data-limited Tool (SS-DL tool). https://github.com/shcaba/SS-DL-tool#the-stock-synthesis-data-limited-tool-ss-dl-tool (Accessed 01 May 2023).

Hordyk, A., Ono, K., Valencia, S., Loneragan, N., & Prince, J. (2015). A novel length-based empirical estimation method of spawning potential ratio (SPR), and tests of its performance, for small-scale, data-poor fisheries. ICES Journal of Marine Science, 72(1), 217-231.

Methot Jr, R. D., & Wetzel, C. R. (2013). Stock synthesis: a biological and statistical framework for fish stock assessment and fishery management. Fisheries Research, 142, 86-99.

Rudd, M. B., & Thorson, J. T. (2017). Accounting for variable recruitment and fishing mortality in length-based stock assessments for data-limited fisheries. Canadian Journal of Fisheries and Aquatic Sciences, 75(7), 1019-1035.

Rudd, M. B., Cope, J. M., Wetzel, C. R., & Hastie, J. (2021). Catch and length models in the stock synthesis framework: expanded application to data-moderate stocks. Frontiers in Marine Science, 8, 663554.

About

Stock Synthesis Data-limited tool

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • R 99.6%
  • Other 0.4%