forked from flr/doc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRunning_Medium_Term_Forecasts_with_FLash.Rmd
755 lines (542 loc) · 25.1 KB
/
Running_Medium_Term_Forecasts_with_FLash.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
---
title: "Running Medium Term Forecasts with FLash"
date: "`r format(Sys.time(), '%d %B, %Y')`"
output:
github_document:
mathjax: TRUE
pdf_document:
fig_width: 6
fig_height: 4
tags: [FLR FLash]
license: Creative Commons Attribution-ShareAlike 4.0 International Public License
---
```{r, ini, echo=FALSE, results='hide', message=FALSE, warnings=FALSE, cache=FALSE}
library(knitr)
source("R/ini.R")
```
This tutorial describes how Medium-Term Forecasts (MTF) can be performed using **FLR**.
It uses the **FLash** package for running projections as well as the **FLBRP** package for evaluating reference points.
MTFs use the same engine as Short-Term Forecasts (STFs). However, there are some key differences between them.
MTFs typically project over 5 to 10 years instead of the usual 3 years for a STF.
Because of this increase in projection length it is necessary to include a stock-recruitment relationship to simulate the dynamics of the biological stock (an STF uses a constant recruitment assumption).
MTFs may also have a more complicated projection control object because they can try to simulate management objectives (e.g. decreases in F over time).
Finally, MTFs may also include consideration of uncertainty by including stochasticity in the projections.
Special attention must be paid to the conditioning and future assumptions of the stock.
## Required packages
To follow this tutorial you should have installed the following packages:
- FLR: [FLCore](http://www.flr-project.org/FLCore/), [FLash](http://www.flr-project.org/FLash/), [FLBRP](http://www.flr-project.org/FLBRP/), [FLAssess](http://www.flr-project.org/FLAssess/)
You can do so as follows,
```{r, eval=FALSE}
install.packages(c("FLCore"), repos="http://flr-project.org/R")
install.packages(c("FLash"), repos="http://flr-project.org/R")
install.packages(c("FLBRP"), repos="http://flr-project.org/R")
install.packages(c("FLAssess"), repos="http://flr-project.org/R")
```
```{r, pkgs}
# This chunk loads all necessary packages, trims pkg messages
library(FLCore)
library(FLash)
library(FLBRP)
library(FLAssess)
```
# Introduction to Medium Term Forecasts
Running a MTF is similar to running a STF in that we need several components:
1. An **FLStock** object set up for the future (assumptions);
2. A stock-recruiment relationship (SRR);
3. A projection control object;
However, there are some significant differences between an MTF and an STF:
1. An MTF is normally run for 5 to 10 years (an STF is normally 3 years);
2. An MTF can use different target types (e.g. setting catch targets, not just F targets);
3. A dynamic SRR should be used (the STF assumption of mean recruitment is not a good one for more a projection of more than 3 years);
4. We can include uncertainty in the recruitment and target values.
In this tutorial we will build a 10 year projection, introduce a range of target types (including minimum and maximum target values and relative target values), use a dynamic SRR and introduce uncertainty.
As ususal, we base the projections on plaice in the North Sea.
# Conditioning the projection
The first step is to condition the projection by making assumptions about the stock in the future and by considering the SRR.
This can be done in several different ways.
## Making the future stock
As ever, load the ple4 data:
```{r, ple4}
data(ple4)
```
We again use `stf()` to set up a future stock (see the STF tutorial.
This makes a lot of assumptions about the future stock (see the LINK TO STF tutorial for more details).
There are methods of setting up the future assumptions but these are not explored here.
We may want to change some of these assumptions but for the moment we will use the defaults.
```{r, stf_condition}
# Set up a 10 year MTF
ple4_mtf <- stf(ple4, nyears = 10)
```
Now the stock goes up to 2027:
```{r, summarymtf}
summary(ple4_mtf)
```
MORE ON ASSUMPTIONS AND CONDITIONING
## The stock-recruitment relationship
In these examples we use a Beverton-Holt model (see the tutorial on fitting SRRs for more detail LINK TO SRR TUTORIAL).
```{r, fitSRR}
ple4_sr <- fmle(as.FLSR(ple4, model="bevholt"), control=list(trace=0))
```
```{r, plotSRR, fig.cap="Fitted Beverton-Holt stock-recruitment relationship for the *ple4* stock object"}
plot(ple4_sr)
```
The resulting SRR fit can be seen in `r fign("plotSRR")`.
# Example 1: F targets
We saw in the STF tutorial how to set an F target (LINK).
Here is some quick revision.
We will set the future F at F status quo (again) and we assume that F status quo is the mean of the last 4 years
```{r, feg1}
f_status_quo <- mean(fbar(ple4)[,as.character(2014:2017)])
f_status_quo
```
Make the control *data.frame* including all the years of the projection:
```{r, feg2}
ctrl_target <- data.frame(year = 2018:2027,
quantity = "f",
val = f_status_quo)
```
Make the *fwdControl* object from the control *data.frame*:
```{r, feg3}
ctrl_f <- fwdControl(ctrl_target)
```
We can take a look at the control object.
We have columns of `year`, `quantity` (target type), `min`, `val` and `max`. `min` and `max` can be ignored for now.
There is also another table underneath (with `min`, `val` and `max`) - again, ignore this for now.
```{r, reg31}
ctrl_f
```
Run fwd() with our three ingredients
```{r, feg4}
ple4_f_sq <- fwd(ple4_mtf, ctrl = ctrl_f, sr = ple4_sr)
```
What just happened? We plot the stock from the year 2010.
```{r, fegplot}
plot(window(ple4_f_sq, start=2010))
```
The future Fs are as we set in the control object (good):
```{r, feg5}
fbar(ple4_f_sq)[,ac(2017:2027)]
```
What about recruitment? Remember we are now using a Beverton-Holt model.
```{r, feg6}
rec(ple4_f_sq)[,ac(2017:2027)]
```
The recruitment is not constant but is not changing very much. That's because the fitted model looks flat REF BACK TO THE SRR FIGURE.
# Example 2: A decreasing catch target
In this example we introduce two new things:
1. A new target type (catch);
2. A changing target value.
Setting a catch target allows to explore the consequences of different TAC strategies.
In this example, the TAC (the total catch of the stock) is reduced 10% each year for 10 years.
We create a vector of future catches based on the catch in 2008:
```{r, ceg1}
future_catch <- c(catch(ple4)[,"2017"]) * 0.9^(1:10)
future_catch
```
We create the *fwdControl* object, setting the quantity to `catch` and passing in the vector of future catches:
```{r, ceg2}
ctrl_catch <- fwdControl(
data.frame(
year=2018:2027,
quantity = "catch",
val=future_catch))
```
The control object has the desired catch target values.
```{r, ceg3}
ctrl_catch
```
We call `fwd()` with the stock, the control object and the SRR:
```{r, ceg4}
ple4_catch <- fwd(ple4_mtf, ctrl_catch, sr = ple4_sr)
```
And take a look at the results:
```{r, cegplot}
plot(window(ple4_catch, start=2010))
```
The decreasing catch targets have been hit. Note that F has to be similarly reduced to hit the catch targets, resulting in a surge in SSB.
# Example 3: Setting an SSB target
In the previous examples we have set target types based on the activity of the fleet (F and catch).
We can also set biological target types. This is useful when there are biological reference points, e.g. Bpa.
Here we set SSB as the target.
## Care with timing
When setting a biological abundance target we have to consider the timing of the target.
In an **FLStock**, abundances are at the beginning of the year (or at the very end of the previous year).
For example, if you look at the total stock abundances you get the stock at the beginning of each year, i.e. before any fishing has occurred.
Internally, **FLash** attempts to hit the desired target by finding the appropriate value of F.
However, the stock abundance at the start of the year is the result of fishing in the previous year, i.e SSB in year Y depends on F in Y-1.
This means that if you set an abundance based target, you are really finding the F in the previous year that will give you that target.
Setting an SSB target in a year is the equivalent of setting an SSB target for the very `end` of that year (the same as setting a target for the very start of the next year).
The result is that you have to be careful with the years in the control object when setting a target based on the stock abundance.
This is best illustrated with a simple example of a one year projection.
If we want to hit an SSB target in 2018 (i.e. the SSB at the start of 2018 etc), we actually set it in the control object as being for 2017 as it is in 2017 that the F will be found that hits the SSB in 2018.
In this example we want the future SSB to be high (we could have used **FLBRP** to come up with a suitable value, e.g. Bmsy but here we just pick a value).
```{r, seg2}
future_ssb <- 500000
ctrl_ssb <- fwdControl(data.frame(year=2017, quantity = "ssb", val=future_ssb))
ctrl_ssb
ple4_ssb <- fwd(ple4_mtf, ctrl_ssb, sr = ple4_sr)
```
Remember, we have effectively set an SSB target for the very end of 2017 but we do not see this in the **FLStock** until the very beginning of 2018.
The result is that we can see that the SSB target has been hit, but not until 2018.
```{r, seg3}
ssb(ple4_ssb)[,ac(2017:2018)]
```
## A longer projection
Here we run a longer projection with a constant SSB target.
The future stock object, `ple4_mtf`, only goes up to 2027. This means that in the control object we can only set an SSB target up to 2026.
Setting an SSB target for 2027 would try to hit the SSB at the start of 2028 which is outside of our stock object, resulting in an error (try it, if you want).
```{r, seg4}
future_ssb <- 500000
ctrl_ssb <- fwdControl(data.frame(year=2017:2026, quantity = "ssb", val=future_ssb))
ple4_ssb <- fwd(ple4_mtf, ctrl_ssb, sr = ple4_sr)
```
The SSB has been hit upto 2027.
```{r, seg5}
ssb(ple4_ssb)[,ac(2016:2027)]
```
Note: we have to ignore the F and removals (catch, landings and discards) in 2027 as these have not been included in the projection and still hold their initial values.
```{r, seg6}
plot(window(ple4_ssb, start=2010, end=2027))
```
# Example 4: Relative catch target
The examples above have dealt with ABSOLUTE target values.
We now introduce the idea of RELATIVE values.
This allows us to set the target value RELATIVE to the value in another year.
We do this by using the `rel.year` column in the control object (the year that the target is relative to).
The `val` column now holds the relative value, not the absolute value.
Here we set catches in the projection years to be 90% of the catches in the previous year, i.e. we want the catches in 2018 to be 0.9 * value in 2017 etc.
```{r, rceg1}
ctrl_rel_catch <- fwdControl(
data.frame(year = 2018:2027,
quantity = "catch",
val = 0.9,
rel.year = 2017:2026))
```
When we look at the control object we can see that an extra column, `rel.year`, appears:
```{r, rceg2}
ctrl_rel_catch
```
We run the projection as normal:
```{r, rceg3}
ple4_rel_catch <- fwd(ple4_mtf, ctrl_rel_catch, sr = ple4_sr)
```
```{r, rceg4}
catch(ple4_rel_catch)
catch(ple4_rel_catch)[,ac(2018:2027)] / catch(ple4_rel_catch)[,ac(2017:2026)]
plot(window(ple4_rel_catch, start = 2010, end = 2027))
```
This is equivalent to the catch example above (LINK TO EXAMPLE 2) but without using absolute values.
# Example 5: Minimum and Maximum targets
In this Example we introduce two new things:
1. Multiple targets;
2. Targets with *bounds*.
Here we set an F target so that the future F = F0.1.
However, we also don't want the catch to fall below a minimum level.
We do this by setting a *minimum* value for the catch.
First we calculate F0.1 using **FLBRP** (see the **FLBRP** tutorial LINK TO FLBRP TUTORIAL):
```{r, meg1}
f01 <- c(refpts(brp(FLBRP(ple4)))["f0.1","harvest"])
f01
```
We'll set our minimum catch to be the mean catch of the last 3 years.
```{r, meg2}
min_catch <- mean(catch(ple4_mtf)[,as.character(2015:2017)])
min_catch
```
To make the control object we can bind together two data.frames, 1 for each target type.
Note that we include a *min = NA* as a column of the F data.frame. This is necessary to bind it to the catch data.frame
```{r, meg3}
ctrl_target <- rbind(
f_df <- data.frame(
year = 2018:2027,
quantity = "f",
val = f01,
min = NA),
catch_df <- data.frame(
year = 2018:2027,
quantity = "catch",
val = NA,
min = min_catch)
)
```
This looks sort of right but we need to order the data.frame so that the years are sequential
and within each year, minimum / maximum targets come after the absolute one.
```{r, meg4}
ctrl_target <- ctrl_target[order(ctrl_target$year),]
ctrl_target
```
Make the control object:
```{r, meg5}
ctrl_min_catch <- fwdControl(ctrl_target)
```
What did we create (again, ignore the second table for the moment)?
We can see that the *min* column has now got some data. The *max* column is still empty.
```{r, meg6}
ctrl_min_catch
```
And project:
```{r, meg7}
ple4_min_catch <- fwd(ple4_mtf, ctrl_min_catch, sr = ple4_sr)
```
What happens? The catch constraint is hit in every year of the projection.
The projected F decreases but never hits the target F because the minimum catch constraint prevents it from dropping further.
```{r, meg8}
plot(window(ple4_min_catch, start = 2010, end = 2027))
```
It is possible to also set a maximum constraint, for example, to prevent F from being too large.
# Example 6 - Relative targets and bounds
In this example we use a combination of *relative* targets and *bounds*.
This kind of approach can be used to model a recovery plan.
For example, we want to decrease F to F0.1 by 2024 (absolute target value) but catches cannot change by more than 10% each year (relative bound).
This requires careful setting up of the control object.
Again, we'll bind two data.frames.
We make a vector of the desired F targets using F0.1 we calculated above.
We set up an F sequence that decreases from the current Fbar in 2017 to F01 in 2024, then F01 until 2027.
```{r, rtbeg1}
current_fbar <- c(fbar(ple4)[,"2017"])
f_target <- c(seq(from = current_fbar, to = f01, length = 8)[-1], rep(f01, 3))
f_target
```
We set maximum annual change in catch to be 10% (in either direction).
```{r, rtbeg2}
rel_catch_bound <- 0.10
```
We make the control **data.frame** by joining a **data.frame** for the F target and one for the catch target.
Note the use of the *rel.year*, *min* and *max* columns in the catch data.frame.
```{r, rtbeg3}
ctrl_target <- rbind(
f_df <- data.frame(
year = 2018:2027,
rel.year = NA,
quantity = "f",
val = f_target,
max = NA,
min = NA),
catch_df <- data.frame(
year = 2018:2027,
rel.year = 2017:2026,
quantity = "catch",
val = NA,
max = 1 + rel_catch_bound,
min = 1 - rel_catch_bound)
)
```
We have to reorder the **data.frame** to be in chronological order and for the absolute values to be before the minimum / maximum targets.
```{r, rtbeg4}
ctrl_target <- ctrl_target[order(ctrl_target$year),]
ctrl_target
```
Make the control object. The *min* and *max* columns now both have data:
```{r, rtbeg5}
ctrl_rel_min_max_catch <- fwdControl(ctrl_target)
ctrl_rel_min_max_catch
```
Run the projection:
```{r, rtbeg6}
recovery<-fwd(ple4_mtf, ctrl=ctrl_rel_min_max_catch, sr=ple4_sr)
```
What happened? The F decreased and then remains constant, while the catch has changed by only a limited amount each year.
```{r, rtbeg7}
plot(window(recovery, start = 2010, end = 2027))
```
The bounds on the catch are operational in several of the years. They prevent the catch from increasing as well as decreasing too strongly, (allegedly) providing stability to the fishery.
```{r, rtbeg8}
catch(recovery)[,ac(2018:2027)] / catch(recovery)[,ac(2017:2026)]
```
# Projections with stochasticity
So far we have looked at combinations of:
* absolute target values;
* relative target values;
* bounds on targets, and
* mixed target types.
But all of the projections have been deterministic, that is they all have only one iteration.
Now, we are going start looking at projecting with multiple iterations.
This is important because it can help us understand the impact of uncertainty (e.g. in the stock-recruitment relationship).
*fwd()* is happy to work over iterations.
It treats each iteration separately.
"All" you need to do is set the arguments correctly.
There are two main ways of introducing iterations into fwd():
1. By passing in residuals to the stock-recruitment function (as another argument to *fwd()*);
2. Through the control object (by setting target values as multiple values)
You can actually use both of these methods at the same time.
As you can probably imagine, this can quickly become very complicated so we'll just do some simple examples to start with.
## Preparation for projecting with iterations
To perform a stochastic projection you need a stock object with multiple iterations.
If you are using the output of a stock assessment method, such as *a4a*, then you may have one already.
Here we use the *propagate()* method to expand the ple4 stock object to have 1000 iterations.
We'll use the ten year projection as before (remember that we probably should change the assumptions that come with the *stf()* method).
```{r, niter}
niters <- 1000
ple4_mtf <- stf(ple4, nyears = 10)
ple4_mtf <- propagate(ple4_mtf, niters)
```
You can see that the 6th dimension, iterations, now has length 1000:
```{r, prop}
summary(ple4_mtf)
```
## Example 7: Stochastic recruitment
There are two arguments to *fwd()* that we haven't used yet:
1. *sr.residuals*
2. *sr.residuals.mult*
These are used for specifying the recruitment residuals (*sr.residuals*) and whether these residuals are multiplicative (*sr.residuals.mult*=TRUE) or additive (FALSE).
In this example we'll use multiplicative residuals i.e. the recruitment values in projection = deterministic recruitment predicted by the SRR model * residuals.
The residuals are passed in as an **FLQuant** with years and iterations.
Here we make an empty **FLQuant** that will be filled with residuals.
```{r, res}
multi_rec_residuals <- FLQuant(NA, dimnames = list(year=2018:2027, iter=1:niters))
```
We're going to use residuals from the stock-recruitment relationship we fitted at the beginning.
We can access these using:
```{r, res2}
residuals(ple4_sr)
```
These residuals are on a log scale i.e. log_residuals = log(observed_recruitment) - log(predicted_recruitment).
To use these log residuals multiplicatively we need to transform them with *exp()*:
We want to fill up our *multi_rec_residuals* **FLQuant** by randomly sampling from these log residuals.
We can do this with the *sample()* function.
We want to sample with replacement (i.e. if a residual is chosen, it gets put back in the pool and can be chosen again).
First we get generate the samples of the years (indices of the residuals we will pick).
```{r, res3}
sample_years <- sample(dimnames(residuals(ple4_sr))$year, niters * 10, replace = TRUE)
```
We fill up the **FLQuant** we made earlier with the residuals using the sampled years:
```{r, res4}
multi_rec_residuals[] <- exp(residuals(ple4_sr)[,sample_years])
```
What have we got?
```{r, res5}
multi_rec_residuals
```
It's an **FLQuant** of SRR residuals but what do those brackets mean?
The information in the brackets is the Median Absolute Deviation, a way of summarising the iterations. We have 1000 iterations but don't want to see all of them - just a summary.
We now have the recruitment residuals.
We'll use the *ctrl_catch* control object we made in [Example 2](#ex2).
with decreasing catch.
We call *fwd()* as usual, only now we have *sr.residuals* and *sr.residuals.mult* arguments.
This takes a little time (we have 1000 iterations).
```{r, res6}
ple4_stoch_rec <- fwd(ple4_mtf, ctrl = ctrl_catch, sr = ple4_sr, sr.residuals = multi_rec_residuals, sr.residuals.mult = TRUE)
```
What just happened? We can see that now we have uncertainty in the recruitment estimates, driven by the residuals.
This uncertainty feeds into the SSB and, to a lesser extent, the projected F and catch.
```{r, res7}
plot(window(ple4_stoch_rec, start = 2010, end = 2027))
```
We can see that the projected stock metrics also have uncertainty in them.
```{r, res8}
rec(ple4_stoch_rec)[,ac(2017:2027)]
fbar(ple4_stoch_rec)[,ac(2017:2027)]
ssb(ple4_stoch_rec)[,ac(2017:2027)]
```
## Example 8: stochastic target values
In this example we introduce uncertainty by including uncertainty in our target values.
This example has catch as the target, except now catch will be stochastic.
We will use the ctrl_catch object from above (we make a copy):
```{r, stv1}
ctrl_catch
ctrl_catch_iters <- ctrl_catch
```
Let's take a look at what else is in the control object:
```{r, stv2}
slotNames(ctrl_catch_iters)
```
The iterations of the target value are set in the *trgtArray* slot.
This is the second table that gets printed when you call the control object.
```{r, stv3}
ctrl_catch_iters@trgtArray
```
What is this slot?
```{r, stv4}
class(ctrl_catch_iters@trgtArray)
dim(ctrl_catch_iters@trgtArray)
```
It's a 3D array with structure: target no x value x iteration.
It's in here that we set the stochastic projection values.
Each row of the *trgtArray* slot corresponds to a row in the control **data.frame** we passed in.
Here we set 10 targets (one for each year in the projection), so the first dimension of *trgtArray* has length 10.
The second dimension always has length 3 (for *min*, *val* and *max* columns).
The third dimension is where the iterations are stored.
This is currently length 1. We have 1000 iterations and therefore we need to expand *trgtArray* along the iter dimension so it can store the 1000 iterations.
Unfortunately, there is not a nice way of doing this.
The simplest way is just to make a new array with the right dimensions.
Note that we need to put in dimnames.
```{r, stv5}
new_trgtArray <- array(NA, dim=c(10,3,niters), dimnames = list(1:10, c("min","val","max"),iter=1:niters))
dim(new_trgtArray)
```
Now we can fill it up with new data (our stochastic catch targets).
We need to generate random catch target data.
This could come from a number of sources (e.g. MSY estimated with uncertainty).
In this example we make it very simple, by using lognormal distribution with a fixed standard deviation of 0.3.
We multiply the deterministic catch target values by samples from this distribution.
```{r, stv6}
future_catch_iters <- ctrl_catch_iters@trgtArray[,"val",] * rlnorm(10 * niters, meanlog = 0, sdlog=0.3)
```
We fill up *trgtArray* with these values.
We just fill up the *val* column (you can also set the *min* and *max* columns to set stochastic bounds).
```{r, stv7}
new_trgtArray[,"val",] <- future_catch_iters
```
We put our new *trgtArray* into the control object:
```{r, stv8}
ctrl_catch_iters@trgtArray <- new_trgtArray
```
We can see that now we have stochasticity in the target values.
```{r, stv9}
ctrl_catch_iters
```
We project as normal using the deterministic SRR.
```{r, stv10}
ple4_catch_iters <- fwd(ple4_mtf, ctrl_catch_iters, sr = ple4_sr)
```
What happened?
```{r, stv11}
plot(window(ple4_catch_iters, start = 2010, end = 2027))
```
The projected catches reflect the uncertainty in the target.
```{r, stv12}
catch(ple4_catch_iters)[,ac(2017:2027)]
```
## Example 9: A projection with stochastic catch and recruiment
What is going on with recruitment in the results of the previous example?
```{r, stv13}
rec(ple4_catch_iters)[,ac(2017:2027)]
```
Remember that here recruitment is not being driven by random residuals, it is only be driven by SSB.
The recruitment in year Y is a result of the SSB in year Y-1.
The SSB in year Y-1 is a result of the catch in year Y-2.
So if catch is stochastic in 2009, we don't see the impact of the stochasticity on the recruitment until 2011. Even then the impact is small.
This seems unlikely so we can also put in recruitment residuals (we already made them for Example 7).
```{r, stv14}
ple4_catch_iters <- fwd(ple4_mtf, ctrl_catch_iters, sr = ple4_sr, sr.residuals = multi_rec_residuals, sr.residuals.mult = TRUE)
```
What happened?
```{r, stv15}
plot(window(ple4_catch_iters, start = 2010, end = 2027))
```
The projected recruitment and catches are stochastic.
```{r, stv16}
catch(ple4_catch_iters)[,ac(2017:2027)]
rec(ple4_catch_iters)[,ac(2017:2027)]
```
# TO DO
## Alternative syntax for controlling the projection
SOMETHING ON CALLING FWD() AND SPECIFYING TARGETS AS ARGUMENTS
## Notes on conditioning projections
SOMETHING ON FWD WINDOW
# References
# 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>.
## Software Versions
* `r version$version.string`
* FLCore: `r packageVersion('FLCore')`
* FLash: `r packageVersion('FLash')`
* FLBRP: `r packageVersion('FLBRP')`
* FLAssess: `r packageVersion('FLAssess')`
* **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
**Finlay Scott**. European Commission, DG Joint Research Centre, Directorate D - Sustainable Resources, Unit D.02 Water and Marine Resources, Via E. Fermi 2749, 21027 Ispra VA, Italy. <https://ec.europa.eu/jrc/>