Title: | FLSR in TMB |
---|---|
Description: | Estimates FLR spawner recruitment relationships in TMB |
Authors: | Henning Winker [aut, cre], European Union [fnd, cph], Iago Mosqueira [aut] , Christoffer Moesgaard Albertsen [ctb] |
Maintainer: | Henning Winker <[email protected]> |
License: | EUPL |
Version: | 1.1.4.9014 |
Built: | 2024-11-04 07:18:01 UTC |
Source: | https://github.com/flr/FLSRTMB |
blimprior plot Plots the bounds of the hockey-stick break-point
blimprior(lplim = 0.05, uplim = 0.2, s.logitsd = 20, par = "plim")
blimprior(lplim = 0.05, uplim = 0.2, s.logitsd = 20, par = "plim")
lplim |
steepness, default 0.6 for a approx. uniform prior with s.logistsd = 20 |
uplim |
s steepness, default 20 for a approx. uniform prior with s = 0.6 |
par |
parameter on x-axis default "plim", else "sstar" |
s.sdlogit |
default 20 |
ggplot
sprior() # approx. uniform with some curving on bounds sprior(s=0.8,s.logitsd=0.5)
sprior() # approx. uniform with some curving on bounds sprior(s=0.8,s.logitsd=0.5)
Definition ...
bootstrapSR( x, iters = 100, method = c("best", "logLik", "relative"), models = c("bevholt", "ricker", "segreg"), verbose = TRUE, ... )
bootstrapSR( x, iters = 100, method = c("best", "logLik", "relative"), models = c("bevholt", "ricker", "segreg"), verbose = TRUE, ... )
x |
An object of class 'FLStock'. |
models |
Name(s) of model(s) to fit, 'character'. See Details. |
verbose |
Should progress be reported, 'logical'. |
iter |
Number of bootstrap iterations, 'numeric'. |
The returned 'FLPar' object contains
A list with elements An object or class 'FLPar' containing the estimated paramaters.
Iago Mosqueira (WMR)
FLSR, linksrrTMB
data(ple4) mods <- bootstrapSR(ple4, iter=50, model=c("bevholt", "segreg"))
data(ple4) mods <- bootstrapSR(ple4, iter=50, model=c("bevholt", "segreg"))
convert steepness from logit
from_logits(logit_s, ll = 0.2, ul = 1)
from_logits(logit_s, ll = 0.2, ul = 1)
logit_s |
logit(steepness) |
ll |
defines lower prior bound of s |
ul |
defines upper prior bound of s |
steepness s
Generic geometric mean function
gm(x)
gm(x)
x |
object |
FLQuant with annual sprFy
helper to quickly extract blim, r0 and srp0 = blim/b0 from hockeystick
hsblim(object)
hsblim(object)
object |
class FLSR fitted with model segreg |
FLPar
plots Jitter results
plotjitter(jitter)
plotjitter(jitter)
jitter |
output from srrjitter() |
ggplot
data(ple4) hs = srrTMB(as.FLSR(ple4,model=segreg),spr0=spr0y(ple4),lplim=0.07,uplim=0.2) plotsrs(hs) jitter = srrjitter(hs) plotsrs(jitter$groups) plotjitter(jitter) bh = srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=spr0y(ple4)) jitbh = srrjitter(bh) plotjitter(jitbh) plotsrs(jitbh$groups)
data(ple4) hs = srrTMB(as.FLSR(ple4,model=segreg),spr0=spr0y(ple4),lplim=0.07,uplim=0.2) plotsrs(hs) jitter = srrjitter(hs) plotsrs(jitter$groups) plotjitter(jitter) bh = srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=spr0y(ple4)) jitbh = srrjitter(bh) plotjitter(jitbh) plotsrs(jitbh$groups)
plotsrs based on plot(FLSRs) Plots FLSRs, i.e. multiple S-R relationships
plotsrs(object, path = TRUE, b0 = FALSE, rel = FALSE)
plotsrs(object, path = TRUE, b0 = FALSE, rel = FALSE)
object |
of class FLSRS |
path |
connect points sequentially |
ggpplot
data(ple4) bh <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=mean(spr0y(ple4))) plotsrs(bh) plotsrs(bh,b0=TRUE) # plot through to B0 plotsrs(bh,b0=TRUE,rel=TRUE) # plot relative to B0 # Try more models hs <- srrTMB(as.FLSR(ple4,model=segreg),spr0=(spr0y(ple4)),plim=0.05,pmax=0.2) ri <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=mean(spr0y(ple4))) bh.tv <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=spr0y(ple4)) ri.tv <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=spr0y(ple4)) all= FLSRs(hs=hs,bh=bh,ri=ri,bh.tv=bh.tv,ri.tv=ri.tv) plotsrs(all) plotsrs(all,path=FALSE) # plot through to b0 plotsrs(all,b0=TRUE) # plot all relative relative to B0 plotsrs(all,rel=TRUE) plotsrs(all,rel=TRUE,b0=TRUE)
data(ple4) bh <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=mean(spr0y(ple4))) plotsrs(bh) plotsrs(bh,b0=TRUE) # plot through to B0 plotsrs(bh,b0=TRUE,rel=TRUE) # plot relative to B0 # Try more models hs <- srrTMB(as.FLSR(ple4,model=segreg),spr0=(spr0y(ple4)),plim=0.05,pmax=0.2) ri <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=mean(spr0y(ple4))) bh.tv <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=spr0y(ple4)) ri.tv <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=spr0y(ple4)) all= FLSRs(hs=hs,bh=bh,ri=ri,bh.tv=bh.tv,ri.tv=ri.tv) plotsrs(all) plotsrs(all,path=FALSE) # plot through to b0 plotsrs(all,b0=TRUE) # plot all relative relative to B0 plotsrs(all,rel=TRUE) plotsrs(all,rel=TRUE,b0=TRUE)
Plots time series of observed and predicted recruitment
plotsrts(object, relative = TRUE)
plotsrts(object, relative = TRUE)
object |
Input FLSR of FLSRs object |
ggplot
data(ple4) bh <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=mean(spr0y(ple4))) plotsrts(bh) # Try more models hs <- srrTMB(as.FLSR(ple4,model=segreg),spr0=(spr0y(ple4)),plim=0.05,pmax=0.2) ri <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=mean(spr0y(ple4))) bh.tv <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=spr0y(ple4)) ri.tv <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=spr0y(ple4)) all= FLSRs(hs=hs,bh=bh,ri=ri,bh.tv=bh.tv,ri.tv=ri.tv) plotsrts(all) do.call(c,lapply(all,function(x)AIC(x))) # AIC
data(ple4) bh <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=mean(spr0y(ple4))) plotsrts(bh) # Try more models hs <- srrTMB(as.FLSR(ple4,model=segreg),spr0=(spr0y(ple4)),plim=0.05,pmax=0.2) ri <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=mean(spr0y(ple4))) bh.tv <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=spr0y(ple4)) ri.tv <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=spr0y(ple4)) all= FLSRs(hs=hs,bh=bh,ri=ri,bh.tv=bh.tv,ri.tv=ri.tv) plotsrts(all) do.call(c,lapply(all,function(x)AIC(x))) # AIC
Function to compute r, generation time (gt) and annual reproductive rate (alpha)
productivity(object, s = 0.7)
productivity(object, s = 0.7)
object |
class FLStock |
s |
steepness of the stock recruitment relationship |
FLQuants with FLQuant r, gt and alpha
Henning Winker and Laurence Kell
Function to compute annual spr0
spr0y(object, byage = FALSE, simplify = TRUE)
spr0y(object, byage = FALSE, simplify = TRUE)
object |
class FLStock |
byage |
if TRUE it return spr0_at_age |
FLQuant with annual spr0y
Laurence Kell
Function to compute annual sprF as function of F_a
sprFy(object, byage = FALSE)
sprFy(object, byage = FALSE)
object |
class FLStock |
byage |
if TRUE it return sprF_at_age |
FLQuant with annual sprFy
Henning Winker and Laurence Kell
sprior plot Plots the logit prior distribution for steepness
sprior(s = 0.6, s.logitsd = 20, ll = 0.2, ul = 1)
sprior(s = 0.6, s.logitsd = 20, ll = 0.2, ul = 1)
s |
steepness, default 0.6 for a approx. uniform prior with s.logistsd = 20 |
s.logitsd |
s steepness, default 20 for a approx. uniform prior with s = 0.6 |
ll |
lower bound of s = 0.2 |
ul |
lower bound of s = 1 |
ggplot
sprior() # approx. uniform with some curving on bounds sprior(s=0.8,s.logitsd=0.5)
sprior() # approx. uniform with some curving on bounds sprior(s=0.8,s.logitsd=0.5)
Jitter of S-R fits
srrjitter(fit, steps = 100)
srrjitter(fit, steps = 100)
fit |
fit of srrTBM() |
steps |
number of jitter steps |
list
data(ple4) hs = srrTMB(as.FLSR(ple4,model=segreg),spr0=spr0y(ple4),lplim=0.07,uplim=0.5) plotsrs(hs) jitter = srrjitter(hs) plotsrs(jitter$groups) plotsrs(jitter$best) # Best # Relax lower bound plotsrs(FLSRs(init=hs,best=jitter$best))
data(ple4) hs = srrTMB(as.FLSR(ple4,model=segreg),spr0=spr0y(ple4),lplim=0.07,uplim=0.5) plotsrs(hs) jitter = srrjitter(hs) plotsrs(jitter$groups) plotsrs(jitter$best) # Best # Relax lower bound plotsrs(FLSRs(init=hs,best=jitter$best))
Fits Stock Recruitment Relationships (SRR) in TMB
srrTMB(object, ...) ## S4 method for signature 'FLSRs' srrTMB(object, ...) ## S4 method for signature 'FLSR' srrTMB( object, spr0 = "missing", s = NULL, s.est = TRUE, s.logitsd = 20, r0.pr = "missing", lplim = 0.001, uplim = 0.3, Blim = "missing", plim = lplim, pmax = uplim, nyears = NULL, report.sR0 = FALSE, inits = NULL, lower = NULL, upper = NULL, SDreport = TRUE, verbose = FALSE, rm.yrs = "missing" )
srrTMB(object, ...) ## S4 method for signature 'FLSRs' srrTMB(object, ...) ## S4 method for signature 'FLSR' srrTMB( object, spr0 = "missing", s = NULL, s.est = TRUE, s.logitsd = 20, r0.pr = "missing", lplim = 0.001, uplim = 0.3, Blim = "missing", plim = lplim, pmax = uplim, nyears = NULL, report.sR0 = FALSE, inits = NULL, lower = NULL, upper = NULL, SDreport = TRUE, verbose = FALSE, rm.yrs = "missing" )
object |
Input FLSR = as.FLSR(stock,model) object with current model options
|
spr0 |
unfished spawning biomass per recruit from FLCore::spr0(FLStock) |
s |
steepness parameter of SRR (fixed or prior mean) |
s.est |
option to estimate steepness |
s.logitsd |
prior sd for logit(s), default is 1.4 (flat) if s.est = TRUE |
r0.pr |
option to condition models on r0 priors (NULL = geomean) |
lplim |
lower bound of spawning ratio potential SRP, default 0.0001 |
uplim |
upper bound of plausible spawning ratio potential SRP , default 0.3 |
Blim |
fixing Blim, only works with segreg |
plim |
depreciated plim = usrp |
pmax |
depreciated pmax = lsrp |
nyears |
yearMeans from the tail used to compute a,b from the reference spr0 (default all years) |
report.sR0 |
option to report s and R0 instead of a,b |
inits |
option to specify initial values of log(r0), log(SigR) and logit(s) |
lower |
option to specify lower bounds of log(r0), log(SigR) and logit(s) |
upper |
option to specify upper bounds of log(r0), log(SigR) and logit(s) |
SDreport |
option to converge hessian and get vcov |
verbose |
if TRUE, it shows tracing |
rm.yrs |
remove recruitment years from model fit |
A list containing elements 'FLSR', of class FLSR
data(ple4) gm <- srrTMB(as.FLSR(ple4,model=geomean),spr0=mean(spr0y(ple4))) bh <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=spr0y(ple4)) ri <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=spr0y(ple4)) hs <- srrTMB(as.FLSR(ple4,model=segreg),spr0=spr0y(ple4),lplim=0.05,uplim=0.2) srs = FLSRs(gm=gm,bh=bh,ri=ri,hs=hs) # combine plotsrs(srs) plotsrts(srs) # relative plotsrs(srs[2:4],b0=TRUE) # through to B0 plotsrs(srs[2:4],b0=TRUE,rel=TRUE) # relative gm@SV # estimates do.call(rbind,lapply(srs,AIC))
data(ple4) gm <- srrTMB(as.FLSR(ple4,model=geomean),spr0=mean(spr0y(ple4))) bh <- srrTMB(as.FLSR(ple4,model=bevholtSV),spr0=spr0y(ple4)) ri <- srrTMB(as.FLSR(ple4,model=rickerSV),spr0=spr0y(ple4)) hs <- srrTMB(as.FLSR(ple4,model=segreg),spr0=spr0y(ple4),lplim=0.05,uplim=0.2) srs = FLSRs(gm=gm,bh=bh,ri=ri,hs=hs) # combine plotsrs(srs) plotsrts(srs) # relative plotsrs(srs[2:4],b0=TRUE) # through to B0 plotsrs(srs[2:4],b0=TRUE,rel=TRUE) # relative gm@SV # estimates do.call(rbind,lapply(srs,AIC))
convert steepness to logit
to_logits(s, ll = 0.2, ul = 1)
to_logits(s, ll = 0.2, ul = 1)
s |
steepness s |
lim |
defines lower prior bound of s |
max |
defines upper prior bound of s |
logit transformed steepness s