forked from flr/doc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFLBEIA_Mixed_Fisheries_Tutorial.Rmd
873 lines (673 loc) · 38.1 KB
/
FLBEIA_Mixed_Fisheries_Tutorial.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
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
---
title: "ICES Mixed Fisheries Advice using FLBEIA"
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 mixed fisheries]
license: Creative Commons Attribution-ShareAlike 4.0 International Public License
bibliography: bibliography.bib
# header-includes: null
---
```{r, ini, echo=FALSE, results='hide', message=FALSE}
# This chunk set the document environment, so it is hidden
library(knitr)
knitr::opts_chunk$set(fig.align="center",
message=FALSE, warning=FALSE, echo=TRUE, cache=FALSE)
options(width=50)
set.seed(1423)
```
```{r 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 sixth tutorial of **FLBEIA** and it is a practical guide about the generation of mixed-fisheries advice in ICES using **FLBEIA**. It is divided in the following sections:
* Conditioning of the model
+ The FLBiols object.
+ The FLFleets object.
+ The rest of data objects.
+ The control objects.
* The validation of the conditioning.
* The scenarios.
* The advice.
At the end of the tutorial some exercises are proposed.
# 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)
[XLConnect](https://cran.r-project.org/web/packages/XLConnect/index.html)
[XLConnectJars](https://cran.r-project.org/web/packages/XLConnectJars/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/)
If you are using Windows, please use 64-bit R version because some of the packages (mainly FLash)
do not work in 32-bit.
```{r, eval=FALSE}
install.packages( c("ggplot2"))
install.packages( c("FLCore", "FLFleet", "FLBEIA",
"FLash", "FLAssess", "FLXSA"),
repos="http://flr-project.org/R")
```
It has to be noted that packages ```FLCore```, ```FLFleets``` and ```FLBEIA``` have to be installed in this exact order, as alternative orders can cause some problems.
Load all the necessary packages.
```{r, pkgs, results = "hide"}
library(FLBEIA)
library(ggplot2)
```
# Conditioning of the model
This tutorial uses the objects produced in the 'Smat conditioning II' tutorial. In that tutorial three objects were created, the FLBiols object, the FLFLeet object and the covars object. Here, only the first two objects will be used. The rest of the objects needed will be created now. Instead of using the function from the 'Smart Conditionin I' module we will use the basic FLR functions.
The data used in the tutorial corresponds with the Demersal fishery operating in Iberian Coast. The fishery is formed by two countries, Spain and Portugal, and several fleets operating with different gears. An squeme of the case sutdy is shown below:
* Stocks:
+ Hake: 16 age classes and caught by most of the fleets, catches around 13000 tons. the status of the stocks was bad in the last years and it is the most restrictive stocks.
+ Monkfish: 30 age classes and caught by most of the fleets, catches around 2500 tons.
+ Four Spot Megrim: 8 age classes and caught by the trawlers, catches around 2500 tons.
+ Megrim: 7 age classes and caught by trawlers along with the other megrim, catches around 500 tons.
* Fleets:
+ SP_GNS: Spanish Gillnetters.
- DEF_100_0_0
- DEF_60_79_0_0
- DEF_80_99_0_0
+ PT_GNS: Portuguese Gillnetters.
- DEF_0_0_0
+ PT_GTR: Portuguese Trammel Nets.
- DEF_0_0_0
+ SP_GTR: Spanish Trammel Nets.
- DEF_0_0_0
+ SP_LLS: Spanish Longliners
- DEF_0_0_0
+ PT_MIS: Portuguese miscelaneous.
- MIS_0_0_0_HC
+ SP_MIS: Spanish miscelaneous.
- MIS_0_0_0_HC
+ PT_OTB: Portuguese Bottom Otter Trawl.
- CRU_55_0_0
- DEF_65_0_0
+ SP_OTB: Spanish Bottom Otter Trawl.
- DEF_65_0_0
- MPD_55_0_0
+ SP_OTB_24m: Spanish Bottom Otter Trawlers smaller than 24 m.
- MCD_55_0_0
+ OTH_OTH: A fleet that accounts for the catch not included in the rest of the fleets.
- OTH
+ SP_PTB: Spanish pair trawlers.
- MPD_55_0_0
First we will download the data generated in the 'Smart Conditioning II' tutoria from the FLR we page using R commands
```{r echo=TRUE, eval=TRUE}
tdir <- tempdir()
# download.file("http://www.flr-project.org/doc/src/flbeia_mixed_fisheries.zip",
# file.path(tdir, "flbeia_mixed_fisheries.zip"))
# unzip(file.path(tdir, "flbeia_mixed_fisheries.zip"), exdir=tdir)
unzip("src/flbeia_mixed_fisheries.zip", exdir=tdir)
tdir <- file.path(tdir,"flbeia_mixed_fisheries")
```
```{r echo=TRUE, eval=TRUE}
load(file.path(tdir,'Smart_Cond_II.Rdata'))
stknms <- names(biols)
```
## SRs objects
Create the FLSRsim object, instead of using the functions in the smart conditioning tutorial we will create by hand using the basic commands in FLCore library.
First we Create an FLQuant with the right dimension and all elements equal to 1. This object will be useful to
give the dimension to the objects we need to create and to fill some of the FLQuants.
```{r echo=TRUE, eval=TRUE}
flq1 <- FLQuant(1,dim = c(1,26), dimnames = list(quant = 'all', year = 2000:2025))
```
For each of the stocks, first we create the FLSRsim object and in the function call of the same name we fill in the slots we already know. We will not introduce any uncertainty in recruitment hence we use the flq1 object to fill the uncertainy slot.
```{r echo=TRUE, eval=TRUE}
hke.sr <- FLSRsim(rec = biols[['HKE']]@n[1,], ssb = ssb(biols[['HKE']]), uncertainty = flq1,
proportion = flq1, model = 'segreg',name = 'HKE')
```
In the short term forecast a constant recruitment is used. We model it using a geometric mean model and fill in
the parameter manually using the value used by the assessment working group.
```{r echo=TRUE, eval=TRUE}
hke.sr <- FLSRsim(rec = biols[['HKE']]@n[1,], ssb = ssb(biols[['HKE']]), uncertainty = flq1,
proportion = flq1, model = 'geomean',name = 'HKE')
hke.sr@params[] <- 92476
```
For the rest of the stocks we do exactly the same:
```{r echo=TRUE, eval=TRUE}
ldb.sr <- FLSRsim(rec = biols[['LDB']]@n[1,], ssb = ssb(biols[['LDB']]), uncertainty = flq1,
proportion = flq1, model = 'geomean',name = 'LDB')
ldb.sr@params[] <- 53614
meg.sr <- FLSRsim(rec = biols[['MEG']]@n[1,], ssb = ssb(biols[['MEG']]), uncertainty = flq1,
proportion = flq1, model = 'geomean',name = 'MEG')
meg.sr@params[] <- 3559
mon.sr <- FLSRsim(rec = biols[['MON']]@n[1,], ssb = ssb(biols[['MON']]), uncertainty = flq1,
proportion = flq1, model = 'geomean',name = 'MON')
mon.sr@params[] <- 760
```
Finally we join all the FLSRsim objects in a single list, that we will use later in the call to FLBEIA.
```{r echo=TRUE, eval=TRUE}
SRs <- list(HKE = hke.sr, LDB = ldb.sr, MEG = meg.sr, MON = mon.sr)
```
## Advice object
The advice object is a list with two elements:
* TAC: An FLQuant with the single stock total allowable catches (one row per stock).
* quota.share: A list with one element per stock and for each stock an FLQuant with
the proportion of the TAC that belongs to each of the fleets.
So first, we create the structure of the advice object:
```{r echo=TRUE, eval=TRUE}
advice <- list(TAC = FLQuant(NA, dimnames= list(stocks = stknms, year = 2000:2025)),
quota.share = lapply(stknms, function(x){
FLQuant(NA,
dimnames = list(fleets = names(fleets), year = 2000:2025))}))
```
The TAC for 2019 and 2018.
```{r echo=TRUE, eval=TRUE}
advice$TAC['HKE', ac(2018)] <- 9258
advice$TAC['LDB', ac(2018)] <- 1151
advice$TAC['MEG', ac(2018)] <- 236
advice$TAC['MON', ac(2018)] <- 1898
advice$TAC['HKE', ac(2019:2025)] <- 8281
advice$TAC['LDB', ac(2019:2025)] <- 1633
advice$TAC['MEG', ac(2019:2025)] <- 399
advice$TAC['MON', ac(2019:2025)] <- 2153
```
For thee quota-share in the projection we use the historical mean.
```{r echo=TRUE, eval=TRUE}
names(advice$quota.share) <- stknms
for(st in stknms){
for(fl in names(fleets)){
if(st %in% catchNames(fleets[[fl]])){
advice$quota.share[[st]][fl,] <- quantSums(catchWStock.f(fleets[[fl]], st))/
quantSums(catchWStock(fleets, st))
advice$quota.share[[st]][fl,ac(2018:2025)] <-
yearMeans(advice$quota.share[[st]][fl,ac(2015:2017)])
}
else advice$quota.share[[st]][fl,] <- 0
}}
```
These are all the data objects we need to generate the mixed-fisheries advice. Now we need to create the control objects.
# The control objects
Each of the model components in FLBEIA needs a control object to tell how to simulate the system.
## The main.ctrl object
In the 'main.ctrl' object we set the time frame of the simulation and tell R is the management of the stocks is done simultaneously or not. The last argument is important when we use for example multi-stock HCRs.
```{r echo=TRUE, eval=TRUE}
main.ctrl <- list()
main.ctrl$sim.years <- c(initial = 2018, final = 2025)
main.ctrl$SimultaneousMngt <- FALSE
```
## The biols.ctrl object
For all the stocks we use an age structured population growth model:
```{r echo=TRUE, eval=TRUE}
growth.model <- c(rep('ASPG',4))
biols.ctrl <- create.biols.ctrl (stksnames=stknms,growth.model= growth.model)
```
## The fleets.ctrl object
The fleets.ctrl objects is one of the most complex controls because we model several processes, the effort allocation in the short term, the catch production, the price formation and the entry-exit of new vessels in the fishery. For each process R needs to now how to proceed. We will use the create.fleets.ctrl function to facilitate the construction of the object. First we generate some of the arguments that will be use in the call to the function.
```{r echo=TRUE, eval=TRUE}
n.flts.stks <- sapply(sapply(fleets, catchNames), length)
flts.stksnames <- NULL
for(f in 1:length(fleets)) flts.stksnames <- c(flts.stksnames, catchNames(fleets[[f]]))
catch.models <- rep("CobbDouglasAge", sum(n.flts.stks))
names(catch.models) <- flts.stksnames
capital.models <- rep('fixedCapital', length(fleets))
flq <- FLQuant(dimnames= list(year = 2000:2025, iter = 1))
```
In the ICES mixed-fisheries advice the single stock TAC advices are evaluated using different scenarios about fleet dynamics. Hence, here we create a different control object for each scenario.
In the first scenario we assume that the fishing effort in the TAC year will be the equal to the effor tin the last year. To simulate this scenario in FLBEIA, we need to fill in the effort and effshare slots in the FLFLeet object using the historical means and a control object with the effort model equal to 'fixedEffort'. The slots were already populated with the historical mean in the 'Smart Conditioning II' tutorial.
In all the scenario we assume that the restriction is on catch, an not in landings.
```{r echo=TRUE, eval=TRUE}
fleets.ctrl.Esq <- create.fleets.ctrl(
fls = names(fleets),
n.fls.stks = n.flts.stks,
fls.stksnames = flts.stksnames,
effort.models = rep('SMFB', length(fleets)),
price.models = rep("fixedPrice", sum(n.flts.stks)),
catch.models = catch.models,
flq = flq,
restriction.SP_GNS = 'catch', restriction.PT_GNS = 'catch',
restriction.PT_GTR = 'catch', restriction.SP_GTR = 'catch',
restriction.SP_LLS = 'catch', restriction.PT_MIS = 'catch',
restriction.SP_MIS = 'catch', restriction.PT_OTB = 'catch',
restriction.SP_OTB = 'catch', restriction.SP_OTB_24m = 'catch',
restriction.OTH_OTH = 'catch',restriction.SP_PTB = 'catch')
for(fl in names(fleets)) fleets.ctrl.Esq[[fl]][['effort.model']] <- 'fixedEffort'
```
In the rest of the scenarios the effort share along metiers, the proportion of the effort that is exerted in each metier, is set equal to the historical mean, and the total effort at fleet level is calculated based on the effort corresponding to single stock TACs. This behaviour is obtained using the 'SMFB' function. First, for each fleet, the total effort corresponding to the quota share of its stock is calculated. A vector of efforts is obtained with each element of the vector corresponding to the quota-share of one stock. Then, different options are used to select one of the efforts of the vector.
In the 'max' option, for each fleet, in the vector of possible efforts the maximum is selected. Depending on the catchabilities, for each fleet the maximum will correspond with the quota-share of a different stock:
```{r echo=TRUE, eval=TRUE}
fleets.ctrl.max <- create.fleets.ctrl(
fls = names(fleets),
n.fls.stks = n.flts.stks,
fls.stksnames = flts.stksnames,
effort.models = rep('SMFB', length(fleets)),
price.models = rep("fixedPrice", sum(n.flts.stks)),
flq = flq,
catch.models = catch.models,
capital.models = capital.models,
restriction.SP_GNS = 'catch', restriction.PT_GNS = 'catch',
restriction.PT_GTR = 'catch', restriction.SP_GTR = 'catch',
restriction.SP_LLS = 'catch', restriction.PT_MIS = 'catch',
restriction.SP_MIS = 'catch', restriction.PT_OTB = 'catch',
restriction.SP_OTB = 'catch', restriction.SP_OTB_24m = 'catch',
restriction.OTH_OTH = 'catch', restriction.SP_PTB = 'catch',
effort.restr.SP_GNS = 'max', effort.restr.PT_GNS = 'max',
effort.restr.PT_GTR = 'max', effort.restr.SP_GTR = 'max',
effort.restr.SP_LLS = 'max', effort.restr.PT_MIS = 'max',
effort.restr.SP_MIS = 'max', effort.restr.PT_OTB = 'max',
effort.restr.SP_OTB = 'max', effort.restr.SP_OTB_24m = 'max',
effort.restr.OTH_OTH = 'max', effort.restr.SP_PTB = 'max')
```
In the opposite side, the 'min' option selects the minimum effort in each of the vectors. This options is usually used to model the landing obligation policy, where the fleet are oblied to land all the catches and over-quota catches are not allowed.
```{r echo=TRUE, eval=TRUE}
fleets.ctrl.min <- create.fleets.ctrl(
fls = names(fleets),
n.fls.stks = n.flts.stks,
fls.stksnames = flts.stksnames,
effort.models = rep('SMFB', length(fleets)),
price.models = rep("fixedPrice", sum(n.flts.stks)),
flq = flq,
catch.models = catch.models,
capital.models = capital.models,
restriction.SP_GNS = 'catch', restriction.PT_GNS = 'catch',
restriction.PT_GTR = 'catch', restriction.SP_GTR = 'catch',
restriction.SP_LLS = 'catch', restriction.PT_MIS = 'catch',
restriction.SP_MIS = 'catch', restriction.PT_OTB = 'catch',
restriction.SP_OTB = 'catch', restriction.SP_OTB_24m = 'catch',
restriction.OTH_OTH = 'catch', restriction.SP_PTB = 'catch',
effort.restr.SP_GNS = 'min', effort.restr.PT_GNS = 'min',
effort.restr.PT_GTR = 'min', effort.restr.SP_GTR = 'min',
effort.restr.SP_LLS = 'min', effort.restr.PT_MIS = 'min',
effort.restr.SP_MIS = 'min', effort.restr.PT_OTB = 'min',
effort.restr.SP_OTB = 'min', effort.restr.SP_OTB_24m = 'min',
effort.restr.OTH_OTH = 'min', effort.restr.SP_PTB = 'min')
```
Finally, for each stock considered in the analysis, an scenario is set where the fleets stop fishing when the quota-share of that stock is reached.
```{r echo=TRUE, eval=TRUE}
fleets.ctrl.HKE <- create.fleets.ctrl(
fls = names(fleets),
n.fls.stks = n.flts.stks,
fls.stksnames = flts.stksnames,
effort.models = rep('SMFB', length(fleets)),
price.models = rep("fixedPrice", sum(n.flts.stks)),
flq = flq,
catch.models = catch.models,
capital.models = capital.models,
restriction.SP_GNS = 'catch', restriction.PT_GNS = 'catch',
restriction.PT_GTR = 'catch', restriction.SP_GTR = 'catch',
restriction.SP_LLS = 'catch', restriction.PT_MIS = 'catch',
restriction.SP_MIS = 'catch', restriction.PT_OTB = 'catch',
restriction.SP_OTB = 'catch', restriction.SP_OTB_24m = 'catch',
restriction.OTH_OTH = 'catch', restriction.SP_PTB = 'catch',
effort.restr.SP_GNS = 'HKE', effort.restr.PT_GNS = 'HKE',
effort.restr.PT_GTR = 'HKE', effort.restr.SP_GTR = 'HKE',
effort.restr.SP_LLS = 'HKE', effort.restr.PT_MIS = 'HKE',
effort.restr.SP_MIS = 'HKE', effort.restr.PT_OTB = 'HKE',
effort.restr.SP_OTB = 'HKE', effort.restr.SP_OTB_24m = 'HKE',
effort.restr.OTH_OTH = 'HKE', effort.restr.SP_PTB = 'HKE')
```
```{r echo=TRUE, eval=TRUE}
fleets.ctrl.LDB <- create.fleets.ctrl(
fls = names(fleets),
n.fls.stks = n.flts.stks,
fls.stksnames = flts.stksnames,
effort.models = rep('SMFB', length(fleets)),
price.models = rep("fixedPrice", sum(n.flts.stks)),
flq = flq,
catch.models = catch.models,
capital.models = capital.models,
restriction.SP_GNS = 'catch', restriction.PT_GNS = 'catch',
restriction.PT_GTR = 'catch', restriction.SP_GTR = 'catch',
restriction.SP_LLS = 'catch', restriction.PT_MIS = 'catch',
restriction.SP_MIS = 'catch', restriction.PT_OTB = 'catch',
restriction.SP_OTB = 'catch', restriction.SP_OTB_24m = 'catch',
restriction.OTH_OTH = 'catch', restriction.SP_PTB = 'catch',
effort.restr.SP_GNS = 'LDB', effort.restr.PT_GNS = 'LDB',
effort.restr.PT_GTR = 'LDB', effort.restr.SP_GTR = 'LDB',
effort.restr.SP_LLS = 'LDB', effort.restr.PT_MIS = 'LDB',
effort.restr.SP_MIS = 'LDB', effort.restr.PT_OTB = 'LDB',
effort.restr.SP_OTB = 'LDB', effort.restr.SP_OTB_24m = 'LDB',
effort.restr.OTH_OTH = 'LDB', effort.restr.SP_PTB = 'LDB')
```
```{r echo=TRUE, eval=TRUE}
fleets.ctrl.MON <- create.fleets.ctrl(
fls = names(fleets),
n.fls.stks = n.flts.stks,
fls.stksnames = flts.stksnames,
effort.models = rep('SMFB', length(fleets)),
price.models = rep("fixedPrice", sum(n.flts.stks)),
flq = flq,
catch.models = catch.models,
capital.models = capital.models,
restriction.SP_GNS = 'catch', restriction.PT_GNS = 'catch',
restriction.PT_GTR = 'catch', restriction.SP_GTR = 'catch',
restriction.SP_LLS = 'catch', restriction.PT_MIS = 'catch',
restriction.SP_MIS = 'catch', restriction.PT_OTB = 'catch',
restriction.SP_OTB = 'catch', restriction.SP_OTB_24m = 'catch',
restriction.OTH_OTH = 'catch', restriction.SP_PTB = 'catch',
effort.restr.SP_GNS = 'MON', effort.restr.PT_GNS = 'MON',
effort.restr.PT_GTR = 'MON', effort.restr.SP_GTR = 'MON',
effort.restr.SP_LLS = 'MON', effort.restr.PT_MIS = 'MON',
effort.restr.SP_MIS = 'MON', effort.restr.PT_OTB = 'MON',
effort.restr.SP_OTB = 'MON', effort.restr.SP_OTB_24m = 'MON',
effort.restr.OTH_OTH = 'MON', effort.restr.SP_PTB = 'MON')
```
```{r echo=TRUE, eval=TRUE}
fleets.ctrl.MEG <- create.fleets.ctrl(
fls = names(fleets),
n.fls.stks = n.flts.stks,
fls.stksnames = flts.stksnames,
effort.models = rep('SMFB', length(fleets)),
price.models = rep("fixedPrice", sum(n.flts.stks)),
flq = flq,
catch.models = catch.models,
capital.models = capital.models,
restriction.SP_GNS = 'catch', restriction.PT_GNS = 'catch',
restriction.PT_GTR = 'catch', restriction.SP_GTR = 'catch',
restriction.SP_LLS = 'catch', restriction.PT_MIS = 'catch',
restriction.SP_MIS = 'catch', restriction.PT_OTB = 'catch',
restriction.SP_OTB = 'catch', restriction.SP_OTB_24m = 'catch',
restriction.OTH_OTH = 'catch', restriction.SP_PTB = 'catch',
effort.restr.SP_GNS = 'MEG', effort.restr.PT_GNS = 'MEG',
effort.restr.PT_GTR = 'MEG', effort.restr.SP_GTR = 'MEG',
effort.restr.SP_LLS = 'MEG', effort.restr.PT_MIS = 'MEG',
effort.restr.SP_MIS = 'MEG', effort.restr.PT_OTB = 'MEG',
effort.restr.SP_OTB = 'MEG', effort.restr.SP_OTB_24m = 'MEG',
effort.restr.OTH_OTH = 'MEG', effort.restr.SP_PTB = 'MEG')
```
## The covars.ctrl object
Covariates are not needed in the mixed-fisheries advice.
```{r echo=TRUE, eval=TRUE}
covars.ctrl <- NULL
```
## The management procedure
There is not management procedure in mixed-fisheries advice evaluation because the management advice is directly taken from the single-stock advice and in the simulations the consequences of those advice are simply evaluated. However, we need to tell FLBEIA that we don't want to do anything in the management procedure. This is obtained using the 'NoObsStock' option in the observation model, the 'NoAssessment' option in the assessment model and the 'fixedAdvice' in the advice model.
```{r echo=TRUE, eval=TRUE}
obs.ctrl <- create.obs.ctrl(stksnames = stknms,
stkObs.models = rep('NoObsStock',length(stknms)))
```
```{r echo=TRUE, eval=TRUE}
assess.ctrl <- create.assess.ctrl(stksnames = stknms,
assess.models = rep('NoAssessment',length(stknms)))
```
```{r echo=TRUE, eval=TRUE}
advice.ctrl <- create.advice.ctrl(stksnames = stknms,
HCR.models = rep('fixedAdvice', length(stknms)))
```
# Quality Checking.
Before evaluating the single stock TAC advice in a mixed-fisheries framework it is necessary to check if the data in the objects we have created is consistent with the data in the short term forecast conducted by the stock assessment working groups. As the population dynamic models used in the assessment working groups may differ from the ones used for the mixed fisheries advice, we need to ensure that the differences obtained come from the modelling approaches used and not from the data.
The checking is done doing a short term forecast at single stock basis, using the objects we have created before and using the catch constraint used by the assessment working groups:
* The catch corresponding to statu quo fishing mortality in the assessment year (2018 in this case).
* The TAC in the advice year (2019 in this case).
In the single stock short term forecast usually fishing mortality is used for the proyection instead of catch. However, as fishing mortality can not be used in FLBEIA as a restrictor we constraint the fishing using the catches obtained in the STF. After conductiin the STF with FLBEIA we compare the SSB and fishing mortality indicators obtained in the single stock forecast by the working groups in 2018, 2019 and 2020.
First, we update the year range in the main.ctrl object because in these simulations we only need three year projection. In the third year, 2020, only the OM is run so we can calculate the SSB at the begining of that year.
```{r echo=TRUE, eval=TRUE}
main.ctrl[[1]][2] <- 2020
```
The checking is done stock by stock. First we will do it for hake and afterwards we will do exactly the same for the rest of the stocks.
Create an advice object corresponding to the catches used in the single stock short term forecast for Hake.
```{r echo=TRUE, eval=TRUE}
advice.hke <- advice
advice.hke$TAC['HKE', '2018'] <- 16709
advice.hke$TAC['HKE', '2019'] <- 8281
```
Run FLBEIA with the fleets constriained by the HKE TAC.
```{r echo=TRUE, eval=TRUE, results = 'hide'}
for(fl in names(fleets)) fleets[[fl]]@capacity[] <- 1e12
hke <- FLBEIA(biols = biols,
SRs = SRs,
BDs = NULL,
fleets = fleets,
indices = NULL,
advice = advice.hke,
main.ctrl = main.ctrl,
biols.ctrl = biols.ctrl,
fleets.ctrl = fleets.ctrl.HKE,
covars.ctrl = NULL,
obs.ctrl = obs.ctrl,
assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
```
Use the 'bioSum' function to get the main biological indicators. As the year dimension of the objects covers up to 2025 and since 2021 the 'n' slot is empty we need to reduce the range for which the biological indicators are calculated.
```{r echo=TRUE, eval=TRUE}
hke.sum <- bioSum(hke, years = ac(2000:2020), long = TRUE)
```
Create two vectors with the indicators obtained in the assessment working groups.
```{r echo=TRUE, eval=TRUE}
ssb1719_wg_hke <- c(23885, 23904, 36104)
f1718_wg_hke <- c(0.6,0.25)
```
Comparison between the indicators obtained here and those obtained in the assessment workin group. The assessment of hake is conducted using a length structure and quarterly model so sginificant differences were expected. However, differences between +/-15% range are considered acceptable.
```{r echo=TRUE, eval=TRUE}
round(subset(hke.sum, year %in% 2018:2020 & indicator %in% c('ssb') & stock == 'HKE')$value/
ssb1719_wg_hke,2)
round(subset(hke.sum, year %in% 2018:2019 & indicator %in% c('f') & stock == 'HKE')$value/
f1718_wg_hke,2)
```
For the rest of the stocks we do exactly the same.
Four spot megrim (LDB):
```{r echo=TRUE, eval=TRUE, results = 'hide'}
advice.ldb <- advice
advice.ldb$TAC['LDB', '2018'] <- 2159 # catch corresponding to Fsq
advice.ldb$TAC['LDB', '2019'] <- 1633 # TAC in 2019
ldb <- FLBEIA(biols = biols,
SRs = SRs,
BDs = NULL,
fleets = fleets,
indices = NULL,
advice = advice.ldb,
main.ctrl = main.ctrl,
biols.ctrl = biols.ctrl,
fleets.ctrl = fleets.ctrl.LDB,
covars.ctrl = NULL,
obs.ctrl = obs.ctrl,
assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
ldb.sum <- bioSum(ldb, years = ac(2000:2020), long = TRUE)
```
```{r echo=TRUE, eval=TRUE}
ssb1719_wg_ldb <- c(8821, 8836, 9286)
f1718_wg_ldb <- c(0.28,0.193)
round(subset(ldb.sum, year %in% 2018:2020 & indicator %in% c('ssb') & stock == 'LDB')$value/
ssb1719_wg_ldb,2)
round(subset(ldb.sum, year %in% 2018:2019 & indicator %in% c('f') & stock == 'LDB')$value/
f1718_wg_ldb,2)
```
Megrim:
```{r echo=TRUE, eval=TRUE, results = 'hide'}
advice.meg <- advice
advice.meg$TAC['MEG', '2018'] <- 642 # catch corresponding to Fsq
advice.meg$TAC['MEG', '2019'] <- 399 # TAC in 2019
meg <- FLBEIA(biols = biols,
SRs = SRs,
BDs = NULL,
fleets = fleets,
indices = NULL,
advice = advice.meg,
main.ctrl = main.ctrl,
biols.ctrl = biols.ctrl,
fleets.ctrl = fleets.ctrl.MEG,
covars.ctrl = NULL,
obs.ctrl = obs.ctrl,
assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
meg.sum <- bioSum(meg, years = ac(2000:2020), long = TRUE)
ssb1719_wg_meg <- c(2504, 2241, 2129)
f1718_wg_meg <- c(0.29,0.191)
```
```{r echo=TRUE, eval=TRUE}
round(subset(meg.sum, year %in% 2018:2020 & indicator %in% c('ssb') & stock == 'MEG')$value/
ssb1719_wg_meg,2)
round(subset(meg.sum, year %in% 2018:2019 & indicator %in% c('f') & stock == 'MEG')$value/
f1718_wg_meg,2)
```
Monkfish:
```{r echo=TRUE, eval=TRUE, results = 'hide'}
advice.mon <- advice
advice.mon$TAC['MON', '2018'] <- 1556 # catch corresponding to Fsq
advice.mon$TAC['MON', '2019'] <- 2153 # TAC 2019
mon <- FLBEIA(biols = biols,
SRs = SRs,
BDs = NULL,
fleets = fleets,
indices = NULL,
advice = advice.mon,
main.ctrl = main.ctrl,
biols.ctrl = biols.ctrl,
fleets.ctrl = fleets.ctrl.MON,
covars.ctrl = NULL,
obs.ctrl = obs.ctrl,
assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
mon.sum <- bioSum(mon, years = ac(2000:2020), long =TRUE)
ssb1719_wg_mon <- c(11839, 11552, 10071)
f1718_wg_mon <- c(0.143,0.24)
```
```{r echo=TRUE, eval=TRUE}
round(subset(mon.sum, year %in% 2018:2020 & indicator %in% c('ssb') & stock == 'MON')$value/
ssb1719_wg_mon,2)
round(subset(mon.sum, year %in% 2018:2019 & indicator %in% c('f') & stock == 'MON')$value/
f1718_wg_mon,2)
```
# Run the mixed-fisheries advice scenarios
Once the conditioning and the performance of the model has been tested, the scenarios used to produce mixed fisheries advice can be run.
The basis of the model is to estimate the potential future levels of effort by a fleet corresponding to the fishing opportunities (TACs by stock and/or effort allocations by fleet) available to that fleet, based on historical fleet effort distribution and catchability by m?tier. This level of effort was used to estimate landings and catches by fleet and stock, using standard forecasting procedures.
In 2018, single-stock ICES advice was given according to MSY approach. Therefore, the same basis was retained in the current mixed-fisheries framework, in which the following eight seven scenarios are considered in the advice:
* max: The fishing stops when all quota species are fully utilized with respect to the upper limit corresponding to single-stock exploitation boundary.
* min: The fishing stops when the catch for the first quota species meets the upper limit corresponding to single-stock exploitation boundary.
* hke: All fleets set their effort to their hake quota share, regardless of other stocks.
* ldb: All fleets set their effort to their four-spot megrim quota share, regardless of other stocks.
* meg: All fleets set their effort to their megrim quota share, regardless of other stocks.
* mon: All fleets set their effort to their white anglerfish quota share, regardless of other stocks.
* sq_E: The effort was set as equal to the effort in the most recently recorded year for which landings and discard data were available.
We run FLBEIA for each of these scenarios using the right fleet control object.
Statu quo effort scenario:
```{r echo=TRUE, eval=TRUE, results = 'hide'}
Esq <- FLBEIA(biols = biols, SRs = SRs, BDs = NULL, fleets = fleets,
covars = NULL, indices = NULL, advice = advice,
main.ctrl = main.ctrl, biols.ctrl = biols.ctrl, fleets.ctrl = fleets.ctrl.Esq,
covars.ctrl = NULL, obs.ctrl = obs.ctrl, assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
```
The fleets continue fishing until the last quota is consumed:
```{r echo=TRUE, eval=TRUE, results = 'hide'}
max <- FLBEIA(biols = biols, SRs = SRs, BDs = NULL, fleets = fleets,
covars = NULL, indices = NULL, advice = advice,
main.ctrl = main.ctrl, biols.ctrl = biols.ctrl, fleets.ctrl = fleets.ctrl.max,
covars.ctrl = NULL, obs.ctrl = obs.ctrl, assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
```
Effort restricted by the most restrictive stock for each fleet:
```{r echo=TRUE, eval=TRUE, results = 'hide'}
min <- FLBEIA(biols = biols, SRs = SRs, BDs = NULL, fleets = fleets,
covars = NULL, indices = NULL, advice = advice,
main.ctrl = main.ctrl, biols.ctrl = biols.ctrl, fleets.ctrl = fleets.ctrl.min,
covars.ctrl = NULL, obs.ctrl = obs.ctrl, assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
```
Effort restricted by hake's TAC:
```{r echo=TRUE, eval=TRUE, results = 'hide'}
hke <- FLBEIA(biols = biols, SRs = SRs, BDs = NULL, fleets = fleets,
covars = NULL, indices = NULL, advice = advice,
main.ctrl = main.ctrl, biols.ctrl = biols.ctrl, fleets.ctrl = fleets.ctrl.HKE,
covars.ctrl = NULL, obs.ctrl = obs.ctrl, assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
```
Effort restricted by four spot megrim's TAC:
```{r echo=TRUE, eval=TRUE, results = 'hide'}
ldb <- FLBEIA(biols = biols, SRs = SRs, BDs = NULL, fleets = fleets,
covars = NULL, indices = NULL, advice = advice,
main.ctrl = main.ctrl, biols.ctrl = biols.ctrl, fleets.ctrl = fleets.ctrl.LDB,
covars.ctrl = NULL, obs.ctrl = obs.ctrl, assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
```
Effort restricted by megrim's TAC:
```{r echo=TRUE, eval=TRUE, results = 'hide'}
meg <- FLBEIA(biols = biols, SRs = SRs, BDs = NULL, fleets = fleets,
covars = NULL, indices = NULL, advice = advice,
main.ctrl = main.ctrl, biols.ctrl = biols.ctrl, fleets.ctrl = fleets.ctrl.MEG,
covars.ctrl = NULL, obs.ctrl = obs.ctrl, assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
```
Effort restricted by monkfish's TAC:
```{r echo=TRUE, eval=TRUE, results = 'hide'}
mon <- FLBEIA(biols = biols, SRs = SRs, BDs = NULL, fleets = fleets,
covars = NULL, indices = NULL, advice = advice,
main.ctrl = main.ctrl, biols.ctrl = biols.ctrl, fleets.ctrl = fleets.ctrl.MON,
covars.ctrl = NULL, obs.ctrl = obs.ctrl, assess.ctrl = assess.ctrl,
advice.ctrl = advice.ctrl)
```
We summarize the biological information and join all the data frames in a single one.
```{r echo=TRUE, eval=TRUE}
bio <- rbind(bioSum(max, scenario = 'max', years = ac(2019), long = TRUE),
bioSum(min, scenario = 'min', years = ac(2019), long = TRUE),
bioSum(hke, scenario = 'hke', years = ac(2019), long = TRUE),
bioSum(ldb, scenario = 'ldb', years = ac(2019), long = TRUE),
bioSum(meg, scenario = 'meg', years = ac(2019), long = TRUE),
bioSum(mon, scenario = 'mon', years = ac(2019), long = TRUE),
bioSum(Esq, scenario = 'Esq', years = ac(2019), long = TRUE))
```
Once the the short term forecast for each stock has been validated, the main product of the mixed-fisheries advice is the mixed-fisheries advice plot where all the information is summarized.
```{r echo=TRUE, eval=TRUE, fig.height = 20/2.54}
nsc <- 7
nst <- 4
scnms <- unique(bio$scenario)
TAC <- c(8281,1633,399,2153)
catch_stock <- matrix(NA, nsc, nst, dimnames = list(scnms, stknms[c(1,3,4,2)]))
for(sc in scnms)
for(st in stknms)
catch_stock[sc,st] <- subset(bio, indicator == 'catch' & year == '2019'&
stock == st & scenario == sc)$value
diff_catch <- round(sweep(catch_stock, 2, TAC, "-"))
maxC <- max(catch_stock)
minC <- min(diff_catch)
a <- barplot(t(catch_stock), beside = TRUE, ylim = c(-7000,maxC*1.3), xlim = c(1,50),
names.arg=rep("",length(scnms)))
segments(0,0,0, 35)
segments(rep(1,4), TAC, rep(35,4), TAC,lty = 2)
text(36, TAC, 1:4, cex = 0.7)
text(a[2,], maxC*1.15, c('max', 'min', 'hke', 'ldb', 'meg', 'mon', 'sq_E'))
text(a[3,1], maxC*1.2, 'Scenarios:')
for(i in 1:7){
polygon(c(a[1,i]-0.75, a[1,i]-0.75, a[4,i]+0.75, a[4,i]+0.75),
c(minC*1.2,maxC*1.1 , maxC*1.1, minC*1.2), lty = 2)
text(a[,i],minC*1.4,1:4, cex = 0.9)
}
# Plot the overshoot using shading lines.
for(st in 1:4){
sces <- which(diff_catch[,st] > 0)
for(i in sces){
polygon(c(a[st,i]-0.5, a[st,i]-0.5, a[st,i]+0.5, a[st,i]+0.5),
c(TAC[st], catch_stock[i,st], catch_stock[i,st], TAC[st]), col = 'white')
polygon(c(a[st,i]-0.5, a[st,i]-0.5, a[st,i]+0.5, a[st,i]+0.5),
c(TAC[st], catch_stock[i,st], catch_stock[i,st], TAC[st]), density = 25)
}
}
for(st in 1:4){
sces <- which(diff_catch[,st] < 0)
for(i in sces){
polygon(c(a[st,i]-0.5, a[st,i]-0.5, a[st,i]+0.5, a[st,i]+0.5),
c(0, diff_catch[i,st], diff_catch[i,st], 0), col = grey((st-1)/3))
}
}
mtext('Predicted catches for 2019 per stock and scenario', font.main = 1,3,2,at = 17)
mtext(substitute(italic("Overshoot")), 2, 3, at = 7000)
mtext(substitute(italic("|--------------------------------------->")), 2, 2, at = 0, adj = 0)
mtext(substitute(italic("<-------------------|")), 2, 2, at = 0, adj = 1)
mtext(substitute(italic("Undershoot")), 2, 3, at = -6000)
legend(a[4,7]+2, maxC/2, c('1: Hake', '2: Four-spot megrim', '3: Megrim', '4: White anglerfish'),
fill = grey((1:4-1)/4), cex = 0.7, bty = 'n')
```
# More information
* You can submit bug reports, questions or suggestions on this tutorial at <https://github.com/flr/doc/issues>.
* Alternatively, 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 <[email protected]>.
## Software Versions
* `r version$version.string`
* FLCore: `r packageVersion('FLCore')`
* FLBEIA: `r packageVersion('FLBEIA')`
* spict: `r packageVersion('spict')`
* fishmethods: `r packageVersion('fishmethods')`
* **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
**Dorleta GARCIA**. AZTI, Marine Research Unit. Txatxarramendi Ugartea z/g, 48395, Sukarrieta, Bizkaia, Spain. https://www.azti.es/.
**FLBEIA team**. AZTI. Marine Reserach Unit. Txatxarramendi Ugartea z/g, 48395, Sukarrieta, Basque Country, Spain.
**Mail** [email protected]
# References