-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathFLBEIA_Using_Assessment_models_in_the_MP.Rmd
638 lines (482 loc) · 27 KB
/
FLBEIA_Using_Assessment_models_in_the_MP.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
---
title: "Using different Assessment models in the Management Procedure of FLBEIA"
# author: "Sonia Sanchez and FLBEIA team"
date: "`r format(Sys.time(), '%d %b, %Y')`"
output:
github_document:
mathjax: TRUE
pdf_document:
fig_width: 6
fig_height: 4
toc: yes
tags: [FLBEIA assessment]
license: Creative Commons Attribution-ShareAlike 4.0 International Public License
bibliography: bibliography.bib
---
```{r, ini, echo=FALSE, results='hide', message=FALSE}
# This chunk set the document environment, so it is hidden
library(knitr)
source("R/ini.R")
knitr::opts_chunk$set(fig.align='center',
message=FALSE, warning=FALSE, echo=TRUE, cache=FALSE)
options(width=50)
set.seed(1423)
```
```{r logo, echo=FALSE, out.width='20%'}
include_graphics('images/FLBEIA_logo.png')
```
# Aim
**FLBEIA** [@garcia2017] provides a battery of tutorials for learning how to use this software.
This is the thirth tutorial of **FLBEIA** and it is a practical guide about how to
implement different assessment models within **FLBEIA**.
In this tutorial they are presented some examples on how to include different
assessment models in the management procedure to generate the observed population.
The Management Procedure Model (MPM) is divided into 3 components: the observation,
the assessment and the management advice.
The observation component produces the required data to run the assessment.
Then, the assessment component is applied to those data to obtain the observed populations.
Finally, the management advice component produces a management advice based on the observed
populations.
MPM procedure is applied yearly in the appropriate season of the year. Not necessarily in
the last season, for example, it can be simulated as in the case of anchovy in the Bay of Biscay, where
management is applied from the mid-season of one year to the mid-season of the next year.
Simulations with multi-annual advice is also possible.
The exact way to define the objects used to set the simulation is described in the **FLBEIA** manual.
This manual can be downloaded from [GitHub](https://github.com/flr/FLBEIA/blob/master/vignettes/FLBEIA_manual.pdf),
within the 'doc' folder of the package installation or typing `help(package = FLBEIA)` in the R console.
Nevertheless, the objects to set the simulation doesn't need to be defined for the following examples,
as the dataset `one` from the FLBEIA package will be used.
For details on these objects, see tutorial on FLBEIA - Simple example.
<!-- [FLBEIA tutorial 2]+++LINK+++. -->
To see all the datasets available in the **FLBEIA** package:
```{r package, eval=FALSE}
data(package='FLBEIA')
```
# Required packages to run this tutorial
To follow this tutorial you should have installed the following packages:
- CRAN: [ggplot2](https://cran.r-project.org/web/packages/ggplot2/index.html)
- FLR: [FLCore](http://www.flr-project.org/FLCore/), [FLAssess](http://www.flr-project.org/FLAssess/),
[FLash](http://www.flr-project.org/FLash/), [FLBEIA](http://www.flr-project.org/FLBEIA/),
[FLFleet](http://www.flr-project.org/FLFleet/), [ggplotFL](http://www.flr-project.org/ggplotFL/)
If you are using Windows, please use 32-bit R version because some of the packages do not work in 64-bit.
```{r installation, eval=FALSE}
install.packages( c("ggplot2"))
install.packages( c("FLCore", "FLBEIA", "FLFleets", "FLash",
"FLAssess", "FLXSA", "FLa4a", "ggplotFL"),
repos="http://flr-project.org/R")
# Package for running SPiCT (only development version --> needed package "devtools"")
install.packages("devtools")
library(devtools)
install_github("mawp/spict/spict")
```
Load all necessary packages.
```{r libraries, pkgs, results = "hide"}
# Load all necessary packages.
library(FLBEIA)
library(FLAssess)
library(FLash)
library(ggplotFL)
```
# Observation models
The following alternatives are possible in the observation model,
depending on the inclusion or not of the assessement in the MP.
* Stock without assessment:
+ The stock is not observed (`NoObsStock`), for example in the cases when
+ there is no need to observe the stock as it is managed independently to its status
(e.g. via fixed TAC),
+ or when you use an alternative to know the abundance, through the observation
of an abundance index, in biomass (`bioInd`) or age structured (`ageInd`),
for example when using a HCR that requires an index to set the TAC.
+ The population and the fleet are observed without errors (`perfectObs`),
that could be usefull to test the HCR without any observation error;
+ It can be simulated an assessment, age structured (`age2agePop`) or
aggregated in biomass (`age2bioPop` or `bio2bioPop`,
respectively if stock is age structured or aggregated in biomass),
given different types of errors defined a priori (e.g. ageing error,
errors in the observation of numbers, weights or total biomass at age
or errors in the observation of total landings or discards).
* Stock with assessment:
+ If biological information (e.g. natural mortality, mean weights, maturity,...) and/or
catch information is required as input for the assessment,
in biomass (`age2bioDat` or `bio2bioDat`, respectively if stock is age structured
or aggregated in biomass) or age structured (`age2ageDat`);
+ If the observation of an abundance index is required, in biomass (`bioInd`)
or age structured (`ageInd`).
For more details on these functions and the related control objects
see Sections 4.3.6-4.3.8 and Table C.5 in the
[**FLBEIA** manual](https://github.com/flr/FLBEIA/blob/master/vignettes/FLBEIA_manual.pdf).
# Assessment models
In this tutorial there will be presented several examples on the introduction of alternative assesments in the MP.
Alternative examples:
0. without assessment;
1. assessment which requires a biomass index, example with SPiCT assessment model;
2. assessment which requires an age structured index, example with SCA assessment model;
3. assessment which requires the observation of the population and the fleets and
abundance indices, example with XSA assessment model.
# Example 0: no assessment
## Description
This example represents a simulation without assessment in the Management Procedure (MP).
In this case, the Operating Model (OM) runs annually and it is formed by a single age-structured stock
and an unique fleet which activity is performed in an unique metier. In the Management Procedure (MP),
the fleet dynamics is assumed to be a Simple Mixed Fisheries behaviour (for details, see information on
SMFB function in the [**FLBEIA** manual](https://github.com/flr/FLBEIA/blob/master/vignettes/FLBEIA_manual.pdf),
the stock is observed without error, there is not assessment carried out and the ICES HCR [@ices2009]
is used to set the TAC yearly.
All the objects have 3 iterations and uncertainty in the projections comes exclusively from the generation of the new incoming recruitments.
* Operating model:
+ Biological:
+ Population dynamics: `stk1` - age structured population growth
+ SR model: `stk1` - Beverthon and Holt autoregressive/segmented regression
+ Fleet: `fl1` - Simple Mixed Fisheries Behaviour
+ Covariates: covariates related to economy (e.g. number of vessels, fuel costs,...)
* Management Procedure:
+ Observation: `stk1` - perfect observation
+ Assessment: `stk1` - no assessment
+ Management advice: `stk1` - ICES harvest control rule
The neccesary `FLR` objects to run **FLBEIA** are available in the dataset called `one`.
```{r data, echo=TRUE, eval=TRUE}
rm(list=ls()) # empty the workspace
data(one) # load the dataset
```
## Exploring the data
Information related to assessment component of the MP is provided in `oneAssC` object.
```{r assCtrl, echo=TRUE, eval=FALSE}
oneAssC
```
In this case, no abundance index is required, as there is no assessment and
the HCR (`IcesHCR`) does not require any index, as it sets the TAC based on the perceived
stock status.
## Run FLBEIA
```{r s0, echo=TRUE, eval=TRUE, results = "hide"}
s0 <- FLBEIA( biols = oneBio, # FLBiols: FLBiol for stk1.
SRs = oneSR, # List: FLSRSim for stk1.
BDs = NULL, # Not population with biomass dynamics.
fleets = oneFl, # FLFleets: one fleet.
covars = oneCv, # List: covars related to economy.
indices = NULL, # Not indices.
advice = oneAdv, # List: 'TAC' and 'quota.share'
main.ctrl = oneMainC, # List: info on start and end of the simulation.
biols.ctrl = oneBioC, # List: model to simulate the stock dynamics.
fleets.ctrl = oneFlC, # List: fleet dynamics models select. and other params.
covars.ctrl = oneCvC, # List: covariates dynamics ("fixedCovar").
obs.ctrl = oneObsC, # List: type of stock and index observation
# ("PerfectObs").
assess.ctrl = oneAssC, # List: assessment model used ("NoAssessment").
advice.ctrl = oneAdvC) # List: rule for TAC advice ("IcesHCR").
```
## Results
We show a comparison between the real population and the perceived one (i.e. assessment results).
```{r s0_out, echo=TRUE, eval=TRUE, results = "hide"}
stk1.mp0 <- s0$stocks[['stk1']]
stk1.om0 <- biolfleets2flstock(s0$biols[['stk1']], s0$fleets)
plot( FLStocks(real=stk1.om0, obs=stk1.mp0)) + theme(legend.position="top")
```
There are exactly the same, as expected, because there is not any observation error.
# Example 1: SPiCT assessment
## Description
This example shows how to use SPiCT assessment [@pedersen2016] to obtain the observed populations in the
Management Procedure (MP).
Currently there is an R package called **spict** that provides the framework to fit a
surplus production model in R using fisheries catch and biomass index data,
specifically the model is a Stochastic suplus Production model in Continuous-Time (SPiCT).
`fit.spict` is the function to fit a contiunuous-time surplus production model to data
using the TMB package.
Following arguments are required:
* inp : List of input variables as output by check.inp
* dbg : Debugging option. Will print out runtime information useful for debugging if set to 1. Will print even more if set to 2.
For more details, type `?fit.spict` in the R console.
Within **FLBEIA** these arguments are given to the function through the assess.ctrl object,
which is a named list with the names of the stocks and the following components for each stock:
* assess.model: character with the name of the assessment model or 'NoAssessment'.
To do the call to SPiCT, this argument has to be set to `spict2flbeia`,
which is an FLBEIA function that links the inputs and outputs of `fit.spict` function
with **FLBEIA** and calls to `fit.spict` function.
* control: control object, which depends on the selected assessment model
(e.g. FLXSA.control() for XSA assessment).
+The FLXSA.control function creates a new control object required by XSA model.
For more details see the FLR tutorial on Stock assessment using eXtended Survivors Analysis with FLXSA
([link](http://www.flr-project.org/doc/Stock_assessment_using_eXtended_Survivors_Analysis_with_FLXSA.html)) .
In this case, the default parameter values will be used.
We load the SPiCT library:
```{r spict, echo=TRUE, eval=TRUE}
library(spict)
```
## Exploring the data
In this example, the same dataset as in Example 0 will be used.
Information related to assessment component of the MP is provided in `oneAssC` object.
```{r assCtrl2, echo=TRUE, eval=FALSE}
oneAssC
```
Now we need to set the control parameters for this assessment.
```{r assCtrl3, echo=TRUE, eval=TRUE}
oneAssC.spict <- oneAssC
oneAssC.spict[["stk1"]]$assess.model <- "spict2flbeia" # selected assessment model
oneAssC.spict[["stk1"]]$harvest.units <- "f"
```
Additionally, we need and abundance index. We will take one age-structured `oneIndAge` object and its related control `oneObsCIndAge`.
And inform in `advice.ctrl` what index should be used.
```{r sum, echo=TRUE, eval=TRUE}
summary(oneIndBio)
summary(oneObsCIndBio)
# Check the observation controls related to the assessment and the observation of the index
oneObsCIndBio$stk1$stkObs$stkObs.model
oneObsCIndBio$stk1$indObs
```
## Run FLBEIA
```{r s1, echo=TRUE, eval=TRUE, results = "hide"}
s1 <- FLBEIA( biols = oneBio, # FLBiols: FLBiol for stk1.
SRs = oneSR, # List: FLSRSim for stk1.
BDs = NULL, # Not population with biomass dynamics.
fleets = oneFl, # FLFleets: one fleet.
covars = oneCv, # List: covars related to economy.
indices = oneIndBio, # Biomass index.
advice = oneAdv, # List: 'TAC' and 'quota.share'
main.ctrl = oneMainC, # List: info on start and end of the simulation.
biols.ctrl = oneBioC, # List: model to simulate the stock dynamics.
fleets.ctrl = oneFlC, # List: fleet dynamics models select. and other params.
covars.ctrl = oneCvC, # List: covariates dynamics ("fixedCovar").
obs.ctrl = oneObsCIndBio, # List: type of stock and index observation
# ("age2bioDat","bioInd").
assess.ctrl = oneAssC.spict, # List: assessment model used ("spict2flbeia").
advice.ctrl = oneAdvC) # List: rule for TAC advice ("IcesHCR").
```
## Results
We show a comparison between the real population and the perceived one (i.e. assessment results).
```{r s1out, echo=TRUE, eval=TRUE, results = "hide"}
stk1.mp1 <- s1$stocks[['stk1']]
stk1.om1 <- biolfleets2flstock(s1$biols[['stk1']], s1$fleets)
adf <- as.data.frame
s1_pop <- rbind( data.frame( population='obs', indicator='SSB', as.data.frame(ssb(stk1.mp1))),
data.frame( population='obs', indicator='Harvest', as.data.frame(harvest(stk1.mp1))),
data.frame( population='obs', indicator='Catch', as.data.frame(catch(stk1.mp1))),
data.frame( population='real', indicator='SSB', as.data.frame(ssb(stk1.om1))),
data.frame( population='real', indicator='Harvest', as.data.frame(fbar(stk1.om1))),
data.frame( population='real', indicator='Catch', as.data.frame(catch(stk1.om1))))
p <- ggplot( data=s1_pop, aes(x=year, y=data, color=population)) +
geom_line() +
facet_grid(indicator ~ ., scales="free") +
geom_vline(xintercept = oneMainC$sim.years[['initial']]-1, linetype = "longdash")+
theme_bw()+
theme(text=element_text(size=15),
title=element_text(size=15,face="bold"),
strip.text=element_text(size=15),
legend.position="top")+
ylab("")
print(p)
```
<!-- ```{r detSpict, echo=FALSE, results='hide', message=FALSE} -->
<!-- detach(package:spict) -->
<!-- ``` -->
# Example 2: Statistical Catch-at-Age assessment
## Description
This example shows how to carry out an assessment using an Statistical Catch-at-Age method
[@millar2015] to obtain the observed populations in the Management Procedure (MP).
Currently there is an R package called **FLa4a** that provides a simple and robust statistical
Catch at Age model that is specifically designed for stocks with intermediate levels of data quantity and quality.
`sca` is the User interface to the statistical catch-at-age method of the a4a stock assessment framework.
Following arguments are required:
* stock : An FLStock object to be used for the analysis
* indices: An FLIndices object holding the indices of abundance to consider in the model
* fmodel : A formula object depicting the model for log fishing mortality at age
* qmodel : A list of formula objects depicting the models for log survey catchability at age
* srmodel: A formula object depicting the model for log recruitment
* fit : Character with type of fit: 'MP' or 'assessment';
the former does not require the hessian to be computed, while the latter does.
For more details, type `?sca` in the R console.
Within **FLBEIA** these arguments are given to the function through the assess.ctrl object,
which is a named list with the names of the stocks and the following components for each stock:
* assess.model: character with the name of the assessment model or 'NoAssessment'.
To do the call to `sca`, this argument has to be set to `sca2flbeia`,
wich is an FLBEIA function that links the inputs and outputs of `sca` function
with **FLBEIA** and calls to `sca` function.
* control: control object, which depends on the selected assessment model.
That is a list with the controls required for sca assessment, these are `fmod`, `qmod` and `srmod`.
We load the FLa4a library.
```{r FLa4a, echo=TRUE, eval=TRUE}
library(FLa4a)
```
The neccesary `FLR` objects to run **FLBEIA** are available in the dataset called `one`.
```{r data2, echo=TRUE, eval=TRUE}
rm(list=ls()) # empty the workspace
data(one) # load the dataset
```
However, in this dataset the assessment is set to `noAssessment` (that is, there is no assessment carried out in this case).
So we need to change the initial settings in the loaded dataset to allow the call to SCA assessment model.
## Exploring the data
Information related to assessment component of the MP is provided in `oneAssC` object.
```{r assCtrl4, echo=TRUE, eval=FALSE}
oneAssC
```
Now we need to set the control parameters for this assessment.
```{r assCtrl5, echo=TRUE, eval=TRUE}
oneAssC.sca <- oneAssC
oneAssC.sca$stk1$assess.model <- "sca2flbeia" # selected assessment model
oneAssC.sca[["stk1"]]$harvest.units <- "f"
oneAssC.sca[["stk1"]]$control$test <- TRUE # control values
```
Additionally, we need and abundance index. We will take one age-structured `oneIndAge` object and its related control `oneObsCIndAge`.
And inform in `advice.ctrl` what index should be used.
```{r sum2, echo=TRUE, eval=TRUE}
summary(oneIndAge)
summary(oneObsCIndAge)
# Check the observation controls related to the assessment and the observation of the index
oneObsCIndAge$stk1$stkObs$stkObs.model
oneObsCIndAge$stk1$indObs
```
## Run FLBEIA
```{r s2, echo=TRUE, eval=TRUE, results = "hide"}
s2 <- FLBEIA( biols = oneBio, # FLBiols: FLBiol for stk1.
SRs = oneSR, # List: FLSRSim for stk1.
BDs = NULL, # Not population with biomass dynamics.
fleets = oneFl, # FLFleets: one fleet.
covars = oneCv, # List: covars related to economy.
indices = oneIndAge, # Age-structured index.
advice = oneAdv, # List: 'TAC' and 'quota.share'
main.ctrl = oneMainC, # List: info on start and end of the simulation.
biols.ctrl = oneBioC, # List: model to simulate the stock dynamics.
fleets.ctrl = oneFlC, # List: fleet dynamics models select. and other params.
covars.ctrl = oneCvC, # List: covariates dynamics ("fixedCovar").
obs.ctrl = oneObsCIndAge, # List: type of stock and index observation
# ("age2ageDat","ageInd").
assess.ctrl = oneAssC.sca, # List: assessment model used ("sca2flbeia").
advice.ctrl = oneAdvC) # List: rule for TAC advice ("IcesHCR").
```
## Results
We show a comparison between the real population and the perceived one (i.e. assessment results).
```{r s2out, echo=TRUE, eval=TRUE, results = "hide"}
stk1.mp2 <- s2$stocks[['stk1']]
stk1.om2 <- biolfleets2flstock(s2$biols[['stk1']], s2$fleets)
adf <- as.data.frame
s2_pop <- rbind( data.frame( population='obs', indicator='SSB', as.data.frame(ssb(stk1.mp2))),
data.frame( population='obs', indicator='Harvest', as.data.frame(harvest(stk1.mp2))),
data.frame( population='obs', indicator='Catch', as.data.frame(catch(stk1.mp2))),
data.frame( population='real', indicator='SSB', as.data.frame(ssb(stk1.om2))),
data.frame( population='real', indicator='Harvest', as.data.frame(fbar(stk1.om2))),
data.frame( population='real', indicator='Catch', as.data.frame(catch(stk1.om2))))
p <- ggplot( data=s2_pop, aes(x=year, y=data, color=population)) +
geom_line() +
facet_grid(indicator ~ ., scales="free") +
geom_vline(xintercept = oneMainC$sim.years[['initial']]-1, linetype = "longdash")+
theme_bw()+
theme(text=element_text(size=15),
title=element_text(size=15,face="bold"),
strip.text=element_text(size=15),
legend.position="top")+
ylab("")
print(p)
```
<!-- ```{r detFLa4a, echo=FALSE, results='hide', message=FALSE} -->
<!-- detach(package:FLa4a) -->
<!-- ``` -->
# Example 3: XSA assessment
## Description
This example shows how to use XSA assessment [@darby1994,@shepherd1997,@shepherd1999]
to obtain the observed populations in the Management Procedure (MP).
Currently there is an R package called **FLXSA** that provides the framework to perform
eXtended Survivor Analysis in FLR.
`FLXSA` is the function to run an XSA analysis and creates an FLXSA object used to
analyse its results. Following arguments are required:
* stock : An FLStock object to be used for the analysis
* indices: An FLIndices object holding the indices of abundance to consider in the model
* control: An FLXSA.control object giving parameters of the model (see FLXSA.control)
* desc : A short description of this analysis
For more details, type `?FLXSA` in the R console.
Within **FLBEIA** these arguments are given to the function through the assess.ctrl object,
which is a named list with the names of the stocks and the following components for each stock:
* assess.model: character with the name of the assessment model or 'NoAssessment'.
To do the call to `FLXSA`, this argument has to be set to `FLXSA2flbeia`,
wich is an FLBEIA function that links the inputs and outputs of `FLXSA` function
with **FLBEIA** and calls to `FLXSA` function.
* control: control object, which depends on the selected assessment model.
That is FLXSA.control() for XSA assessment.
The FLXSA.control function creates a new control object required by XSA model.
For more details see the FLR tutorial on Stock assessment using eXtended Survivors Analysis with FLXSA
([link](http://www.flr-project.org/doc/Stock_assessment_using_eXtended_Survivors_Analysis_with_FLXSA.html)) .
In this case, the default parameter values will be used.
We load the FLXSA library.
```{r FLXSA, echo=TRUE, eval=TRUE}
library(FLXSA)
```
The neccesary `FLR` objects to run this example are available in the dataset called `one`.
```{r data3, echo=TRUE, eval=TRUE}
rm(list=ls()) # empty the workspace
data(one) # load the dataset
```
However, in this dataset the assessment is set to `noAssessment` (that is, there is no assessment carried out).
So we need to change the initial settings in the loaded dataset to allow the call to XSA assessment model.
## Exploring the data
In this example, the same dataset as in Example 1 will be used, but as mentioned before
some parameters related to the selected assessment (i.e. XSA) need to be set.
Information related to assessment component of the MP is provided in `oneAssC` object.
```{r assCtrl6, echo=TRUE, eval=FALSE}
oneAssC
```
Then we set the control parameters for XSA assessment:
```{r assCtrl7, echo=TRUE, eval=TRUE}
oneAssC1 <- list()
oneAssC1$stk1 <- list()
oneAssC1$stk1$assess.model <- 'FLXSA2flbeia' # selected assessment model
oneAssC1$stk1$control <- FLXSA.control() # default control values
oneAssC1$stk1$work_w_Iter <- TRUE
oneAssC1$stk1$harvest.units <- 'f'
```
Additionally, we need an abundance index. We will take one age-structured index available at `oneIndAge` object and its related control object `oneObsCIndAge`.
And inform in `advice.ctrl` which index should be used.
```{r sum3, echo=TRUE, eval=TRUE}
summary(oneIndAge)
summary(oneObsCIndAge)
# Check the observation controls related to the assessment and the observation of the index
oneObsCIndAge$stk1$stkObs$stkObs.model
oneObsCIndAge$stk1$indObs
```
## Run FLBEIA
```{r errs3, echo=FALSE, results='hide', message=FALSE}
try( FLXSA::FLXSA(stock = biolfleets2flstock(oneBio$stk1, oneFl), indices = oneIndAge$stk1,
control=oneAssC1$stk1$control, diag.flag = FALSE), silent = TRUE)
```
```{r s3, echo=TRUE, eval=TRUE, results = "hide"}
s3 <- FLBEIA( biols = oneBio, # FLBiols: FLBiol for stk1.
SRs = oneSR, # List: FLSRSim for stk1.
BDs = NULL, # Not population with biomass dynamics.
fleets = oneFl, # FLFleets: one fleet.
covars = oneCv, # List: covars related to economy.
indices = oneIndAge, # Age-structured index.
advice = oneAdv, # List: 'TAC' and 'quota.share'
main.ctrl = oneMainC, # List: info on start and end of the simulation.
biols.ctrl = oneBioC, # List: model to simulate the stock dynamics.
fleets.ctrl = oneFlC, # List: fleet dynamics models select. and other params.
covars.ctrl = oneCvC, # List: covariates dynamics ("fixedCovar").
obs.ctrl = oneObsCIndAge, # List: type of stock and index observation
# ("age2ageDat","ageInd").
assess.ctrl = oneAssC1, # List: assessment model used ("FLXSAnew").
advice.ctrl = oneAdvC) # List: rule for TAC advice ("IcesHCR").
```
## Results
We show a comparison between the real population and the perceived one (i.e. assessment results).
```{r sum4, echo=TRUE, eval=TRUE, results = "hide"}
stk1.mp3 <- s3$stocks[['stk1']]
stk1.om3 <- biolfleets2flstock(s3$biols[['stk1']], s3$fleets)
plot( FLStocks(real=stk1.om3, obs=stk1.mp3)) + theme(legend.position="top")
```
# More information
* You can submit bug reports, questions or suggestions on this tutorial at <https://github.com/flr/doc/issues>.
* Or send a pull request to <https://github.com/flr/doc/>
* For more information on the FLR Project for Quantitative Fisheries Science in R, visit the FLR webpage, <http://flr-project.org>.
* You can submit bug reports, questions or suggestions specific to **FLBEIA** to <flbeia@azti.es>.
## Software Versions
* `r version$version.string`
* FLCore: `r packageVersion('FLCore')`
* FLBEIA: `r packageVersion('FLBEIA')`
* FLFleet: `r packageVersion('FLFleet')`
* FLash: `r packageVersion('FLash')`
* FLAssess: `r packageVersion('FLAssess')`
* FLXSA: `r packageVersion('FLXSA')`
* ggplotFL: `r packageVersion('ggplotFL')`
* ggplot2: `r packageVersion('ggplot2')`
* **Compiled**: `r date()`
## License
This document is licensed under the [Creative Commons Attribution-ShareAlike 4.0 International](https://creativecommons.org/licenses/by-sa/4.0) license.
## Author information
**Sonia Sanchez**. AZTI, Marine Research Unit. Herrera Kaia, Portualdea z/g, 20110, Pasaia, Gipuzkoa, Spain. https://www.azti.es/.
**FLBEIA team**. AZTI. Marine Reserach Unit. Txatxarramendi Ugartea z/g, 48395, Sukarrieta, Basque Country, Spain.
**Mail** flbeia@azti.es