-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathSS_param.tpl
642 lines (562 loc) · 24.4 KB
/
SS_param.tpl
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
// SS_Label_file #5. **SS_param.tpl**
// SS_Label_file # - <div style="color: #ff0000">INITIALIZE_SECTION</div>
// SS_Label_file #
// SS_Label_file # - not used in SS3
// SS_Label_file # - <div style="color: #ff0000">PARAMETER_SECTION</div>
// SS_Label_file #
// SS_Label_file # - create needed parameters and derived quantities as dvar arrays
// SS_Label_Section_4.99 #INITIALIZE_SECTION (not used in SS3)
INITIALIZATION_SECTION
// SS_Label_Section_5.0 #PARAMETER_SECTION
PARAMETER_SECTION
// {
// SS_Label_Info_5.0.1 #Setup convergence critera and max func evaluations
LOCAL_CALCS
// clang-format on
// set the filename to all ADMB output files to "base_modelname.[ext]"
// where base_modelname can be read from command line with command modelname followed by text
// e.g. ss3_win.exe -nohess -stopph 3 modelname ss4you
// if requested modelname.par is not found, then will attempt to read from ss3.par then ss.par
// whatever name is read, the write will be to modelname.par. Which has default of ss3.par
ad_comm::adprogram_name = base_modelname;
echoinput << "Begin setting up parameters" << endl;
cout << "Begin setting up parameters ... ";
if (readparfile >= 1)
{
anystring = base_modelname + ".par";
cout << " read parm file: " << anystring << endl;
ifstream fin(anystring);
if(fin.fail() ) {
cout << " no find, try ss3.par" << endl;
anystring = "ss3.par";
ifstream fin(anystring);
if(fin.fail() ) {
cout << " no find, try ss.par" << endl;
anystring = "ss.par";
ifstream fin(anystring);
if(fin.fail() ) {
warnstream << "could not find ss3.par, ss.par, or requested parfile " << base_modelname << ".par";
write_message(FATAL, 0);
}
}}
cout << " found "<<anystring<<endl;
ad_comm::change_pinfile_name(anystring);
}
maximum_function_evaluations.allocate(func_eval.indexmin(), func_eval.indexmax());
maximum_function_evaluations = func_eval;
convergence_criteria.allocate(func_conv.indexmin(), func_conv.indexmax());
convergence_criteria = func_conv;
if (do_ageK == 1) // need for age-specific K
{
k = nages;
} // use for dimension of VBK()
else
{
k = 0;
}
// clang-format off
END_CALCS
!! // SS_Label_Info_5.0.2 #Create dummy_parm that will be estimated even if turn_off_phase is set to 0
init_bounded_number dummy_parm(0,2,dummy_phase) // estimate in phase 0
!! // SS_Label_Info_5.1.1 #Create MGparm vector and associated arrays
// growth
init_bounded_number_vector MGparm(1,N_MGparm2,MGparm_LO,MGparm_HI,MGparm_PH)
vector femfrac(1,N_GP*gender);
vector L_inf(1,N_GP*gender);
vector Lmax_temp(1,N_GP*gender);
vector CV_delta(1,N_GP*gender);
matrix VBK(1,N_GP*gender,0,k);
vector Richards(1,N_GP*gender);
vector Lmin(1,N_GP*gender);
vector Lmin_last(1,N_GP*gender);
vector CVLmin(1,N_GP*gender)
vector CVLmax(1,N_GP*gender)
vector CV_const(1,N_GP*gender)
matrix mgp_save(styr,YrMax,1,N_MGparm2);
vector mgp_adj(1,N_MGparm2);
matrix Cohort_Growth(styr,YrMax,0,nages)
3darray Cohort_Lmin(1,N_GP*gender,styr,YrMax,0,nages)
vector VBK_seas(0,nseas);
3darray wtlen_seas(0,nseas,1,N_GP,1,8); // contains seasonally adjusted wtlen_p
matrix wtlen_p(1,N_GP,1,8);
vector parm_dev_stddev(1,N_parm_dev)
vector parm_dev_rho(1,N_parm_dev) // determines the mean regressive characteristic: with 0 = no autoregressive; 1= all autoregressive
3darray wt_len(1,nseas,1,N_GP*gender,1,nlength) // stores wt at mid-bin
// following wt_len are defined for 1,N_GP, but only use gp=1 due to complications in vbio, exp_ms and sizefreq calc
3darray wt_len2(1,nseas,1,N_GP,1,nlength2) // stores wt at midbin; stacked genders
3darray wt_len2_sq(1,nseas,1,N_GP,1,nlength2) // stores wt at midbin^2; stacked genders
3darray wt_len_low(1,nseas,1,N_GP,1,nlength2) // wt at lower edge of size bin
3darray wt_len_fd(1,nseas,1,N_GP,1,nlength2-1) // first diff of wt_len_low
matrix mat_len(1,N_GP,1,nlength)
matrix fec_len(1,N_GP,1,nlength) // fecundity at length
matrix mat_fec_len(1,N_GP,1,nlength)
matrix mat_age(1,N_GP,0,nages)
matrix Hermaphro_val(1,N_GP,0,nages)
matrix catch_mult(styr-1,YrMax,1,Nfleet)
4darray Save_PopLen(styr-3*nseas,TimeMax_Fcast_std+nseas,1,2*pop,1,gmorph,1,nlength)
4darray Save_PopWt(styr-3*nseas,TimeMax_Fcast_std+nseas,1,2*pop,1,gmorph,1,nlength)
4darray Save_PopAge(styr-3*nseas,TimeMax_Fcast_std+nseas,1,2*pop,1,gmorph,0,nages)
4darray Save_PopBio(styr-3*nseas,TimeMax_Fcast_std+nseas,1,2*pop,1,gmorph,0,nages)
LOCAL_CALCS
// clang-format on
// If empirical wt-at-age is used, maturity and fecundity vectors are set to a distinctive value of 0.5
// If parameters are used, then the calcs could be age-based or length-based or both, so start with default value of 1.0
// These calculations happen in function get_mat_fec() in file SS_biofxn.tpl
if (WTage_rd == 1 || Maturity_Option == 4 || Maturity_Option == 5 ) {
mat_len = 0.5;
mat_age = 0.5;
mat_fec_len = 0.5;
fec_len = 0.5;
}
else {
mat_len = 1.0;
mat_age = 1.0;
mat_fec_len = 1.0;
fec_len = 1.0;
}
// clang-format off
END_CALCS
3darray age_age(0,N_ageerr+store_agekey_add,1,n_abins2,0,gender*nages+gender-1)
// where store_agekey_add will normally be 0, but can be the number of blocks if key is from parameters that invoke blocks
3darray age_err(1,N_ageerr+store_agekey_add,1,2,0,nages) // ageing imprecision as stddev for each age
// Age-length keys for each gmorph
4darray ALK(1,N_subseas*nseas,1,gmorph,0,nages,1,nlength)
matrix exp_AL(0,nages2,1,nlength2);
matrix exp_AL_ret(0,nages2,1,nlength2);
3darray Sd_Size_within(1,N_subseas*nseas,1,gmorph,0,nages)
3darray Sd_Size_between(1,N_subseas*nseas,1,gmorph,0,nages)
4darray Ave_Size(styr-3*nseas,TimeMax_Fcast_std+nseas,1,N_subseas,1,gmorph,0,nages)
3darray CV_G(1,N_GP*gender,1,N_subseas*nseas,0,nages); // temporary storage of CV enroute to sd of len-at-age
// 3darray Wt_Age_save(styr-3*nseas,TimeMax_Fcast_std+nseas,1,gmorph,0,nages)
3darray Wt_Age_beg(1,nseas,1,gmorph,0,nages)
3darray Wt_Age_mid(1,nseas,1,gmorph,0,nages)
4darray Wt_Age_t(styr-3*nseas,TimeMax_Fcast_std+nseas,-2,Nfleet,1,gmorph,0,nages) // set to begin period for pop (type=0), or mid period for fleet/survey
// read: yr, seas, gender, morph, settlement, fleet, <age vec> where first value is for age 0!
// if yr=-yr, then fill remaining years for that seas, growpattern, gender, fleet
// fleet 0 contains begin season pop WT
// fleet -1 contains mid season pop WT
// fleet -2 contains maturity*fecundity
3darray migrrate(styr-3,YrMax,1,do_migr2,0,nages)
4darray recr_dist(styr-3,YrMax,1,N_GP*gender,1,N_settle_timings,1,pop);
3darray recr_dist_unf(1,N_GP*gender,1,N_settle_timings,1,pop);
3darray recr_dist_endyr(1,N_GP*gender,1,N_settle_timings,1,pop);
!!// SS_Label_Info_5.1.2 #Create SR_parm vector, recruitment vectors
init_bounded_number_vector SR_parm(1,N_SRparm3,SR_parm_LO,SR_parm_HI,SR_parm_PH)
matrix SR_parm_byyr(styr-3,YrMax,1,N_SRparm2+1) // R0, steepness, parm3, sigmar, rec_dev_offset, R1, rho, SPB Time_vary implementation of spawner-recruitment
vector SR_parm_virg(1,N_SRparm2+1)
vector SR_parm_work(1,N_SRparm2+1)
number two_sigmaRsq;
number half_sigmaRsq;
number sigmaR;
number SPR_virgin;
number regime_change;
number rho;
number dirichlet_Parm;
LOCAL_CALCS
// clang-format on
Ave_Size.initialize();
// if(SR_parm(N_SRparm2)!=0.0 || SR_parm_PH(N_SRparm2)>0) {SR_autocorr=1;} else {SR_autocorr=0;} // flag for recruitment autocorrelation
if (do_recdev == 1)
{
k = recdev_start;
j = recdev_end;
s = 1;
p = -1;
}
else if (do_recdev >= 2)
{
s = recdev_start;
p = recdev_end;
k = 1;
j = -1;
}
else
{
s = 1;
p = -1;
k = 1;
j = -1;
}
// clang-format off
END_CALCS
// vector biasadj(styr-nages,YrMax) // biasadj as used; depends on whether a recdev is estimated or not
// vector biasadj_full(styr-nages,YrMax) // full time series of biasadj values, only used in defined conditions
number sd_offset_rec
init_bounded_number_vector recdev_cycle_parm(1,recdev_cycle,recdev_cycle_LO,recdev_cycle_HI,recdev_cycle_PH)
// init_bounded_dev_vector recdev_early(recdev_early_start,recdev_early_end,recdev_LO,recdev_HI,recdev_early_PH)
init_bounded_vector recdev_early(recdev_early_start,recdev_early_end,recdev_LO,recdev_HI,recdev_early_PH)
init_bounded_dev_vector recdev1(k,j,recdev_LO,recdev_HI,recdev_PH)
init_bounded_vector recdev2(s,p,recdev_LO,recdev_HI,recdev_PH)
vector recdev(recdev_first,YrMax);
LOCAL_CALCS
// clang-format on
if (do_recdev == 0)
{
s = -1;
}
else
{
s = YrMax;
}
if (Do_Impl_Error > 0)
{
k = Fcast_recr_PH2;
j = YrMax;
}
else
{
k = -1;
j = -1;
}
// clang-format off
END_CALCS
init_bounded_vector Fcast_recruitments(recdev_end+1,s,recdev_LO,recdev_HI,Fcast_recr_PH2)
init_bounded_vector Fcast_impl_error(endyr+1,j,-1,1,k)
vector ABC_buffer(endyr+1,YrMax);
// SPAWN-RECR: define some spawning biomass and recruitment entities
number SSB_virgin
number Recr_virgin
number SSB_vir_LH
number SSB_unf
number Recr_unf
number SSB_current; // Spawning biomass
number SSB_equil;
number SPR_trial
number SPR_actual;
number SPR_temp; // used to pass quantity into Equil_SpawnRecr
number Recruits; // Age0 Recruits
number equ_mat_bio
number equ_mat_num
number YPR // variable still used in SPR series
number YPR_Btgt_enc;
number YPR_Btgt_dead;
number YPR_Btgt_N_dead;
number YPR_Btgt_ret;
number YPR_Btgt_cost;
number YPR_Btgt_revenue;
number YPR_Btgt_profit;
number YPR_Btgt;
number YPR_spr_enc;
number YPR_spr_dead;
number YPR_spr_N_dead;
number YPR_spr_ret;
number YPR_spr_cost;
number YPR_spr_revenue;
number YPR_spr_profit;
number Vbio_spr;
number Vbio1_spr;
number Vbio_Btgt;
number Vbio1_Btgt;
number Btgt;
number Btgttgt;
number SPR_Btgt;
number Btgt_Rec;
number Bspr;
number Bspr_rec;
number MSY
number Bmsy
number Recr_msy
number YPR_msy_enc;
number YPR_msy_dead;
number YPR_msy_N_dead;
number YPR_msy_ret;
number YPR_msy_cost;
number YPR_msy_revenue;
number YPR_msy_profit;
number YPR_enc;
number YPR_dead;
number YPR_opt; // used to find F0.1 and Fmsy contains all dead catch
vector YPR_val_vec(1,Nfleet); // used to calculate value, so is multipled by price per unit
number YPR_N_dead;
number YPR_ret;
number Cost; // total fishery cost across all fleets
number Profit; // total revenues - Cost
number MSY_Fmult;
number SPR_Fmult;
number Btgt_Fmult;
number MSY_SPR;
number Btgt2;
number Btgttgt2;
number SPR_Btgt2;
number Btgt_Rec2;
number Btgt_Fmult2;
number H4010_top;
3darray SSB_pop_gp(styr-3,YrMax,1,pop,1,N_GP) //Spawning biomass
vector SSB_yr(styr-3,YrMax)
vector SSB_B_yr(styr-3,YrMax) // mature biomass (no fecundity)
vector SSB_N_yr(styr-3,YrMax) // mature numbers
!!k=0;
!!if(Hermaphro_Option!=0) k=1;
3darray MaleSPB(styr-3,YrMax*k,1,pop,1,N_GP) //Male Spawning biomass
matrix SSB_equil_pop_gp(1,pop,1,N_GP);
matrix MaleSSB_equil_pop_gp(1,pop,1,N_GP);
matrix Recr(1,pop,styr-2*nseas,TimeMax_Fcast_std+nseas) //Recruitment
matrix exp_rec(styr-2,YrMax,1,4) //expected value for recruitment: 1=spawner-recr only; 2=with environ and cycle; 3=with bias_adj; 4=with dev
matrix Nmid(1,gmorph,0,nages);
matrix Nsurv(1,gmorph,0,nages);
3darray natage_temp(1,pop,1,gmorph,0,nages)
number ave_age // average age of fish in unfished population; used to weight R1
!!// SS_Label_Info_5.1.3 #Create M, F, and Z parameters and associated arrays and constants
init_bounded_number_vector init_F(1,N_init_F,init_F_LO,init_F_HI,init_F_PH)
// matrix est_equ_catch(1,nseas,1,Nfleet)
// natural, predation and fishing mortality
matrix natMparms(1,N_natMparms,1,N_GP*gender) // will be derived from the MGparms
!!if(Do_Forecast>0) {k=TimeMax_Fcast_std+nseas;} else {k=TimeMax+nseas;}
4darray natM(styr-3*nseas,k,0,pop,1,N_GP*gender*N_settle_timings,0,nages) // M1 + pred_M2, see desc. in biofxn.tpl
// 3darray natM_M1(1,nseas,1,N_GP*gender*N_settle_timings,0,nages) // base M, biology only
matrix pred_M2(1,N_pred,styr-3*nseas,TimeMax_Fcast_std+nseas); // predator M2
// add area (pop) dimension to same dimension as season; use s1=(p-1)*pop + s
3darray surv1(1,nseas*pop,1,N_GP*gender*N_settle_timings,0,nages)
3darray surv2(1,nseas*pop,1,N_GP*gender*N_settle_timings,0,nages)
4darray Z_rate(styr-3*nseas,k,1,pop,1,gmorph,0,nages)
3darray Zrate2(1,pop,1,gmorph,0,nages)
matrix Hrate(1,Nfleet,styr-3*nseas,k) //Harvest Rate for each fleet; this is F
4darray natage(styr-3*nseas,k,1,pop,1,gmorph,0,nages) // add +1 year
4darray catage(styr-3*nseas,k,1,Nfleet,1,gmorph,0,nages)
4darray disc_age(styr-3*nseas,TimeMax_Fcast_std+nseas,1,2*N_retain_fleets,1,gmorph,0,nages);
4darray equ_catage(1,nseas,1,Nfleet,1,gmorph,0,nages)
4darray equ_numbers(1,nseas,1,pop,1,gmorph,0,3*nages)
4darray equ_Z(1,nseas,1,pop,1,gmorph,0,nages)
matrix catage_tot(1,gmorph,0,nages)//sum the catches for all fleets, reuse matrix each year
matrix bycatch_F(1,Nfleet,1,nseas)
3darray catch_fleet(styr-3*nseas,k,1,Nfleet,1,6) // 1=sel_bio, 2=kill_bio; 3=ret_bio; 4=sel_num; 5=kill_num; 6=ret_num
matrix annual_catch(styr-1,YrMax,1,6) // same six as above
matrix annual_F(styr-1,YrMax,1,3) // 1=sum of hrate (if Pope fmethod) or sum hrate*seasdur if F; 2=Z-M for selected ages; 3=M
3darray equ_catch_fleet(1,6,1,nseas,1,Nfleet)
matrix vuln_bio(styr-3*nseas,k,1,Nfleet) // biomass selected by each fleet
matrix vuln_num(styr-3*nseas,k,1,Nfleet) // numbers selected by each fleet
matrix fec(1,gmorph,0,nages) //relative fecundity at age, is the maturity times the weight-at-age times eggs/kg for females
matrix make_mature_bio(1,gmorph,0,nages) // mature female weight at age
matrix make_mature_numbers(1,gmorph,0,nages) // mature females at age
matrix virg_fec(1,gmorph,0,nages)
vector Equ_SpawnRecr_Result(1,2);
number fish_bio;
number fish_bio_r;
number fish_bio_e;
number fish_num_e;
number fish_num;
number fish_num_r;
number vbio;
number totbio;
number smrybio;
number smrynum;
number smryage; // mean age of the summary numbers (not accounting for settlement timing)
number catch_mnage; // mean age of the catch (not accounting for settlement timing or season of the catch)
number catch_mnage_d; // total catch numbers for calc of mean age
number harvest_rate; // Harvest rate
number maxpossF;
LOCAL_CALCS
// clang-format on
if (N_Fparm > 0) // continuous F
{
k = N_Fparm;
}
else
{
k = -1;
}
// clang-format off
END_CALCS
// defining F_rate as number_vector allows for Fparm_PH to be element specific
init_bounded_number_vector F_rate(1,k,0.,max_harvest_rate,Fparm_PH_dim)
vector Nmigr(1,pop);
number Nsurvive;
number caa;
number Fmult;
number Fcast_Fmult;
number Fcurr_Fmult;
number Fchange;
number last_calc;
matrix Fcast_RelF_Use(1,nseas,1,Nfleet);
matrix Bmark_RelF_Use(1,nseas,1,Nfleet); // relative F among all catch fleets
matrix Bmark_HistF(1,nseas,1,Nfleet); // save F to use for non-optimized fleets
// note that bycatch_F(1,Nfleet,1,nseas) has similar role
number alpha;
number beta;
number GenTime;
number Yield;
number Adj4010;
// !!k1 = styr+(endyr-styr)*nseas-1 + nseas + 1;
// !!y=k1+N_Fcast_Yrs*nseas-1;
!!// SS_Label_Info_5.1.4 #Create Q_parm and associated arrays
init_bounded_number_vector Q_parm(1,Q_Npar2,Q_parm_LO,Q_parm_HI,Q_parm_PH)
matrix Svy_log_q(1,Nfleet,1,Svy_N_fleet);
matrix Svy_q(1,Nfleet,1,Svy_N_fleet);
matrix Svy_se_use(1,Nfleet,1,Svy_N_fleet)
matrix Svy_est(1,Nfleet,1,Svy_N_fleet) // will store expected survey in normal or lognormal units as needed
matrix Svy_selec_abund(1,Nfleet,1,Svy_N_fleet); // Vulnerable biomass
matrix Svy_like_I(1,Nfleet,1,Svy_N_fleet)
vector surv_like(1,Nfleet) // likelihood of the indices
matrix Q_dev_like(1,Nfleet,1,2) // likelihood of the Q deviations
vector disc_like(1,Nfleet) // likelihood of the discard biomass
vector mnwt_like(1,Nfleet) // likelihood of the mean body wt
matrix exp_disc(1,Nfleet,1,disc_N_fleet)
3darray retain(styr-3,YrMax,1,Nfleet,1,nlength2)
vector retain_M(1,nlength)
3darray discmort(styr-3,YrMax,1,Nfleet,1,nlength2)
vector discmort_M(1,nlength)
vector exp_mnwt(1,nobs_mnwt)
matrix Morphcomp_exp(1,Morphcomp_nobs,6,5+Morphcomp_nmorph) // expected value for catch by growthpattern
3darray SzFreqTrans(1,SzFreq_Nmeth*nseas,1,nlength2,1,SzFreq_Nbins_seas_g);
!!// SS_Label_Info_5.1.5 #Selectivity-related parameters
!! echoinput<<" now dimension the selectivity arrays "<<N_selparm2<<endl;
!! echoinput<<selparm_LO<<endl;
!! echoinput<<selparm_HI<<endl;
!! echoinput<<selparm_PH<<endl;
init_bounded_number_vector selparm(1,N_selparm2,selparm_LO,selparm_HI,selparm_PH)
// init_bounded_matrix selparm_dev(1,N_selparm_dev,selparm_dev_minyr,selparm_dev_maxyr,-10,10,selparm_dev_PH)
// matrix selparm_dev_rwalk(1,N_selparm_dev,selparm_dev_minyr,selparm_dev_maxyr)
// vector selparm_dev_stddev(1,N_selparm_dev)
// vector selparm_dev_rho(1,N_selparm_dev) // determines the mean regressive characteristic: with 0 = no autoregressive; 1= all autoregressive
4darray sel_l(styr-3,YrMax,1,Nfleet,1,gender,1,nlength)
4darray sel_l_r(styr-3,YrMax,1,Nfleet,1,gender,1,nlength) // selex x retained
4darray discmort2(styr-3,YrMax,1,Nfleet,1,gender,1,nlength)
4darray sel_a(styr-3,YrMax,1,Nfleet,1,gender,0,nages)
vector sel(1,nlength) // used to multiply by ALK
4darray retain_a(styr-3,YrMax,1,Nfleet,1,gender,0,nages)
4darray discmort_a(styr-3,YrMax,1,Nfleet,1,gender,0,nages)
4darray discmort2_a(styr-3,YrMax,1,Nfleet,1,gender,0,nages)
4darray sel_a_r(styr-3,YrMax,1,Nfleet,1,gender,0,nages)
!! echoinput<<" OK after dimension the selectivity arrays "<<endl;
!! echoinput<<" check "<<TwoD_AR_cnt<<" "<<TwoD_AR_cor_dim<<endl;
3darray cor(1,TwoD_AR_cnt,1,TwoD_AR_cor_dim,1,TwoD_AR_cor_dim)
3darray inv_cor(1,TwoD_AR_cnt,1,TwoD_AR_cor_dim,1,TwoD_AR_cor_dim)
vector det_cor(1,TwoD_AR_cnt);
matrix TwoD_AR_ave(1,TwoD_AR_cnt,TwoD_AR_amin,TwoD_AR_amax) // ragged array for these averages
!! echoinput<<" OK after dimension the 2dar arrays "<<endl;
!!// SS_Label_Info_5.1.6 #Create tag parameters and associated arrays
matrix TG_alive(1,pop,1,gmorph)
matrix TG_alive_temp(1,pop,1,gmorph)
3darray TG_recap_exp(1,N_TG2,0,TG_endtime,0,Nfleet) // do not need to store POP index because each fleet is in just one area
matrix TG_recap_gen(1,100000,1,5) // changes courtesy of Gavin Fay
vector TG_like1(1,N_TG2)
vector TG_like2(1,N_TG2)
number overdisp // overdispersion
LOCAL_CALCS
// clang-format on
k = Do_TG * (3 * N_TG + 2 * Nfleet1);
// clang-format off
END_CALCS
init_bounded_number_vector TG_parm(1,k,TG_parm_LO,TG_parm_HI,TG_parm_PH);
init_bounded_vector_vector parm_dev(1,N_parm_dev,parm_dev_minyr,parm_dev_maxyr,-10,10,parm_dev_PH)
matrix parm_dev_rwalk(1,N_parm_dev,parm_dev_minyr,parm_dev_maxyr);
init_bounded_number checksum999(998,1000,-1) // value must be 999 to check reading of ss.par
vector timevary_parm(1,timevary_parm_cnt); // holds the link parameters; in SS_timevaryparm these are set to actual parms in MGparms, SRparms, Qparms, selparms
matrix parm_timevary(1,timevary_cnt,styr-1,YrMax); // time series of adjusted parm values for block and trend
LOCAL_CALCS
// clang-format on
if (Do_Forecast > 0)
k = TimeMax_Fcast_std + nseas;
else
k = TimeMax + nseas;
// clang-format off
END_CALCS
!!// SS_Label_Info_5.1.7 #Create arrays for storing derived selectivity quantities for use in mortality calculations
// 4darray fish_body_wt(styr-3*nseas,k,1,Nfleet,1,gmorph,0,nages); // wt (adjusted for size selex)
4darray sel_bio(1,nseas,1,Nfleet,1,gmorph,0,nages); // selected * wt
4darray sel_ret_bio(1,nseas,1,Nfleet,1,gmorph,0,nages); // selected * retained * wt
4darray sel_num(1,nseas,1,Nfleet,1,gmorph,0,nages); // selected numbers
4darray sel_ret_num(1,nseas,1,Nfleet,1,gmorph,0,nages); // selected * retained numbers
4darray sel_dead_num(1,nseas,1,Nfleet,1,gmorph,0,nages); // sel * (retain + (1-retain)*discmort)
4darray sel_dead_bio(1,nseas,1,Nfleet,1,gmorph,0,nages); // sel * (retain + (1-retain)*discmort) * wt
4darray save_sel_num(styr-3*nseas,TimeMax_Fcast_std+nseas,1,Nfleet,1,gmorph,0,nages) // save sel_num (Asel_2) and save fecundity for output; +nseas covers no forecast setups
4darray Sel_for_tag(TG_timestart*Do_TG,TimeMax*Do_TG,1,Nfleet,1,gmorph*Do_TG,0,nages)
vector TG_report(1,Nfleet*Do_TG);
vector TG_rep_decay(1,Nfleet*Do_TG);
3darray save_sp_len(styr,YrMax,1,2*Nfleet,1,50); // use to output selex parm values after adjustment
3darray exp_l(1,Nfleet,1,Nobs_l,1,nlen_bin2)
matrix neff_l(1,Nfleet,1,Nobs_l)
vector tempvec_l(1,nlength);
vector exp_l_temp(1,nlength2);
vector exp_truea_ret(0,nages2);
vector exp_l_temp_ret(1,nlength2); // retained lengthcomp
vector exp_l_temp_dat(1,nlen_bin2);
// vector offset_l(1,Nfleet) // Compute OFFSET for multinomial (i.e, value for the multinonial function
matrix length_like(1,Nfleet,1,Nobs_l) // likelihood of the length-frequency data
vector length_like_tot(1,Nfleet) // likelihood of the length-frequency data
matrix SzFreq_exp(1,SzFreq_totobs,1,SzFreq_Setup2);
vector SzFreq_like(1,SzFreq_N_Like)
3darray exp_a(1,Nfleet,1,Nobs_a,1,n_abins2)
vector exp_a_temp(1,n_abins2)
vector tempvec_a(0,nages)
vector agetemp(0,nages2)
matrix neff_a(1,Nfleet,1,Nobs_a)
matrix age_like(1,Nfleet,1,Nobs_a) // likelihood of the age-frequency data
vector age_like_tot(1,Nfleet) // likelihood of the age-frequency data
vector sizeage_like(1,Nfleet) // likelihood of the age-frequency data
3darray exp_ms(1,Nfleet,1,Nobs_ms,1,n_abins2)
3darray exp_ms_sq(1,Nfleet,1,Nobs_ms,1,n_abins2)
number Morphcomp_like
vector equ_catch_like(1,Nfleet)
vector catch_like(1,Nfleet)
number recr_like
number noBias_recr_like
number JT_obj_fun
number regime_like
number sum_recdev
number Fcast_recr_like
number parm_like
matrix parm_dev_like(1,N_parm_dev,1,2)
// vector selparm_dev_like(1,N_selparm_dev)
number CrashPen
number SoftBoundPen
number Equ_penalty
number F_ballpark_like
number R1
number R1_exp
number t1
number t2
number temp
number temp1
number temp2
number temp3
number temp4
number join1
number join2
number join3
number upselex
number downselex
number peak
number peak2
number point1
number point2
number point3
number point4
number timing
number equ_Recr
number equ_F_std
number equ_M_std
!!// SS_Label_Info_5.1.8 #Create matrix called smry to store derived quantities of interest
matrix Smry_Table(styr-3,YrMax,1,17);
// 1=totbio, 2=smrybio, 3=smrynum, 4=enc_catch, 5=dead_catch, 6=ret_catch, 7=spbio, 8=recruit,
// 9=equ_totbio, 10=equ_smrybio, 11=equ_SSB_virgin, 12=equ_S1, 13=Gentime, 14=YPR, 15=meanage_spawners, 16=meanage_smrynums, 17=meanage_catch
matrix env_data(styr-1,YrMax,-4,N_envvar)
matrix TG_save(1,N_TG,1,3+TG_endtime)
// save gradients for all active parameters
!! int parm_grad_active_count = max(1,active_count); // the dummy parameter is still in there even if no other params are estimated
vector parm_gradients(1,parm_grad_active_count);
!!// SS_Label_Info_5.2 #Create sdreport vectors
sdreport_vector SSB_std(1,N_STD_Yr);
sdreport_vector recr_std(1,N_STD_Yr);
sdreport_vector SPR_std(1,N_STD_Yr_Ofish);
sdreport_vector F_std(1,N_STD_Yr_F);
sdreport_vector depletion(1,N_STD_Yr_Dep);
sdreport_vector Mgmt_quant(1,N_STD_Mgmt_Quant)
sdreport_vector Extra_Std(1,Extra_Std_N) // includes many subvectors created in SS_readcontrol
sdreport_vector Svy_sdreport_est(1,Svy_N_sdreport)
!!// SS_Label_Info_5.3 #Create log-Likelihood vectors
vector MGparm_Like(1,N_MGparm2)
vector init_F_Like(1,N_init_F)
vector Q_parm_Like(1,Q_Npar2)
vector selparm_Like(1,N_selparm2)
vector SR_parm_Like(1,N_SRparm3)
vector recdev_cycle_Like(1,recdev_cycle)
!! k=Do_TG*(3*N_TG+2*Nfleet1);
vector TG_parm_Like(1,k);
!!// SS_Label_Info_5.4 #Define objective function
objective_function_value obj_fun
number last_objfun
vector phase_output(1,max_phase+1)
!!cout<<" end of parameter section "<<endl;
!!echoinput<<"end of parameter section"<<endl;
// } // end of parameter section