// Stock Synthesis // Developed by Richard Methot, NOAA Fisheries // ProgLabel_1.0_# DATA_SECTION DATA_SECTION // ProgLabel_1.1.1 Create string with version info !!version_info+="SS-V3.24Z-safe;_05/18/2016;_Stock_Synthesis_by_Richard_Methot_(NOAA)_using_ADMB_11.2x64"; !!version_info_short+="#V3.24Z"; //*********COUNTERS************************* int z // counters for size (length) int z1 // min for z counter int z2 // max for z counter int L1 // for selecting sex specific length data int L2 // used for l+nlength to get length bin for males int A2 // used for a+nages+1 to get true age bin for males int a1 // use to track a subset of ages int f // counter for fleets and surveys int fs // counter for fleets when looping across size and ageselex; so = f-Ntypes int g // counter for gmorph int gg // counter for gender int a // counter for ages int b // counter for age bins int p // counter for area int p1 int p2 // counter for destination area in migration int i // counter for observations int y // counter for year int yz // year, but not allowed to extend past endyr int s // counter for seasons int s2 // destination season int smid // = s+nseas int t // counter for time, combining year and season int mo // month (1-12), not (0-11) int j int j1 int j2 int k int s_off // offset for male section of vectors int Fishon // whether or not to do fishery catch in equil_calc int NP // number of parameters int Ip // parameter counter int firstseas // used to start season loops at the birthseason int t_base; // int niter // iteration count int loop int TG_t; // time counter (in seasons) for tag groups int Fcast_catch_start int ParCount; int N_SC; // counter for starter comments int N_DC; int N_CC; int N_FC; int depletion_fleet; // stores fleet(survey) number for the fleet that is defined as "depletion" int icycle int Ncycle int No_Report // flag to skip output reports after MCMC and MCeval number mcmcFlag number temp; number temp1; int Nparm_on_bound; !! No_Report=0; !! Ncycle=3; // ProgLabel_1.1.2 create elements of parameter labels LOCAL_CALCS adstring_array NumLbl; adstring_array GenderLbl; // gender label adstring_array CRLF; // blank to terminate lines CRLF+=""; GenderLbl+="Fem"; GenderLbl+="Mal"; onenum=" "; for (i=1;i<=199;i++) { sprintf(onenum, "%d", i); NumLbl+=onenum+CRLF(1); } adstring sw; mcmcFlag = 0; for(i=0;i> readline; // reads a single line from input stream if(length(readline)>2) { checkchar=readline(1); k=strcmp(checkchar,"#"); checkchar=readline(1,2); j=strcmp(checkchar,"#C"); if(j==0) {N_SC++; Starter_Comments+=readline;} } } END_CALCS !! echoinput<0) echoinput<0) { echoinput<>runnumber; runnumber++; fin1.close(); } else { runnumber=1; } // ProgLabel_1.3.1 increment runnumber and write to file ofstream fin2("runnumber.ss", ios::out); fin2 << runnumber; fin2.close(); // ProgLabel_1.4 Read Profilevalues.ss file N_prof_var=998; ifstream fin3("profilevalues.ss", ios::in); fin3>>N_prof_var; // if file is null this will not return anything if (N_prof_var==998) {N_prof_var=0; prof_junk=0;} else {prof_junk=1;} fin3.close(); if(N_prof_var>0) {ad_comm::change_datafile_name("profilevalues.ss");} else {ad_comm::change_datafile_name("runnumber.ss");} // just to have something in scope prof_var_cnt=(runnumber-1)*N_prof_var+2; END_CALCS init_vector prof_var(1,prof_junk+runnumber*N_prof_var); //**************************************************************** // ProgLabel_2.0 READ DATA FILE // ProgLabel_2.1 Read comments and dimension info // ProgLabel_2.1.1 Read and save #C comments at top of data file LOCAL_CALCS ad_comm::change_datafile_name(datfilename); cout<<" reading from data file"<> readline; // reads the line from input stream if(length(readline)>2) { checkchar=readline(1); k=strcmp(checkchar,"#"); checkchar=readline(1,2); j=strcmp(checkchar,"#C"); if(j==0) {N_DC++; Data_Comments+=readline;} } } END_CALCS // ProgLabel_2.1.2 read model time dimensions init_int styr //start year of the model !!echoinput<=11.9) {seasdur /=sumseas;} else {seasdur /=12.;} seasdur_half = seasdur*0.5; // half a season TimeMax = styr+(endyr-styr)*nseas+nseas-1; retro_yr=endyr+retro_yr; azero_seas(1)=0.; if(nseas>1) for(s=2;s<=nseas;s++) {azero_seas(s)=sum(seasdur(1,s-1));} // calculate the season that the start of a month occurs within // s=1; // Mo_seas=1; // default is all months are in seas 1 // if(nseas>1) // { // for (mo=2;mo<=12;mo++) // { // if( float(mo-1)/12.>=(azero_seas(s)-0.000001) ) {s++;} // Mo_seas(mo)=s; // } // } // echoinput<<"Mo_seas: "<nseas) { N_warn++; warning<<" spawn_seas index must be <= nseas "<1 && F_reporting==3) {N_warn++; warning<<" F-reporting=3 (sum of full Fs) not advised in multiple area models "<(nages-2) || F_reporting_ages(1)<0) {N_warn++; warning<<" reset lower end of F_reporting_ages to be nages-2 "<(nages-2) || F_reporting_ages(2)<0) {N_warn++; warning<<" reset upper end of F_reporting_ages to be nages-2 "<=styr && y<=endyr) { if(s>nseas) s=nseas; // allows for collapsing multiple season catch data down into fewer seasons // typically to collapse to annual because accumulation will all be in the index "nseas" if(s>0) { t=styr+(y-styr)*nseas+s-1; for(f=1;f<=Nfleet;f++) catch_ret_obs(f,t) += catch_bioT(k,f); } else // distribute catch equally across seasons { for(s=1;s<=nseas;s++) { t=styr+(y-styr)*nseas+s-1; for(f=1;f<=Nfleet;f++) catch_ret_obs(f,t) += catch_bioT(k,f)/nseas; } } } } echoinput<<" processed catch "<0.) {catch_se(t,f)=catch_se_rd(f);} else {catch_se(t,f)=0.1;} // for bycatch fleets } // calc total catch by year so can calculate the first year with catch and to omit zero catch years from sdreport totcat.initialize(); catch_seas_area.initialize(); totcatch_byarea.initialize(); totcat(styr-1)=sum(obs_equ_catch); first_catch_yr=0; if(totcat(styr-1)>0.0) first_catch_yr=styr-1; for(y=styr; y<=endyr; y++) { for(s=1;s<=nseas;s++) { t=styr+(y-styr)*nseas+s-1; for(p=1;p<=pop;p++) for(f=1;f<=Nfleet;f++) if(fleet_area(f)==p && catch_ret_obs(f,t) > 0.0) { totcat(y) += catch_ret_obs(f,t); catch_seas_area(t,p,f)=1; catch_seas_area(t,p,0)=1; totcatch_byarea(t,p)+=catch_ret_obs(f,t); } } if(totcat(y)>0.0 && first_catch_yr==0) first_catch_yr=y; if(y==endyr && totcat(y)==0.0) { N_warn++; warning<<" catch is 0.0 in endyr; this will cause failure in the benchmark and forecast calculations"<0) {k=3; j=Ntypes;} else {k=0; j=Ntypes;} END_CALCS init_imatrix cr_units_rd(1,Ntypes,1,k) ivector cr_units(1,j) //0=num/1=bio/2=F ivector cr_errtype(1,j) // -1=normal / 0=lognormal / >0=T LOCAL_CALCS if(k>0) { echoinput<<"Units: 0=numbers; 1=biomass; 2=F"<0=T"<0) echoinput<<" indexdata "<0) { for(i=1;i<=nobs_cr_rd;i++) { y=indexdata(i,1); s=abs(indexdata(i,2)); // because neg season indicates super period if(s>nseas) {N_warn++; cout<<" EXIT - see warning "< nseas"<=styr && y<=retro_yr) { f=abs(indexdata(i,3)); // negative f turns off observation nyr_cr(f)++; if(indexdata(i,5)<0) {N_warn++; cout<<" EXIT - see warning "<0) { j=N_suprper_cr(f)/2; // because we counted the begin and end if(2*j!=N_suprper_cr(f)) { N_warn++; cout<<" EXIT - see warning "<0) // proceed if any data in yr range { for(i=1;i<=nobs_cr_rd;i++) // loop all, including those out of yr range { y=indexdata(i,1); if(y>=styr && y<=retro_yr) { s=abs(indexdata(i,2)); // because neg season indicates super period t=styr+(y-styr)*nseas+s-1; f=abs(indexdata(i,3)); nyr_cr(f)++; j=nyr_cr(f); yr_cr(f,j)=t; yr_cr_y(f,j)=y; se_cr_obs(f,j)=indexdata(i,5); // later adjust with varadjust, copy to se_cr_use, then adjust with extra se parameter yr_cr_s(f,j)=indexdata(i,2); // so keeps sign of this value if(indexdata(i,3)<0) {yr_cr_use(f,j)=-1;} else {yr_cr_use(f,j)=1;} obs_cr(f,j)=indexdata(i,4); // create super_year indexes if(indexdata(i,2)<0) // start or stop a super-period; ALL observations must be continguous in the file if(in_superperiod==0) // start superperiod {N_suprper_cr(f)++; suprper_cr1(f,N_suprper_cr(f))=j; in_superperiod=1;} else { if(in_superperiod==1) // end superperiod { suprper_cr2(f,N_suprper_cr(f))=j; in_superperiod=0; } else { } } } } echoinput<<" processed survey data "<0 read: fleet, disc_units, disc_error(for 1,Ndisc_fleets), then read obs "<0) {j=Ntypes;} else {j=0;} END_CALCS init_imatrix disc_units_rd(1,Ndisc_fleets,1,3) ivector disc_units(1,j) // formerly scalar disc_type ivector disc_errtype(1,j) // formerly scalar DF_disc vector disc_errtype_r(1,j) // real version for T-dist LOCAL_CALCS disc_units.initialize(); disc_errtype.initialize(); if(Ndisc_fleets>0) { echoinput<<"#_discard_units (1=same_as_catchunits(bio/num);2=fraction; 3=numbers)"<0 for DF of T-dist(read CV below); 0 for normal with CV; -1 for normal with se; -2 for lognormal"<0) echoinput<<" discarddata "<0) { for(i=1;i<=nobs_disc_rd;i++) // get count of observations in date range { y=discdata(i,1); s=abs(discdata(i,2)); if(s>nseas) {N_warn++; cout<<" EXIT - see warning "< nseas"<=styr && y<=retro_yr) { f=abs(discdata(i,3)); nyr_disc(f)++; if(discdata(i,5)<0) {N_warn++; cout<<"EXIT - see warning"<0) { j=N_suprper_disc(f)/2; // because we counted the begin and end if(2*j!=N_suprper_disc(f)) { N_warn++; cout<<"EXIT - see warning"<0) { for(i=1;i<=nobs_disc_rd;i++) { y=discdata(i,1); if(y>=styr && y<=retro_yr) { s=abs(discdata(i,2)); f=abs(discdata(i,3)); t=styr+(y-styr)*nseas+s-1; nyr_disc(f)++; j=nyr_disc(f); yr_disc(f,j)=t; yr_disc_y(f,j)=y; yr_disc_s(f,j)=discdata(i,2); cv_disc(f,j)=discdata(i,5); obs_disc(f,j)=discdata(i,4); if(discdata(i,4)<0.0) discdata(i,3)=-abs(discdata(i,3)); // convert to new format using negative fleet if(discdata(i,3)<0) {yr_disc_use(f,j)=-1;} else {yr_disc_use(f,j)=1;} if(catch_ret_obs(f,t)<=0.0) { N_warn++; warning<<" discard observation but no corresponding catch, yr, seas, fleet "<0) echoinput<<" meanbodywt_data "<=styr && y<=retro_yr) nobs_mnwt++; } END_CALCS matrix mnwtdata(1,9,1,nobs_mnwt) // yr, seas, type, mkt, obs, CV LOCAL_CALCS yr_mnwt2=0; if(nobs_mnwt>0) j=0; for(i=1;i<=nobs_mnwt_rd;i++) { y=mnwtdata1(i,1); if(y>=styr && y<=retro_yr) { j++; s=mnwtdata1(i,2); if(s<1) {N_warn++; cout<<" EXIT - see warning "<nseas) {N_warn++; cout<<" EXIT - see warning "< nseas"<0) echoinput<0) echoinput<nlen_bin) { N_warn++; warning<<"Combgender_l cannot be greater than nlen_bin; resetting"<len_bins(nlength)) { N_warn++; cout<<"Critical error, see warning.sso"<=topbin) {ibin++; } //echoinput<<" incr ibin "; if(ibin>1) {botbin=len_bins_dat(ibin);} if(ibin=botbin && len_bins(z+1)<=topbin ) //echoinput<<" pop inside dat, put here"<0) echoinput<<" first lencomp obs "<0) for(i=1;i<=nobsl_rd;i++) { y=lendata(i,1); if(y>=styr && y<=retro_yr) { f=abs(lendata(i,3)); s=abs(lendata(i,2)); if(lendata(i,6)<0) {N_warn++; cout<<"error in length data "<0) { for(floop=1;floop<=Ntypes;floop++) // loop fleets for(i=1;i<=nobsl_rd;i++) // loop all observations to find those for this fleet/time { y=lendata(i,1); if(y>=styr && y<=retro_yr) { s=abs(lendata(i,2)); if(s>nseas) {N_warn++; cout<<" EXIT - see warning "< nseas"<0) { for(z=1;z<=CombGender_l;z++) { obs_l(f,j,z)+=obs_l(f,j,z+nlen_bin); obs_l(f,j,z+nlen_bin)=0.0; } tails_l(f,j,3)=nlen_binP+CombGender_l; } if(gen_l(f,j)==2) obs_l(f,j)(1,nlen_bin) = 0.; // zero out females for male-only obs if(gen_l(f,j)<=1 && gender==2) obs_l(f,j)(nlen_binP,nlen_bin2) = 0.; // zero out males for female-only or combined gender obs obs_l(f,j) /= sum(obs_l(f,j)); // make sum to 1.00 if(gen_l(f,j)!=2) // do females, unless Male-only observation { k=0; temp=sum(obs_l(f,j)(1,nlen_bin)); for(z=1;z<=nlen_bin;z++) if(obs_l(f,j,z)>0.) // find Nbins with data {k++;} if(temp>0.0 && k>1) // only compress tail if obs exist for this gender and there is more than 1 bin with data { k=0; for(z=1;z<=nlen_bin-1;z++) // compress Female lower tail until exceeds min_tail { if(obs_l(f,j,z)<=min_tail && k==0) { obs_l(f,j,z+1)+=obs_l(f,j,z); obs_l(f,j,z)=0.00; tails_l(f,j,1)=z+1; } else {k=1;} } k=0; for(z=nlen_bin;z>=tails_l(f,j,1);z--) // compress Female upper tail until exceeds min_tail { if(obs_l(f,j,z)<=min_tail && k==0) { obs_l(f,j,z-1)+=obs_l(f,j,z); obs_l(f,j,z)=0.00; tails_l(f,j,2)=z-1; } else {k=1;} } } obs_l(f,j)(tails_l(f,j,1),tails_l(f,j,2)) += min_comp; // add min_comp to bins in range } if(gen_l(f,j)>=2 && gender==2) // process males { k=0; temp=sum(obs_l(f,j)(nlen_binP,nlen_bin2)); for(z=nlen_binP;z<=nlen_bin2;z++) if(obs_l(f,j,z)>0.) {k++;} if(temp>0.0 && k>1) // only compress tail if obs exist for this gender and there is more than 1 bin with data { k=0; k1=tails_l(f,j,3); for(z=k1;z<=nlen_bin2-1;z++) { if(obs_l(f,j,z)<=min_tail && k==0) { obs_l(f,j,z+1)+=obs_l(f,j,z); obs_l(f,j,z)=0.00; tails_l(f,j,3)=z+1; } else {k=1;} } k=0; for(z=nlen_bin2;z>=tails_l(f,j,3);z--) // compress Male upper tail until exceeds min_tail { if(obs_l(f,j,z)<=min_tail && k==0) { obs_l(f,j,z-1)+=obs_l(f,j,z); obs_l(f,j,z)=0.00; tails_l(f,j,4)=z-1; } else {k=1;} } } obs_l(f,j)(tails_l(f,j,3),tails_l(f,j,4)) += min_comp; // add min_comp to bins in range } // end doing males obs_l(f,j) /= sum(obs_l(f,j)); // make sum to 1.00 again after adding min_comp if(gender==1 || gen_l(f,j)!=2) {obs_l_all(1,f)(1,nlen_bin)+=obs_l(f,j)(1,nlen_bin);} // females or combined if(gender==2) { if(gen_l(f,j)==1 || gen_l(f,j)==3) // put females into female only { obs_l_all(3,f)(1,nlen_bin)+=obs_l(f,j)(1,nlen_bin); } if(gen_l(f,j)>=2) // put males into combined and into male only { for(z=1;z<=nlen_bin;z++) { obs_l_all(1,f,z)+=obs_l(f,j,nlen_bin+z); obs_l_all(4,f,z)+=obs_l(f,j,nlen_bin+z); } } } } } } } echoinput<<"Overall_Compositions"<0.0) { obs_l_all(j,f)/=temp; } else { obs_l_all(j,f)=float(1./nlen_bin); } } } obs_l_all(2,f,1)=obs_l_all(1,f,1); // first bin for(z=2;z<=nlen_bin;z++) { obs_l_all(2,f,z)=obs_l_all(2,f,z-1)+obs_l_all(1,f,z); } if(Nobs_l(f)>0) { echoinput<0) { for(i=1;i<=N_ageerr;i++) { if(age_err_rd(i,2,0)<0.) Use_AgeKeyZero=i; // set flag for setup of age error parameters } echoinput<<"set agekey: "<0 && N_ageerr==0) { N_warn++; cout<<" EXIT - see warning "<n_abins2) { N_warn++; warning<<"Combgender_a cannot be greater than n_abins; resetting"<0) echoinput<<" first agecomp obs "<=styr && y<=retro_yr) { f=abs(agedata(i,3)); if(agedata(i,9)<0) {N_warn++; cout<<"error in age data "<N_ageerr) {N_warn++; cout<<"error in age data "<0) { echoinput<<"process age comps "<=styr && y<=retro_yr) { s=abs(agedata(i,2)); if(s>nseas) {N_warn++; cout<<" EXIT - see warning "< nseas"<N_ageerr) { N_warn++; cout<<" EXIT - see warning "<nlength) Lbin_hi(f,j)=nlength; break; } case 2: // values are data length bin numbers { if(Lbin_lo(f,j)<=0) Lbin_lo(f,j)=1; if(Lbin_hi(f,j)<=0 || Lbin_hi(f,j)>nlen_bin) Lbin_hi(f,j)=nlen_bin; s=0; for(k=1;k<=nlength;k++) { if( len_bins(k)==len_bins_dat(Lbin_lo(f,j)) ) s=k; // find poplen bin that matches data len bin } if(s==0) {N_warn++; cout<<" EXIT - see warning "<len_bins(nlength)) Lbin_hi(f,j)=len_bins(nlength); s=0; for(k=1;k<=nlength;k++) { if( len_bins(k)==Lbin_lo(f,j) ) s=k; // find poplen bin that matches input length for lbin_lo } if(s==0) {N_warn++; cout<<" exit - see warning "<nlength || Lbin_lo(f,j)>Lbin_hi(f,j)) {N_warn++; cout<<" EXIT - see warning "<0) { for(z=1;z<=CombGender_a;z++) { obs_a(f,j,z)+=obs_a(f,j,z+n_abins); obs_a(f,j,z+n_abins)=0.0; } tails_a(f,j,3)=n_abins+1+CombGender_a; } } obs_a(f,j) /= sum(obs_a(f,j)); if(gen_a(f,j)!=2) // do females, unless Male-only observation { k=0; temp=sum(obs_a(f,j)(1,n_abins)); for(z=1;z<=n_abins;z++) if(obs_a(f,j,z)>0.) {k++;} if(temp>0.0 && k>1) // only compress tail if obs exist for this gender and there is more than 1 bin with data { k=0; for(z=1;z<=n_abins-1;z++) // compress Female lower tail until exceeds min_tail { if(obs_a(f,j,z)<=min_tail && k==0) { obs_a(f,j,z+1)+=obs_a(f,j,z); obs_a(f,j,z)=0.00; tails_a(f,j,1)=z+1; } else {k=1;} } k=0; for(z=n_abins;z>=tails_a(f,j,1);z--) // compress Female upper tail until exceeds min_tail { if(obs_a(f,j,z)<=min_tail && k==0) { obs_a(f,j,z-1)+=obs_a(f,j,z); obs_a(f,j,z)=0.00; tails_a(f,j,2)=z-1; } else {k=1;} } } obs_a(f,j)(tails_a(f,j,1),tails_a(f,j,2)) += min_comp; // add min_comp to bins in range } // done with females if(gen_a(f,j)>=2 && gender==2) // compress Male tails until exceeds min_tail { k=0; temp=sum(obs_a(f,j)(n_abins1,n_abins2)); for(z=n_abins1;z<=n_abins2;z++) if(obs_a(f,j,z)>0.) {k++;} if(temp>0.0 && k>1) // only compress tail if obs exist for this gender and there is more than 1 bin with data { k=0; for(z=n_abins1;z<=n_abins2-1;z++) { if(obs_a(f,j,z)<=min_tail && k==0) { obs_a(f,j,z+1)+=obs_a(f,j,z); obs_a(f,j,z)=0.00; tails_a(f,j,3)=z+1; } else {k=1;} } k=0; for(z=n_abins2;z>=tails_a(f,j,3);z--) // compress Male upper tail until exceeds min_tail { if(obs_a(f,j,z)<=min_tail && k==0) { obs_a(f,j,z-1)+=obs_a(f,j,z); obs_a(f,j,z)=0.00; tails_a(f,j,4)=z-1; } else {k=1;} } } obs_a(f,j)(tails_a(f,j,3),tails_a(f,j,4)) += min_comp; // add min_comp to bins in range } if(sum(obs_a(f,j))>0.) obs_a(f,j) /= sum(obs_a(f,j)); // make sum to 1.00 again after adding min_comp if(gender==1 || gen_a(f,j)!=2) obs_a_all(1,f)(1,n_abins)+=obs_a(f,j)(1,n_abins); // females or combined if(gender==2 && gen_a(f,j)>=2) { for(a=1;a<=n_abins;a++) { obs_a_all(1,f,a)+=obs_a(f,j,n_abins+a); // males } } } } } echoinput<<"Fleet age_bins "<0) { obs_a_all(1,f)/=sum(obs_a_all(1,f)); } else { obs_a_all(1,f)=float(1./n_abins); } obs_a_all(2,f,1)=obs_a_all(1,f,1); // first bin for(a=2;a<=n_abins;a++) { obs_a_all(2,f,a)=obs_a_all(2,f,a-1)+obs_a_all(1,f,a); } echoinput<0) echoinput<<" first size-at-age obs "<0) for(i=1;i<=nobs_ms_rd;i++) { y=sizeagedata(i,1); if(y>=styr && y<=retro_yr) { f=abs(sizeagedata(i,3)); if(sizeagedata(i,7)<0) {N_warn++; cout<<"error in meansize"<0) { in_superperiod=0; for(floop=1;floop<=Ntypes;floop++) for(i=1;i<=nobs_ms_rd;i++) { y=sizeagedata(i,1); if(y>=styr && y<=retro_yr) { s=abs(sizeagedata(i,2)); if(s>nseas) {N_warn++; cout<<" EXIT - see warning "< nseas"<N_ageerr) { N_warn++;cout<<" EXIT - see warning "<0) { if(N_envdata>0)echoinput<<" env data "<=(styr-1)) {env_data_RD(env_temp(i,1), env_temp(i,2) ) = env_temp(i,3);} } END_CALCS // ProgLabel_2.11 start generalized size composition section // ProgLabel_2.11.1 read generalized size frequency data (aka wt frequency) int SzFreqMethod; int iobs; init_int SzFreq_Nmeth; // number of sizefreq methods to be read !!echoinput<0) echoinput<0) echoinput<0) echoinput<0) echoinput<0) echoinput<0) { SzFreq_HaveObs.initialize(); SzFreq_HaveObs2.initialize(); for(k=1;k<=SzFreq_Nmeth;k++) { SzFreq_Nbins3(k)=gender*SzFreq_Nbins(k); for(s=1;s<=nseas;s++) { g++; SzFreq_Nbins_seas_g(g)=SzFreq_Nbins(k)*gender; } } } END_CALCS init_matrix SzFreq_bins1(1,SzFreq_Nmeth,1,SzFreq_Nbins); // lower edge of wt bins !!if(SzFreq_Nmeth>0) echoinput<<" SizeFreq bins-raw "<0) { for(k=1;k<=SzFreq_Nmeth;k++) { // set flag for accumulating, or not, fish from small pop len bins up into first SzFreq data bin SzFreq_Omit_Small(k)=1; if(SzFreq_bins1(k,1)<0) { SzFreq_Omit_Small(k)=-1; SzFreq_bins1(k,1)*=-1; // make this positive for use in model, then write out as negative in data.ss_new } SzFreq_bins(k)(1,SzFreq_Nbins(k))=SzFreq_bins1(k)(1,SzFreq_Nbins(k)); if(gender==2) { for(j=1;j<=SzFreq_Nbins(k);j++) { SzFreq_bins(k,j+SzFreq_Nbins(k))=SzFreq_bins1(k,j); } } if(SzFreq_scale(k)==2) // convert from lbs to kg { SzFreq_bins(k)*=0.4536; } else if (SzFreq_scale(k)==4) // convert from inches to cm { SzFreq_bins(k)*=2.54; } SzFreq_bins2(k,0)=0.; SzFreq_bins2(k)(1,SzFreq_Nbins(k))=SzFreq_bins(k)(1,SzFreq_Nbins(k)); if(gender==2) { SzFreq_bins2(k,SzFreq_Nbins(k)+1)=0.; for(j=1;j<=SzFreq_Nbins(k);j++) {SzFreq_bins2(k,j+SzFreq_Nbins(k)+1)=SzFreq_bins2(k,j);} } echoinput<<"Processed_SizeFreqMethod_bins"<0) { g=0; for(k=1;k<=SzFreq_Nmeth;k++) for(j=1;j<=SzFreq_nobs(k);j++) {g++; SzFreq_Setup(g)=7+gender*SzFreq_Nbins(k); SzFreq_Setup2(g)=gender*SzFreq_Nbins(k);} } END_CALCS // ProgLabel_2.11.2 read size comp observations into a ragged array // , with the number of elements for each obs stored in sizefreq_setup // unlike the size and agecomp, obs from all fleets are in one dimension, rather than having a dimension for fleet // to do super-period, obs must be sorted by fleet and time within each method init_matrix SzFreq_obs1(1,SzFreq_totobs,1,SzFreq_Setup); !!if(SzFreq_totobs>0) echoinput<<" first sizefreq obs "< // SzFreq_obs_hdr: 1=y; 2=s; 3=f; 4=gender; 5=partition; 6=method&skip flag; 7=first bin to use; 8=last bin(e.g. to include males or not) vector SzFreq_sampleN(1,SzFreq_totobs); vector SzFreq_effN(1,SzFreq_totobs); vector SzFreq_eachlike(1,SzFreq_totobs); matrix SzFreq_obs(1,SzFreq_totobs,1,SzFreq_Setup2); imatrix SzFreq_LikeComponent(1,Ntypes,1,SzFreq_Nmeth) number N_suprper_SzFreq // no real need to keep track of these by method, so just use a number LOCAL_CALCS SzFreq_N_Like=0; if(SzFreq_Nmeth>0) { SzFreq_LikeComponent.initialize(); SzFreq_obs.initialize(); N_suprper_SzFreq=0; iobs=0; for(k=1;k<=SzFreq_Nmeth;k++) { for(j=1;j<=SzFreq_nobs(k);j++) { // if(y>=styr && y<=retro_yr) // not used because all obs in one list iobs++; for(z=1;z<=5;z++) {SzFreq_obs_hdr(iobs,z) = int(SzFreq_obs1(iobs,z+1));} SzFreq_sampleN(iobs) = SzFreq_obs1(iobs,7); if(SzFreq_obs_hdr(iobs,2)<0) N_suprper_SzFreq++; // count the number of superperiod start/stops if(SzFreq_obs_hdr(iobs,4)==3) // both genders { for(z=1;z<=SzFreq_Setup2(iobs);z++) {SzFreq_obs(iobs,z)=SzFreq_obs1(iobs,7+z);} } else if(SzFreq_obs_hdr(iobs,4)<=1) // combined gender or female only { for(z=1;z<=SzFreq_Nbins(k);z++) {SzFreq_obs(iobs,z)=SzFreq_obs1(iobs,7+z);} } else // male only { for(z=SzFreq_Nbins(k)+1;z<=SzFreq_Setup2(iobs);z++) {SzFreq_obs(iobs,z)=SzFreq_obs1(iobs,7+z);} } if(gender==1) SzFreq_obs_hdr(iobs,4)=1; // just in case SzFreq_obs(iobs)/=sum(SzFreq_obs(iobs)); SzFreq_obs(iobs)+=SzFreq_mincomp(k); SzFreq_obs(iobs)/=sum(SzFreq_obs(iobs)); y=SzFreq_obs_hdr(iobs,1); s=abs(SzFreq_obs_hdr(iobs,2)); if(s>nseas) {N_warn++; cout<<" EXIT - see warning "< nseas"<=styr && y<=retro_yr) { SzFreq_LikeComponent(f,k)=1; // indicates that this combination is being used if(SzFreq_HaveObs(f,k,t,1)==0) SzFreq_HaveObs(f,k,t,1)=iobs; // save first counter in time x fleet locations with data SzFreq_HaveObs(f,k,t,2)=iobs; // saves last pointer to this source of data if(SzFreq_HaveObs2(k,t)==0 || f<=SzFreq_HaveObs2(k,t)) SzFreq_HaveObs2(k,t)=f; // find the smallest numbered f index that uses this method have_data(f,t)=1; if(SzFreq_obs_hdr(iobs,7)<0) SzFreq_obs_hdr(iobs,3)=-abs(SzFreq_obs_hdr(iobs,3)); // old method for excluding from logL } else { SzFreq_obs_hdr(iobs,3)=-abs(SzFreq_obs_hdr(iobs,3)); // flag for skipping this obs } } } SzFreq_N_Like=sum(SzFreq_LikeComponent); if(N_suprper_SzFreq>0) { j=N_suprper_SzFreq/2; // because we counted the begin and end if(2*j!=N_suprper_SzFreq) { N_warn++; cout<<" EXIT - see warning "<0) { SzFreq_like_base.initialize(); suprper_SzFreq_start.initialize(); suprper_SzFreq_end.initialize(); suprper_SzFreq_sampwt.initialize(); N_suprper_SzFreq=0; // redo this counter so can use the counter // count the number of type x methods being used to create vector length for the likelihoods g=0; for(f=1;f<=Ntypes;f++) for(k=1;k<=SzFreq_Nmeth;k++) { if(SzFreq_LikeComponent(f,k)>0) {g++; SzFreq_LikeComponent(f,k)=g;} // so stored value g gives index in list of logL elements } in_superperiod=0; for(iobs=1;iobs<=SzFreq_totobs;iobs++) { k=SzFreq_obs_hdr(iobs,6); // get the method f=abs(SzFreq_obs_hdr(iobs,3)); s=SzFreq_obs_hdr(iobs,2); // sign used to indicate start/stop of super period if(SzFreq_obs_hdr(iobs,3)>0) // negative for out of range or skip { z1=SzFreq_obs_hdr(iobs,7); z2=SzFreq_obs_hdr(iobs,8); g=SzFreq_LikeComponent(f,k); SzFreq_like_base(g)-=SzFreq_sampleN(iobs)*SzFreq_obs(iobs)(z1,z2)*log(SzFreq_obs(iobs)(z1,z2)); } // identify super-period starts and stops if(s<0) // start/stop a super-period ALL observations must be continguous in the file { if(in_superperiod==0) { N_suprper_SzFreq++; suprper_SzFreq_start(N_suprper_SzFreq)=iobs; in_superperiod=1; } else if(in_superperiod==1) // end a super-period { suprper_SzFreq_end(N_suprper_SzFreq)=iobs; in_superperiod=0; } } } } echoinput<<" finished processing sizefreq data "<0) echoinput<<"sizefreq superperiod start obs: "<0) { Do_TG=1; N_TG=TG_temp(1); N_TG_recap=TG_temp(2); TG_mixperiod=TG_temp(3); TG_maxperiods=TG_temp(4); N_TG2=N_TG; TG_timestart=9999; echoinput<0) { for(TG=1;TG<=N_TG;TG++) { t=styr+int((TG_release(TG,3)-styr)*nseas+TG_release(TG,4)-1); TG_release(TG,5)=t; if(tTimeMax) k-=(t+TG_maxperiods-TimeMax); TG_endtime(TG)=k; } } END_CALCS // ProgLabel_2.12.1 store recapture info by TG group and time to follow it as a cohort init_matrix TG_recap_data(1,N_TG_recap,1,5) // TG, year, season, fleet, gender, Number 3darray TG_recap_obs(1,N_TG2,0,TG_endtime,0,Nfleet); // no area index because each fleet is in just one area LOCAL_CALCS if(N_TG>0) { echoinput<<"First row of tag-recapture data "<TG_maxperiods) t=TG_maxperiods; if(t<0) { N_warn++; cout<<" EXIT - see warning "<0.) TG_recap_obs(TG,TG_t)(1,Nfleet)/=TG_recap_obs(TG,TG_t,0); } } } END_CALCS // ProgLabel_2.13 Morphcomposition data init_int Do_Morphcomp !!echoinput<0) { Morphcomp_nobs=mc_temp(1); Morphcomp_nmorph=mc_temp(2); // later compare this value to the n morphs in the control file and exit if different Morphcomp_mincomp=mc_temp(3); echoinput<0) { echoinput<<" morph composition data"<retro_yr) Morphcomp_obs(i,5) = -fabs(Morphcomp_obs(i,5)); Morphcomp_obs(i)(6,5+Morphcomp_nmorph) /= sum(Morphcomp_obs(i)(6,5+Morphcomp_nmorph)); Morphcomp_obs(i)(6,5+Morphcomp_nmorph) += Morphcomp_mincomp; Morphcomp_obs(i)(6,5+Morphcomp_nmorph) /= sum(Morphcomp_obs(i)(6,5+Morphcomp_nmorph)); } } END_CALCS // ProgLabel_2.14 End of datafile indicator init_int fid !! if(fid!=999) {cout<<" final data value in error "<> readline; // reads the line from input stream if(length(readline)>2) { checkchar=readline(1); k=strcmp(checkchar,"#"); checkchar=readline(1,2); j=strcmp(checkchar,"#C"); if(j==0) {N_FC++; Forecast_Comments+=readline;} } } END_CALCS init_int Do_Benchmark // 0=skip; do Fspr, Fbtgt, Fmsy !!echoinput<=styr) {Bmark_Yr(i)=Bmark_Yr_rd(i);} else if(Bmark_Yr_rd(i)<=0) {Bmark_Yr(i)=endyr+Bmark_Yr_rd(i);} else { N_warn++;Bmark_Yr(i)=styr;warning<<"benchmark year less than styr; reset to equal styr"<0) { Fcast_Input(1,k)=Fcast_Input_rd(1,k); k=0; k++; N_Fcast_Yrs=int(Fcast_Input(k)); echoinput<0) {Fcast_yr(i)=Fcast_yr(i);} else {Fcast_yr(i)=endyr+Fcast_yr(i);} } Fcast_Sel_yr1=Fcast_yr(1); Fcast_Sel_yr2=Fcast_yr(2); Fcast_RelF_yr1=Fcast_yr(3); Fcast_RelF_yr2=Fcast_yr(4); echoinput< control rule bottom "<1.0) {N_warn++; warning<<" Sure you want harvest policy scalar > 1.0? "<0.0) Do_Impl_Error=1; k++; Do_Rebuilder=int(Fcast_Input(k)); k++; Rebuild_Ydecl=int(Fcast_Input(k)); k++; Rebuild_Yinit=int(Fcast_Input(k)); echoinput<< Do_Rebuilder<<" Do_Rebuilder "<0) {k=1;} else {k=0;} if(Do_Forecast>0) { echoinput<<"Now read cap for each fleet, then cap for each area (even if only 1 area), then allocation assignment for each fleet"<0) { for(f=1;f<=Nfleet;f++) {if(Fcast_MaxFleetCatch(f)>0.0) Fcast_Do_Fleet_Cap=1;} for(p=1;p<=pop;p++) {if(Max_Fcast_Catch(p)>0.0) Fcast_Do_Area_Cap=1;} Fcast_Catch_Allocation_Groups=max(Allocation_Fleet_Assignments); } END_CALCS init_matrix Fcast_Catch_Allocation(1,N_Fcast_Yrs,1,Fcast_Catch_Allocation_Groups); LOCAL_CALCS if(Do_Forecast>0) { k=2; echoinput<<" Max totalcatch by fleet "<0) { N_Fcast_Input_Catches=more_Fcast_input(1); Fcast_InputCatch_Basis=more_Fcast_input(2); echoinput<0) echoinput<<"Now read "<0) echoinput<<" Fcast_catches_input "<0) { for(t=k1;t<=y;t++) for(f=1;f<=Nfleet;f++) {Fcast_InputCatch(t,f,1)=-1;} if(N_Fcast_Input_Catches>0) { for(i=1;i<=N_Fcast_Input_Catches;i++) { y=Fcast_InputCatch_rd(i,1); s=Fcast_InputCatch_rd(i,2); f=Fcast_InputCatch_rd(i,3); if(y>endyr && y<=YrMax && f<=Nfleet) { t=styr+(y-styr)*nseas +s-1; Fcast_InputCatch(t,f,1)=Fcast_InputCatch_rd(i,4); if(y>=Fcast_Cap_FirstYear) {N_warn++;warning<<"Input catches in "<0) echoinput<<"Processed "<0 && Do_Forecast<=0) {N_warn++; cout<<" EXIT - see warning "<=1 && Do_Forecast<=3) {Do_Benchmark=1; N_warn++; warning<<" Turn Benchmark on because Forecast needs it"<0) {F_report_basis=0; N_warn++; warning<<" Set F_report_basis=0 because no benchmark or forecast"<=1 && SPR_reporting<=3) {SPR_reporting=4; N_warn++; warning<<" Change SPR_reporting to 4 because benchmarks are off"<Fcast_Sel_yr2) {N_warn++; cout<<" EXIT - see warning "<endyr || Fcast_Sel_yr1endyr || Fcast_Sel_yr20 && fif!=999) {cout<<" EXIT, must have 999 to verify end of forecast inputs "<YrMax) STD_Yr_max=YrMax; STD_Yr_Reverse.initialize(); for(y=STD_Yr_min;y<=STD_Yr_max;y++) {STD_Yr_Reverse(y)=1;} for(i=1;i<=N_STD_Yr_RD;i++) {if(STD_Yr_RD(i)>=styr && STD_Yr_RD(i)0) { j++; STD_Yr_Reverse(y)=j; // use for SPB and recruitment if(y>=styr) { // depletion must start in year AFTER first catch. It could vary earlier if recdevs happened enough earlier to change spbio, but this is not included if((depletion_basis>0 && y>first_catch_yr) || y==endyr) {N_STD_Yr_Dep++; STD_Yr_Reverse_Dep(y) = N_STD_Yr_Dep; } if(y<=endyr) { if((SPR_reporting>0 && totcat(y)>0.0) || y==endyr) {N_STD_Yr_Ofish++; STD_Yr_Reverse_Ofish(y) = N_STD_Yr_Ofish; } if((F_reporting>0 && totcat(y)>0.0) || y==endyr) {N_STD_Yr_F++; STD_Yr_Reverse_F(y) = N_STD_Yr_F; } } else { if(SPR_reporting>0) {N_STD_Yr_Ofish++; STD_Yr_Reverse_Ofish(y) = N_STD_Yr_Ofish; } if(F_reporting>0) {N_STD_Yr_F++; STD_Yr_Reverse_F(y) = N_STD_Yr_F; } } } } } END_CALCS //********CONTROLS******************************** // ProgLabel_4.0 Begin Reading from Control File LOCAL_CALCS ad_comm::change_datafile_name(ctlfilename); echoinput<> readline; // reads the line from input stream if(length(readline)>2) { checkchar=readline(1); k=strcmp(checkchar,"#"); checkchar=readline(1,2); j=strcmp(checkchar,"#C"); if(j==0) {N_CC++; Control_Comments+=readline;} } } END_CALCS // ProgLabel_4.2 Read info for growth patterns, gender, birthseasons, sub-morphs init_int N_GP // number of growth patterns !!echoinput<1) { *(ad_comm::global_datafile) >> sd_ratio; *(ad_comm::global_datafile) >> submorphdist; echoinput<1) { sd_within_platoon = sd_ratio * sqrt(1. / (1. + sd_ratio*sd_ratio)); sd_between_platoon = sqrt(1. / (1. + sd_ratio*sd_ratio)); } else {sd_within_platoon=1; sd_between_platoon=0.000001;} if(N_platoon==1) {ishadow(1)=0; shadow(1)=0.;} else if (N_platoon==3) {ishadow.fill_seqadd(-1,1); shadow.fill_seqadd(-1.,1.);} else if (N_platoon==5) {ishadow.fill_seqadd(-2,1); shadow.fill_seqadd(-2.,1.);} else {N_warn++; cout<<" EXIT - see warning "<0) { echoinput<<" recr distribution as read "<0.) { recr_dist_pattern_2(gp,birthseas)=1; use_morph(g)=1; } } if(use_morph(g)==1) { if( (N_platoon==1) || (N_platoon==3 && gp2==2) || (N_platoon==5 && gp2==3) ) GP_finder(gp,k)=g; // finds g for a given GP and gender and last birstseason } } } for(g=1;g<=gmorph;g++) for(s=1;s<=nseas;s++) { curr_age_beg(g,s)=r_ages+azero_seas(s)-azero_G(g); curr_age_mid(g,s)=curr_age_beg(g,s)+seasdur_half(s); // curr_age3(g,s)=curr_age_beg(g,s)+seasdur(s); if(azero_G(g)>azero_seas(s)) { a=0; while(curr_age_mid(g,s,a)<0.0) {curr_age_mid(g,s,a)=0.0; a++;} a=0; while(curr_age_beg(g,s,a)<0.0) {curr_age_beg(g,s,a)=0.0; a++;} } a=0; } if(N_TG>0) { for(TG=1;TG<=N_TG;TG++) { for(g=1;g<=gmorph;g++) { if(TG_release(TG,6)>2) {N_warn++; warning<<" gender for tag groups must be 0, 1 or 2 "<0 && (TG_release(TG,6)==0 || TG_release(TG,6)==sx(g))) TG_use_morph(TG,g)=1; } } } END_CALCS // ProgLabel_4.3 define movement between areas int do_migration // number of explicit movements to define number migr_firstage matrix migr_start(1,nseas,1,N_GP) LOCAL_CALCS migr_firstage=0.0; do_migration=0; if (pop>1) { *(ad_comm::global_datafile) >> do_migration; echoinput<0) { *(ad_comm::global_datafile) >> migr_firstage; echoinput<0) { echoinput<<" migration setup "<0) { if(GP4(g)==gp && firstBseas(gp)==0) firstBseas(gp)=Bseas(g); } } for(g=1;g<=gmorph;g++) if(use_morph(g)>0 && firstBseas(GP4(g))==Bseas(g)) { for(s=1;s<=nseas;s++) { a=0; while(curr_age_beg(g,s,a)0) { for(k=1;k<=do_migration;k++) {move_def2(k)=move_def(k);} k=do_migration; for(s=1;s<=nseas;s++) for(gp=1;gp<=N_GP;gp++) for(p=1;p<=pop;p++) { if(move_pattern(s,gp,p,p)>do_migration) { k++; move_def2(k,1)=s; move_def2(k,2)=gp; move_def2(k,3)=p; move_def2(k,4)=p; move_def2(k,5)=0; move_def2(k,6)=nages; } } } END_CALCS // ProgLabel_4.4 define the time blocks for time-varying parameters int k1 int k2 int k3 init_int N_Block_Designs // read N block designs !!echoinput<0) echoinput<0) Nblk2=Nblk + Nblk; END_CALCS init_imatrix Block_Design(1,N_Block_Designs,1,Nblk2) // read the ending year for each block LOCAL_CALCS if(N_Block_Designs>0) { echoinput<<" read block info "<retro_yr+1) {N_warn++; cout<<" EXIT - see warning "<retro_yr+1) {N_warn++; warning<<"Block:"<=1.0) fracfemale=0.999999; !!if(fracfemale<=0.0) fracfemale=0.000001; // read natmort setup init_int natM_type; // 0=1Parm; 1=segmented; 2=Lorenzen; 3=agespecific; 4=agespec with seas interpolate !!echoinput<=3) {k1=N_GP*gender;} // for reading age_natmort } END_CALCS init_vector NatM_break(1,k); // these breakpoints only get read for natM_type=1 !!if(k>0) echoinput<0) echoinput<<" Age_NatMort "<0) echoinput<nages) AFIX2_forCV=nages; AFIX_delta=AFIX2-AFIX; if(AFIX!=0.0) {AFIX_plus=AFIX;} else {AFIX_plus=1.0e-06;} MGparm_per_def=N_natMparms+N_growparms; lin_grow_beg.initialize(); lin_grow_mid.initialize(); for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { first_grow_age=0; for(a=0;a<=nages;a++) { for(s=1;s<=nseas;s++) { if(a==0 && s0) echoinput<<"Age-specific_K_points"<0) echoinput<<" Len_At_Age_rd"<0) echoinput<<" read Age_Maturity for each GP"<0) echoinput<<" read Length_Maturity for each GP"<5) {N_warn++; cout<<" EXIT - see warning "<0) k=2; init_ivector Hermaphro_more(1,k); int Hermaphro_seas; int Hermaphro_maleSPB; LOCAL_CALCS Hermaphro_seas=0; Hermaphro_maleSPB=0; if (k>0) { Hermaphro_seas=Hermaphro_more(1); Hermaphro_maleSPB=Hermaphro_more(2); echoinput<0) { N_MGparm+=2*do_migration; for(k=1;k<=do_migration;k++) { s=move_def(k,1); gp=move_def(k,2); p=move_def(k,3); p2=move_def(k,4); ParCount++; ParmLabel+="MoveParm_A_seas_"+NumLbl(s)+"_GP_"+NumLbl(gp)+"from_"+NumLbl(p)+"to_"+NumLbl(p2); ParCount++; ParmLabel+="MoveParm_B_seas_"+NumLbl(s)+"_GP_"+NumLbl(gp)+"from_"+NumLbl(p)+"to_"+NumLbl(p2); } } if(Use_AgeKeyZero>0) { AgeKeyParm=N_MGparm+1; for(k=1;k<=7;k++) { N_MGparm++; ParCount++; ParmLabel+="AgeKeyParm"+NumLbl(k); } } END_CALCS init_matrix MGparm_1(1,N_MGparm,1,14) // matrix with natmort and growth parms controls ivector MGparm_offset(1,N_MGparm) LOCAL_CALCS echoinput<<" Biology parameter setup"<1) { for(j=1;j<=MGparm_per_def;j++) { if(MGparm_1(Ip+j,3)==0.0 && MGparm_1(Ip+j,7)<0) MGparm_offset(Ip+j)=Ip+j-N_GP*MGparm_per_def; // value is zero and not estimated } } Ip+=MGparm_per_def; } } echoinput<<"Now read blocks and other adjustments to MGparms "<0) {mgp_type(k,k+2)=3; k=k+3;} // herma parameters done with wtlen and fecundity mgp_type(k,MGP_CGD-1)=4; // recruit apportionments mgp_type(MGP_CGD)=2; // cohort growth dev if(do_migration>0) mgp_type(MGP_CGD+1,N_MGparm)=5; if(Use_AgeKeyZero>0) mgp_type(AgeKeyParm,N_MGparm)=6; MGparm_env.initialize(); // will store the index of environ fxns here MGparm_envtype.initialize(); N_MGparm_env=0; for (f=1;f<=N_MGparm;f++) { if(MGparm_1(f,8)!=0) { N_MGparm_env ++; MGparm_env(f)=N_MGparm+N_MGparm_env; if(MGparm_1(f,8)>0) { ParCount++; ParmLabel+=ParmLabel(f)+"_ENV_mult"; MGparm_envtype(f)=1; MGparm_envuse(f)=MGparm_1(f,8); if(MG_adjust_method==2) {N_warn++; cout<<" EXIT - see warning "<0) { *(ad_comm::global_datafile) >> customMGenvsetup; if(customMGenvsetup==0) {k1=1;} else {k1=N_MGparm_env;} echoinput<0) echoinput<<" MGparm-env setup "<N_Block_Designs) {N_warn++; warning<<" ERROR, Block > N Blocks "<0) { g=1; for(a=1;a<=Nblk(z);a++) { N_MGparm_blk++; y=Block_Design(z,g); time_vary_MG(y,mgp_type(j))=1; sprintf(onenum, "%d", y); ParCount++; k=int(MGparm_1(j,14)); switch(k) { case 0: {ParmLabel+=ParmLabel(j)+"_BLK"+NumLbl(z)+"mult_"+onenum+CRLF(1); break;} case 1: {ParmLabel+=ParmLabel(j)+"_BLK"+NumLbl(z)+"add_"+onenum+CRLF(1); break;} case 2: {ParmLabel+=ParmLabel(j)+"_BLK"+NumLbl(z)+"repl_"+onenum+CRLF(1); break;} case 3: {ParmLabel+=ParmLabel(j)+"_BLK"+NumLbl(z)+"delta_"+onenum+CRLF(1); break;} } y=Block_Design(z,g+1)+1; // first year after block if(y>endyr+1) y=endyr+1; time_vary_MG(y,mgp_type(j))=1; for(y=Block_Design(z,g);y<=Block_Design(z,g+1);y++) // loop years for this block, including yrs past endyr+1 { Block_Defs_MG(j,y)=N_MGparm+N_MGparm_env+N_MGparm_blk; } g+=2; } echoinput<<"Block definitions for MGparms"<0) { *(ad_comm::global_datafile) >> customblocksetup_MG; if(customblocksetup_MG==0) {k1=1;} else {k1=N_MGparm_blk;} echoinput<0) echoinput<<" MGparm-blk setup "<0) echoinput<<" MGparm-blk setup "<0) echoinput<<"MG trend and cycle parameters "<0) { k1=0; k2=N_MGparm+N_MGparm_env+N_MGparm_blk; for(j=1;j<=N_MGparm;j++) { if(MGparm_1(j,13)<0) // timetrend exists { k1++; MGparm_trend_rev(k1)=j; // reverse pointer from trend to affected parameter MGparm_trend_rev_1(k1)=k2; // pointer to base in list of MGparms (so k2+1 is first parameter used) if(MGparm_1(j,13)>=-2) // timetrend {k2+=3;} else {k2+=Ncycle;} } } } END_CALCS // ProgLabel_4.5.7 set up seasonal effects for MG parms init_ivector MGparm_seas_effects(1,10) // femwtlen1, femwtlen2, mat1, mat2, fec1 fec2 Malewtlen1, malewtlen2 L1 K int MGparm_doseas int N_MGparm_seas // number of MGparms that use seasonal effects LOCAL_CALCS echoinput<0) { for(j=1;j<=10;j++) { if(MGparm_seas_effects(j)>0) { MGparm_seas_effects(j)=N_MGparm+N_MGparm_env+N_MGparm_blk+N_MGparm_seas; // store base parameter count for(s=1;s<=nseas;s++) { N_MGparm_seas++; ParCount++; ParmLabel+=MGseasLbl(j)+"_seas_"+NumLbl(s); } } } } END_CALCS init_matrix MGparm_seas_1(1,N_MGparm_seas,1,7) // read matrix that defines the seasonal parms !!if(N_MGparm_seas>0) echoinput<<" MGparm_seas"<0) {MG_active(mgp_type(f))=1;} } if(natM_type==2 && MG_active(2)>0) MG_active(1)=1; // lorenzen M depends on growth j=N_MGparm; if(N_MGparm_env>0) { for (f=1;f<=N_MGparm_env;f++) { j++; if(customMGenvsetup==0) {k=1;} else {k=f;} MGparm_LO(j)=MGparm_env_1(k,1); MGparm_HI(j)=MGparm_env_1(k,2); MGparm_RD(j)=MGparm_env_1(k,3); MGparm_PR(j)=MGparm_env_1(k,4); MGparm_PRtype(j)=MGparm_env_1(k,5); MGparm_CV(j)=MGparm_env_1(k,6); MGparm_PH(j)=MGparm_env_1(k,7); } } if(N_MGparm_blk>0) for (f=1;f<=N_MGparm_blk;f++) { j++; if(customblocksetup_MG==0) k=1; else k=f; MGparm_LO(j)=MGparm_blk_1(k,1); MGparm_HI(j)=MGparm_blk_1(k,2); MGparm_RD(j)=MGparm_blk_1(k,3); MGparm_PR(j)=MGparm_blk_1(k,4); MGparm_PRtype(j)=MGparm_blk_1(k,5); MGparm_CV(j)=MGparm_blk_1(k,6); MGparm_PH(j)=MGparm_blk_1(k,7); } if(N_MGparm_trend>0) for (f=1;f<=N_MGparm_trend2;f++) { j++; MGparm_LO(j)=MGparm_trend_1(f,1); MGparm_HI(j)=MGparm_trend_1(f,2); MGparm_RD(j)=MGparm_trend_1(f,3); MGparm_PR(j)=MGparm_trend_1(f,4); MGparm_PRtype(j)=MGparm_trend_1(f,5); MGparm_CV(j)=MGparm_trend_1(f,6); MGparm_PH(j)=MGparm_trend_1(f,7); } if(N_MGparm_seas>0) for (f=1;f<=N_MGparm_seas;f++) { j++; MGparm_LO(j)=MGparm_seas_1(f,1); MGparm_HI(j)=MGparm_seas_1(f,2); MGparm_RD(j)=MGparm_seas_1(f,3); MGparm_PR(j)=MGparm_seas_1(f,4); MGparm_PRtype(j)=MGparm_seas_1(f,5); MGparm_CV(j)=MGparm_seas_1(f,6); MGparm_PH(j)=MGparm_seas_1(f,7); } END_CALCS // ProgLabel_4.5.8 set up random deviations for MG parms int N_MGparm_dev // number of MGparms that use annual deviations LOCAL_CALCS N_MGparm_dev=0; for(f=1;f<=N_MGparm;f++) { if(MGparm_1(f,9)>=1) N_MGparm_dev ++; } END_CALCS ivector MGparm_dev_minyr(1,N_MGparm_dev) ivector MGparm_dev_maxyr(1,N_MGparm_dev) vector MGparm_dev_stddev(1,N_MGparm_dev) ivector MGparm_dev_type(1,N_MGparm_dev) // contains type of dev: 1 for multiplicative, 2 for additive, 3 for additive randwalk ivector MGparm_dev_select(1,N_MGparm) int MGparm_dev_PH LOCAL_CALCS MGparm_dev_select.initialize(); int N_MGparm_dev_tot=0; if(N_MGparm_dev>0) { j=0; for (f=1;f<=N_MGparm;f++) { if(MGparm_1(f,9)>=1) { j++; if(MG_adjust_method==2 && MGparm_1(f,9)==1) {N_warn++; warning<<" cannot use MG_adjust_method==2 and multiplicative devs for parameter "<endyr) { N_warn++; warning<<" reset MGparm_dev end year to endyr for MGparm: "<> MGparm_dev_PH; echoinput<0 && y0) { MG_active(f)=1; time_vary_MG(y,0)=1; // tracks active status for all MG types } } } MG_active(0)=sum(MG_active(1,6)); END_CALCS //************************************** // ProgLabel_4.6 read setup for Spawner-Recruitment parameters // read setup for SR parameters: LO, HI, INIT, PRIOR, PRtype, CV, PHASE init_int SR_fxn ivector N_SRparm(1,10) !!N_SRparm.fill("{0,2,2,2,3,2,3,3,0,0}"); int N_SRparm2 !!echoinput<N_envvar) { N_warn++; warning<<" ERROR: SR_env_link ( "<0) {N_warn++; warning<<" WARNING: SR_env_target was set, but no SR_env_link selected, SR_env_target set to 0"<0) { recdev_options(1,13)=recdev_options_rd(1,13); recdev_early_start_rd=recdev_options(1); recdev_early_PH=recdev_options(2); Fcast_recr_PH=recdev_options(3); Fcast_recr_lambda=recdev_options(4); recdev_adj(1)=recdev_options(5); recdev_adj(2)=recdev_options(6); recdev_adj(3)=recdev_options(7); recdev_adj(4)=recdev_options(8); recdev_adj(5)=recdev_options(9); // maxbias adj recdev_cycle=recdev_options(10); recdev_LO=recdev_options(11); recdev_HI=recdev_options(12); recdev_read=recdev_options(13); } else { recdev_early_start_rd=0; // 0 means no early recdev_early_end=-1; recdev_early_PH=-4; recdev_options(2)=recdev_early_PH; Fcast_recr_PH=0; // so will be reset to maxphase+1 recdev_options(3)=Fcast_recr_PH; Fcast_recr_lambda=1.; recdev_adj(1)=double(styr)-1000.; recdev_adj(2)=styr-nages; recdev_adj(3)=recdev_end; recdev_adj(4)=double(endyr)+1.; recdev_adj(5)=1.0; recdev_cycle=0; recdev_LO=-5; recdev_HI=5; recdev_read=0; } recdev_early_start=recdev_early_start_rd; if(recdev_adv>0) {echoinput<<"#_start of advanced SR options"<0) { for(y=1;y<=recdev_cycle;y++) { ParCount++; sprintf(onenum, "%d", y); ParmLabel+="RecrDev_Cycle_"+onenum+CRLF(1); } } // ProgLabel_4.6.4 setup recruitment deviations and create parm labels for each year if(recdev_end>retro_yr) recdev_end=retro_yr; if(recdev_start<(styr-nages)) {recdev_start=styr-nages; N_warn++; warning<<" adjusting recdev_start to: "<=recdev_start) { N_warn++; cout<<" EXIT - see warning "<0) recdev_early_PH=-recdev_early_PH; } else { if(recdev_early_start<0) recdev_early_start+=recdev_start; // do relative to start of recdevs recdev_do_early=1; if(recdev_early_start<(styr-nages)) {recdev_early_start=styr-nages; N_warn++; warning<<" adjusting recdev_early to: "<=styr) { sprintf(onenum, "%d", y); ParmLabel+="Early_RecrDev_"+onenum+CRLF(1); } else { onenum=" "; sprintf(onenum, "%d", styr-y); ParmLabel+="Early_InitAge_"+onenum+CRLF(1); } } } if(do_recdev>0) { for(y=recdev_start;y<=recdev_end;y++) { ParCount++; recdev_doit(y)=1; if(y>=styr) { sprintf(onenum, "%d", y); ParmLabel+="Main_RecrDev_"+onenum+CRLF(1); } else { onenum=" "; sprintf(onenum, "%d", styr-y); ParmLabel+="Main_InitAge_"+onenum+CRLF(1); } } } if(Do_Forecast>0) { for(y=recdev_end+1;y<=YrMax;y++) { sprintf(onenum, "%d", y); ParCount++; if(y>endyr) {ParmLabel+="ForeRecr_"+onenum+CRLF(1);} else {ParmLabel+="Late_RecrDev_"+onenum+CRLF(1);} } for(y=endyr+1;y<=YrMax;y++) { sprintf(onenum, "%d", y); ParCount++; ParmLabel+="Impl_err_"+onenum+CRLF(1); } } END_CALCS // ProgLabel_4.6.5 read recdev_cycle parameters and input recruitment deviations if needed init_matrix recdev_cycle_parm_RD(1,recdev_cycle,1,14); !!k=1; !!if(recdev_cycle>0) k=recdev_cycle; vector recdev_cycle_LO(1,k); vector recdev_cycle_HI(1,k); ivector recdev_cycle_PH(1,k); !!if(recdev_cycle>0) echoinput<<"recruitment cycle input "<0) echoinput<<"recruitment deviation input "<3) { N_warn++; warning<<" ERROR: F_Method must be 1 or 2 or 3, value is: "<0.999) {N_warn++; cout<<" EXIT - see warning "<1.0 for F_method 2 or 3 "<1) { if(F_Method==2) { echoinput<0.0) { N_warn++; warning<0.0 && init_F_RD(f)<=0.0) {N_warn++; cout<<" EXIT - see warning "<0"<0.) { have_catch(g)=F_setup(2); } else { have_catch(g)=-1; } } if(F_detail>0) { for(k=1;k<=F_detail;k++) { f=F_setup2(k,1); y=F_setup2(k,2); s=F_setup2(k,3); g=(f-1)*(TimeMax-styr+1)+(y-styr)*nseas+s; t=styr+(y-styr)*nseas+s-1; if(F_setup2(k,6)!=-999) have_catch(g)=F_setup2(k,6); // used to setup the phase for F_rate if(F_setup2(k,5)!=-999) catch_se(t,f)=F_setup2(k,5); // reset the se for this observation // setup of F_rate values occurs later in the parameter section } } } END_CALCS //*********************************** // ProgLabel_4.8 read catchability (Q) setup init_matrix Q_setup(1,Ntypes,1,4) // do power, env-var, extra sd, devtype(<0=mirror, 0=float_nobiasadj 1=float_biasadj, 2=parm_nobiasadj, 3=rand, 4=randwalk); num/bio/F, err_type(0=lognormal, >=1 is T-dist-lognormal) // change to matrix because devstd has real, not integer, values int Q_Npar2 int Q_Npar int ask_detail imatrix Q_setup_parms(1,Ntypes,1,4) LOCAL_CALCS echoinput<<" Q setup "<0) { Q_Npar++; Q_setup_parms(f,1)=Q_Npar; ParCount++; ParmLabel+="Q_power_"+NumLbl(f)+"_"+fleetname(f); if(Q_setup(f,4)<2) {N_warn++; warning<<" must create base Q parm to use Q_power for fleet: "<0) { Q_Npar++; Q_setup_parms(f,3)=Q_Npar; ParCount++; ParmLabel+="Q_extraSD_"+NumLbl(f)+"_"+fleetname(f); } } // ProgLabel_4.8.2 create time-varying catchability as needed Q_Npar2=Q_Npar; for (f=1;f<=Ntypes;f++) { Q_setup_parms(f,4)=0; if(Q_setup(f,4)>=2) { Q_Npar++; Q_Npar2++; Q_setup_parms(f,4)=Q_Npar; ParCount++; ParmLabel+="LnQ_base_"+NumLbl(f)+"_"+fleetname(f); if(Q_setup(f,4)==3) { ask_detail=1; Q_Npar2++; Q_Npar+=nyr_cr(f); for(j=1;j<=nyr_cr(f);j++) { y=yr_cr_y(f,j); ParCount++; sprintf(onenum, "%d", y); onenum+=CRLF(1); if(nseas==1) { ParmLabel+="Q_dev_"+NumLbl(f)+"y_"+onenum; } else { ParmLabel+="Q_dev_"+NumLbl(f)+"y_"+onenum+"_s_"+NumLbl(abs(yr_cr_s(f,j))); } } } if(Q_setup(f,4)==4) { ask_detail=1; Q_Npar2++; Q_Npar+=nyr_cr(f)-1; for(j=2;j<=nyr_cr(f);j++) { y=yr_cr_y(f,j); ParCount++; // _itoa(y,onenum,10); sprintf(onenum, "%d", y); onenum+=CRLF(1); if(nseas==1) { ParmLabel+="Q_walk_"+NumLbl(f)+"y_"+onenum; } else { ParmLabel+="Q_walk_"+NumLbl(f)+"y_"+onenum+"_s_"+NumLbl(abs(yr_cr_s(f,j))); } } } } else if(cr_errtype(f)==-1) {N_warn++; cout<<" EXIT - see warning "<=0) // lognormal { N_warn++; warning<<" Lognormal error selected for effort deviations for fleet "<0) // density-dependence { N_warn++; warning<<" Do not use Density-dependence for effort deviations (fleet "<0) {k=Q_Npar;} else {k=1;} END_CALCS vector Q_parm_LO(1,k) vector Q_parm_HI(1,k) ivector Q_parm_PH(1,k) int Q_parm_detail LOCAL_CALCS if(ask_detail>0) { *(ad_comm::global_datafile) >> Q_parm_detail; echoinput<0) echoinput<<" Catchability parameters"<0) { Q_Npar++; Q_parm_1(Q_Npar)=Q_parm_2(Q_Npar); } } for (f=1;f<=Ntypes;f++) { if(Q_setup(f,2)!=0) { Q_Npar++; Q_parm_1(Q_Npar)=Q_parm_2(Q_Npar); } } for (f=1;f<=Ntypes;f++) { if(Q_setup(f,3)>0) { Q_Npar++; Q_parm_1(Q_Npar)=Q_parm_2(Q_Npar); } } Q_Npar2=Q_Npar; for (f=1;f<=Ntypes;f++) { if(Q_setup(f,4)>=2) { Q_Npar++; Q_Npar2++; Q_parm_1(Q_Npar)=Q_parm_2(Q_Npar2); if(Q_setup(f,4)==3) { Q_Npar2++; for(j=1;j<=nyr_cr(f);j++) { Q_Npar++; Q_parm_1(Q_Npar)=Q_parm_2(Q_Npar2); } } if(Q_setup(f,4)==4) { Q_Npar2++; for(j=2;j<=nyr_cr(f);j++) { Q_Npar++; Q_parm_1(Q_Npar)=Q_parm_2(Q_Npar2); } } } } } else { Q_parm_1=Q_parm_2; } END_CALCS !! if(Q_Npar>0 ) echoinput<<" processed Q parms "<0) { for(f=1;f<=Q_Npar;f++) { Q_parm_LO(f)=Q_parm_1(f,1); Q_parm_HI(f)=Q_parm_1(f,2); Q_parm_PH(f)=Q_parm_1(f,7); } } else {Q_parm_LO=-1.; Q_parm_HI=1.; Q_parm_PH=-4;} END_CALCS //****************************************** // ProgLabel_4.9 Define Selectivity patterns and N parameters needed per pattern ivector seltype_Nparam(0,34) LOCAL_CALCS seltype_Nparam(0)=0; // selex=1.0 for all sizes seltype_Nparam(1)=2; // logistic; with 95% width specification seltype_Nparam(2)=8; // double logistic, with defined peak seltype_Nparam(3)=6; // flat middle, power up, power down seltype_Nparam(4)=0; // set size selex=female maturity seltype_Nparam(5)=2; // mirror another selex; PARMS pick the min-max bin to mirror seltype_Nparam(6)=2; // non-parm len selex, additional parm count is in seltype(f,4) seltype_Nparam(7)=8; // New doublelogistic with smooth transitions and constant above Linf option seltype_Nparam(8)=8; // New doublelogistic with smooth transitions and constant above Linf option seltype_Nparam(9)=6; // simple 4-parm double logistic with starting length; parm 5 is first length; parm 6=1 does desc as offset seltype_Nparam(10)=0; // First age-selex selex=1.0 for all ages seltype_Nparam(11)=2; // pick min-max age seltype_Nparam(12)=2; // logistic seltype_Nparam(13)=8; // double logistic seltype_Nparam(14)=nages+1; // empirical seltype_Nparam(15)=0; // mirror another selex seltype_Nparam(16)=2; // Coleraine - Gaussian seltype_Nparam(17)=nages+1; // empirical as random walk N parameters to read can be overridden by setting special to non-zero seltype_Nparam(18)=8; // double logistic - smooth transition seltype_Nparam(19)=6; // simple 4-parm double logistic with starting age seltype_Nparam(20)=6; // double_normal,using joiners seltype_Nparam(21)=2; // non-parm len selex, additional parm count is in seltype(f,4), read as pairs of size, then selex seltype_Nparam(22)=4; // double_normal as in CASAL seltype_Nparam(23)=6; // double_normal where final value is directly equal to sp(6) so can be >1.0 seltype_Nparam(24)=6; // double_normal with sel(minL) and sel(maxL), using joiners seltype_Nparam(25)=3; // exponential-logistic in size seltype_Nparam(26)=3; // exponential-logistic in age seltype_Nparam(27)=3; // cubic spline for selex at length, additional parm count is in seltype(f,4) // seltype_Nparam(28)=3; // cubic spline for selex at age, additional parm count is in seltype(f,4) seltype_Nparam(29)=0; // undefined seltype_Nparam(30)=0; // spawning biomass seltype_Nparam(31)=0; // recruitment dev seltype_Nparam(32)=0; // pre-recruitment (spawnbio * recrdev) seltype_Nparam(33)=0; // recruitment seltype_Nparam(34)=0; // spawning biomass depletion END_CALCS // ProgLabel_4.9.1 read selectivity definitions // do 2*Ntypes to create options for size-selex (first), then age-selex init_imatrix seltype(1,2*Ntypes,1,4) // read selex type for each fleet/survey, Do_retention, Do_male !! echoinput<<" selex types "<0 && seltype(f,1)>0) { N_warn++; warning<<" Use of size selectivity not advised when reading empirical wt-at-age "<0 && seltype(f,1)<30) {dolen(f)=1;} else {dolen(f)=0;} if(seltype(f,1)==27) { ParCount++; ParmLabel+="SizeSpline_Code_"+fleetname(f)+"_"+NumLbl(f); ParCount++; ParmLabel+="SizeSpline_GradLo_"+fleetname(f)+"_"+NumLbl(f); ParCount++; ParmLabel+="SizeSpline_GradHi_"+fleetname(f)+"_"+NumLbl(f); for(s=1;s<=seltype(f,4);s++) { ParCount++; ParmLabel+="SizeSpline_Knot_"+NumLbl(s)+"_"+fleetname(f)+"_"+NumLbl(f); } for(s=1;s<=seltype(f,4);s++) { ParCount++; ParmLabel+="SizeSpline_Val_"+NumLbl(s)+"_"+fleetname(f)+"_"+NumLbl(f); } } else { for(j=1;j<=N_selparmvec(f);j++) { ParCount++; ParmLabel+="SizeSel_"+NumLbl(f)+"P_"+NumLbl(j)+"_"+fleetname(f); } } if(seltype(f,1)==34) // special code for depletion, so adjust phases and lambdas { depletion_fleet=f; } if(seltype(f,2)>=1) { if(WTage_rd>0) { N_warn++; warning<<" BEWARE: Retention functions not implemented fully when reading empirical wt-at-age "<=1) { if(gender==1) {N_warn++; cout<<"Critical error"<=3) { if(seltype(f,3)==3) {anystring="Male_";} else {anystring="Fem_";} if(seltype(f,1)==1) { N_selparmvec(f)++; ParCount++; ParmLabel+="SzSel_"+NumLbl(f)+anystring+"Infl_"+fleetname(f); N_selparmvec(f)++; ParCount++; ParmLabel+="AgeSel_"+NumLbl(f)+anystring+"Slope_"+fleetname(f); N_selparmvec(f)++; ParCount++; ParmLabel+="AgeSel_"+NumLbl(f)+anystring+"Scale_"+fleetname(f); } else if(seltype(f,1)==24) { N_selparmvec(f)++; ParCount++; ParmLabel+="SzSel_"+NumLbl(f)+anystring+"Peak_"+fleetname(f); N_selparmvec(f)++; ParCount++; ParmLabel+="SzSel_"+NumLbl(f)+anystring+"Ascend_"+fleetname(f); N_selparmvec(f)++; ParCount++; ParmLabel+="SzSel_"+NumLbl(f)+anystring+"Descend_"+fleetname(f); N_selparmvec(f)++; ParCount++; ParmLabel+="SzSel_"+NumLbl(f)+anystring+"Final_"+fleetname(f); N_selparmvec(f)++; ParCount++; ParmLabel+="SzSel_"+NumLbl(f)+anystring+"Scale_"+fleetname(f); } else { N_warn++; cout<<" EXIT - see warning "<=f-Ntypes) { N_warn++; cout<<" EXIT - see warning "<=1) { if(gender==1) {N_warn++; cout<<"Critical error"<=3 && seltype(f,1)==20) { if(seltype(f,3)==3) {anystring="Male_";} else {anystring="Fem_";} N_selparmvec(f)++; ParCount++; ParmLabel+="AgeSel_"+NumLbl(f-Ntypes)+anystring+"Peak_"+fleetname(f-Ntypes); N_selparmvec(f)++; ParCount++; ParmLabel+="AgeSel_"+NumLbl(f-Ntypes)+anystring+"Ascend_"+fleetname(f-Ntypes); N_selparmvec(f)++; ParCount++; ParmLabel+="AgeSel_"+NumLbl(f-Ntypes)+anystring+"Descend_"+fleetname(f-Ntypes); N_selparmvec(f)++; ParCount++; ParmLabel+="AgeSel_"+NumLbl(f-Ntypes)+anystring+"Final_"+fleetname(f-Ntypes); N_selparmvec(f)++; ParCount++; ParmLabel+="AgeSel_"+NumLbl(f-Ntypes)+anystring+"Scale_"+fleetname(f-Ntypes); } else { N_warn++; cout<<" EXIT - see warning "<0 && seltype(f,2)==0) {N_warn++; cout<<" EXIT - see warning "<0) { ParCount++; ParmLabel+=ParmLabel(j+firstselparm)+"_ENV_mult"; selparm_envtype(j)=1; selparm_envuse(j)=selparm_1(j,8); } else if(selparm_1(j,8)==-999) {ParCount++; ParmLabel+=ParmLabel(j+firstselparm)+"_ENV_densdep"; selparm_envtype(j)=3; MGparm_envuse(j)=-1;} else {ParCount++; ParmLabel+=ParmLabel(j+firstselparm)+"_ENV_add"; selparm_envtype(j)=2; selparm_envuse(j)=-selparm_1(j,8);} } } if(N_selparm_env>0) { *(ad_comm::global_datafile) >> customenvsetup; if(customenvsetup==0) {k1=1;} else {k1=N_selparm_env;} echoinput<0) {echoinput<<" selex-env parameters "<N_Block_Designs) {N_warn++; cout<<" EXIT - see warning "< N Blocks "<0) { g=1; for(a=1;a<=Nblk(z);a++) { N_selparm_blk++; y=Block_Design(z,g); sprintf(onenum, "%d", y); ParCount++; k=selparm_1(j,14); switch(k) { case 0: {ParmLabel+=ParmLabel(j+firstselparm)+"_BLK"+NumLbl(z)+"mult_"+onenum+CRLF(1); break;} case 1: {ParmLabel+=ParmLabel(j+firstselparm)+"_BLK"+NumLbl(z)+"add_"+onenum+CRLF(1); break;} case 2: {ParmLabel+=ParmLabel(j+firstselparm)+"_BLK"+NumLbl(z)+"repl_"+onenum+CRLF(1); break;} case 3: {ParmLabel+=ParmLabel(j+firstselparm)+"_BLK"+NumLbl(z)+"delta_"+onenum+CRLF(1); break;} } for(y=Block_Design(z,g);y<=Block_Design(z,g+1);y++) // loop years for this block { if(y<=endyr) Block_Defs_Sel(j,y)=N_selparm+N_selparm_env+N_selparm_blk; } g+=2; } } } if(N_selparm_blk>0) { *(ad_comm::global_datafile) >> customblocksetup; if(customblocksetup==0) {k1=1;} else {k1=N_selparm_blk;} echoinput<0) { echoinput<<" selex-block parameters "<0) echoinput<<" Create N selparm_trend "<0) { echoinput<<"Selex trend and cycle parameters "<0) { k1=0; k2=N_selparm+N_selparm_env+N_selparm_blk; for(j=1;j<=N_selparm;j++) { if(selparm_1(j,13)<0) // create timetrend parameter { k1++; selparm_trend_rev(k1)=j; selparm_trend_rev_1(k1)=k2; // pointer to base in list of MGparms (so k2+1 is first parameter used) if(selparm_1(j,13)>=-2) // timetrend {k2+=3;} else {k2+=Ncycle;} } } } END_CALCS // ProgLabel_4.9.7 create and label selectivity parameter annual devs int N_selparm_dev // number of selparms that use random deviations int N_selparm_dev_tot // number of selparms that use random deviations LOCAL_CALCS N_selparm_dev=0; N_selparm_dev_tot=0; for(j=1;j<=N_selparm;j++) { if(selparm_1(j,9)!=0) { N_selparm_dev++; for(y=selparm_1(j,10);y<=selparm_1(j,11);y++) { N_selparm_dev_tot++; sprintf(onenum, "%d", y); ParCount++; if(selparm_1(j,9)==1) {ParmLabel+=ParmLabel(j+firstselparm)+"_DEVmult_"+onenum+CRLF(1);} else if(selparm_1(j,9)==2) {ParmLabel+=ParmLabel(j+firstselparm)+"_DEVadd_"+onenum+CRLF(1);} else if(selparm_1(j,9)==3) {ParmLabel+=ParmLabel(j+firstselparm)+"_DEVrwalk_"+onenum+CRLF(1);} else {N_warn++; cout<<" EXIT - see warning "<0) j=N_selparm_dev; else j=1; // for defining non-zero array size END_CALCS ivector selparm_dev_minyr(1,j) ivector selparm_dev_maxyr(1,j) vector selparm_dev_stddev(1,j) ivector selparm_dev_type(1,j) ivector selparm_dev_select(1,N_selparm) number selparm_dev_PH int selparm_adjust_method // 1=do V1.xx approach to adjustment by env, block or dev; 2=use new logistic approach; 3=no check LOCAL_CALCS selparm_dev_select.initialize(); if(N_selparm_dev==0) { selparm_dev_PH=-6; echoinput<<" No selparm devs selected, so don't read selparm_dev_PH"<> selparm_dev_PH; echoinput< 0) { *(ad_comm::global_datafile) >> selparm_adjust_method; echoinput<3) { N_warn++; cout<<" EXIT - see warning "<0) { j++; selparm_dev_type(j)=selparm_1(f,9); // 1 for mult; 2 for additive; 3 for additive randwalk selparm_dev_select(f)=j; // pointer to dev vector used by this parameter selparm_dev_minyr(j)=selparm_1(f,10); selparm_dev_maxyr(j)=selparm_1(f,11); selparm_dev_stddev(j)=selparm_1(f,12); if(selparm_dev_type(j)==2 && selparm_dev_stddev(j)<0.10*selparm_1(f,3)) {N_warn++; warning<<" selparm_dev_stddev is small (<10% of parm value) for selparm: "<endyr) {N_warn++; cout<<" EXIT - see warning "<= midsize bin 2 ("<len_bins_m(nlength-1)) {N_warn++; warning<<"Fleet:_"<0) time_vary_sel(endyr+1)=1; time_vary_sel(endyr+1)=1; time_vary_makefishsel(styr)=1; time_vary_makefishsel(styr-3)=1; // if(Do_Forecast>0) time_vary_makefishsel(endyr+1)=1; time_vary_makefishsel(endyr+1)=1; for(y=styr+1;y<=endyr;y++) { z=0; // parameter counter within this section for (f=1;f<=2*Ntypes;f++) { if(seltype(f,1)==5 || seltype(f,1)==15) // mirror { if(f<=Ntypes) {time_vary_sel(y,f)=time_vary_sel(y,seltype(f,4));} else {time_vary_sel(y,f)=time_vary_sel(y,seltype(f,4)+Ntypes);} z+=seltype_Nparam(seltype(f,1)); } else { if(seltype_Nparam(seltype(f,1))>0 || (seltype(f,2)==1) || (seltype(f,2)==2)) // type has parms, so look for adjustments { for(j=1;j<=N_selparmvec(f);j++) { z++; if(selparm_envuse(z)!=0) // env linkage { if((env_data_RD(y,selparm_envuse(z))!=env_data_RD(y-1,selparm_envuse(z)) || selparm_envtype(z)==3 )) time_vary_sel(y,f)=1; } if(selparm_1(z,9)>=1) // dev vector { s=selparm_1(z,11)+1; if(s>endyr) s=endyr; if(y>=selparm_1(z,10) && y<=s) time_vary_sel(y,f)=1; } if(selparm_1(z,13)>0) // blocks { if(Block_Defs_Sel(z,y)!=Block_Defs_Sel(z,y-1) ) time_vary_sel(y,f)=1; } if(selparm_1(z,13)<0) // trend { time_vary_sel(y,f)=1; } } } } if(f<=Ntypes && seltype(f,2)<0) // retention is being mirrored { k=-seltype(f,2); if(time_vary_sel(y,k)>0) time_vary_sel(y,f)=1; } } // end type // time_vary_makefishsel(y)(1,Nfleet)=time_vary_sel(y)(1,Nfleet); // error, this will only do size selex for(f=1;f<=Nfleet;f++) { if(time_vary_sel(y,f)>0 || time_vary_sel(y,f+Ntypes)>0) time_vary_makefishsel(y,f)=1; } if(time_vary_MG(y,2)>0 || time_vary_MG(y,3)>0 || WTage_rd>0) { time_vary_makefishsel(y)=1; } } // end years // ProgLabel_4.9.12 create vectors, e.g. selparm_PH(), that will be used to create actual array of estimted parameters for (f=1;f<=N_selparm;f++) { selparm_LO(f)=selparm_1(f,1); selparm_HI(f)=selparm_1(f,2); selparm_RD(f)=selparm_1(f,3); selparm_PR(f)=selparm_1(f,4); selparm_PRtype(f)=selparm_1(f,5); selparm_CV(f)=selparm_1(f,6); selparm_PH(f)=selparm_1(f,7); } j=N_selparm; if(N_selparm_env>0) for (f=1;f<=N_selparm_env;f++) { j++; if(customenvsetup==0) k=1; else k=f; selparm_LO(j)=selparm_env_1(k,1); selparm_HI(j)=selparm_env_1(k,2); selparm_RD(j)=selparm_env_1(k,3); selparm_PR(j)=selparm_env_1(k,4); selparm_PRtype(j)=selparm_env_1(k,5); selparm_CV(j)=selparm_env_1(k,6); selparm_PH(j)=selparm_env_1(k,7); } if(N_selparm_blk>0) for (f=1;f<=N_selparm_blk;f++) { j++; if(customblocksetup==0) k=1; else k=f; selparm_LO(j)=selparm_blk_1(k,1); selparm_HI(j)=selparm_blk_1(k,2); selparm_RD(j)=selparm_blk_1(k,3); selparm_PR(j)=selparm_blk_1(k,4); selparm_PRtype(j)=selparm_blk_1(k,5); selparm_CV(j)=selparm_blk_1(k,6); selparm_PH(j)=selparm_blk_1(k,7); } if(N_selparm_trend>0) for (f=1;f<=N_selparm_trend2;f++) { j++; selparm_LO(j)=selparm_trend_1(f,1); selparm_HI(j)=selparm_trend_1(f,2); selparm_RD(j)=selparm_trend_1(f,3); selparm_PR(j)=selparm_trend_1(f,4); selparm_PRtype(j)=selparm_trend_1(f,5); selparm_CV(j)=selparm_trend_1(f,6); selparm_PH(j)=selparm_trend_1(f,7); } END_CALCS // ProgLabel_4.10 Read tag recapture parameter setup // if Tags are used, the read parameters for initial tag loss, chronic tag loss, andd // fleet-specific tag reporting. Of these, only reporting rate will be allowed to be time-varying init_int TG_custom; // 1=read; 0=create default parameters !! echoinput<0) echoinput<<" Tag parameters as read "<0) {k1=k;} else {k1=1;} vector TG_parm_LO(1,k1); vector TG_parm_HI(1,k1); ivector TG_parm_PH(1,k1); LOCAL_CALCS if(Do_TG>0) { if(TG_custom==1) { TG_parm2=TG_parm1; // assign to the read values } else { TG_parm2.initialize(); onenum=" "; for(j=1;j<=N_TG;j++) { TG_parm2(j,1)=-10; // min TG_parm2(j,2)=10; // max TG_parm2(j,3)=-9.; // init TG_parm2(j,4)=-9.; // prior TG_parm2(j,5)=1.; // default prior type is symmetric beta TG_parm2(j,6)=0.001; // prior is quite diffuse TG_parm2(j,7)=-4; // phase } for(j=1;j<=N_TG;j++) { TG_parm2(j+N_TG)=TG_parm2(1); // set chronic tag retention equal to initial tag_retention } for(j=1;j<=N_TG;j++) // set overdispersion { TG_parm2(j+2*N_TG,1)=1; // min TG_parm2(j+2*N_TG,2)=10; // max TG_parm2(j+2*N_TG,3)=2.; // init TG_parm2(j+2*N_TG,4)=2.; // prior TG_parm2(j+2*N_TG,5)=1.; // default prior type is symmetric beta TG_parm2(j+2*N_TG,6)=0.001; // prior is quite diffuse TG_parm2(j+2*N_TG,7)=-4; // phase } for(j=1;j<=Nfleet;j++) { TG_parm2(j+3*N_TG)=TG_parm2(1); // set tag reporting equal to near 1.0, as is the tag retention parameters } // set tag reporting decay to nil decay rate for(j=1;j<=Nfleet;j++) { k=j+3*N_TG+Nfleet; TG_parm2(k,1)=-4.; TG_parm2(k,2)=0.; TG_parm2(k,3)=0.; TG_parm2(k,4)=0.; // prior of zero TG_parm2(k,5)=0.; // default prior is squared dev TG_parm2(k,6)=2.; // sd dev of prior TG_parm2(k,7)=-4.; } } // ProgLabel_4.10.1 create parameter count and parameter names for tag parameters onenum=" "; for(j=1;j<=N_TG;j++) { sprintf(onenum, "%d", j); ParCount++; ParmLabel+="TG_loss_init_"+onenum+CRLF(1); } for(j=1;j<=N_TG;j++) { sprintf(onenum, "%d", j); ParCount++; ParmLabel+="TG_loss_chronic_"+onenum+CRLF(1); } for(j=1;j<=N_TG;j++) { sprintf(onenum, "%d", j); ParCount++; ParmLabel+="TG_overdispersion_"+onenum+CRLF(1); } for(j=1;j<=Nfleet;j++) { sprintf(onenum, "%d", j); ParCount++; ParmLabel+="TG_report_fleet:_"+onenum+CRLF(1); } for(j=1;j<=Nfleet;j++) { sprintf(onenum, "%d", j); ParCount++; ParmLabel+="TG_rpt_decay_fleet:_"+onenum+CRLF(1); } TG_parm_LO=column(TG_parm2,1); TG_parm_HI=column(TG_parm2,2); k=3*N_TG+2*Nfleet; for(j=1;j<=k;j++) TG_parm_PH(j)=TG_parm2(j,7); // write it out due to no typecast available echoinput<<" Processed/generated Tag parameters "<0) { var_adjust=var_adjust1; echoinput<<" Varadjustments as read "<0 && max_lambda_phase<2) { max_lambda_phase=2; N_warn++; warning<<"Increase max_lambda_phase to 2 because depletion fleet is being used"<0) echoinput<<" lambda changes "<0) { for(f=1;f<=Ntypes;f++) { surv_lambda(f,1)=0.0; disc_lambda(f,1)=0.0; mnwt_lambda(f,1)=0.0; length_lambda(f,1)=0.0; age_lambda(f,1)=0.0; sizeage_lambda(f,1)=0.0; // catch_lambda(f,1)=0.0; // keep this positive to prevent crashes from bad fit to catch } if(SzFreq_Nmeth>0) { for(z=1;z<=SzFreq_N_Like;z++) {SzFreq_lambda(z,1)=0.0;} } if(N_TG2>0) { for(z=1;z<=N_TG2;z++) { TG_lambda1(z,1)=0.0; TG_lambda2(z,1)=0.0; } } init_equ_lambda(1)=0.0; recrdev_lambda(1)=0.0; Morphcomp_lambda(1)=0.0; F_ballpark_lambda(1)=0.0; surv_lambda(depletion_fleet,1)=1.0; } N_changed_lambdas=0; for(j=1;j<=N_lambda_changes;j++) { k=Lambda_changes(j,1); // like component f=Lambda_changes(j,2); // fleet s=Lambda_changes(j,3); // phase if(k<=14) { if(f>Ntypes) { k=0; N_warn++; warning<<" illegal fleet/survey for lambda change at row: "< Ntypes"<N_TG2) { k=0; N_warn++; warning<<" illegal tag group for lambda change at row: "< N_taggroups"<17) { k=0; N_warn++; warning<<" illegal lambda_type for lambda change at row: "< 17"<max_lambda_phase) {k=0; N_warn++; warning<<" illegal request for lambda change at row: "< max_lam_phase: "<Turn_off_phase) s=max(1,Turn_off_phase); temp=Lambda_changes(j,4); // value if(temp!=0.0 && temp!=1.0) N_changed_lambdas++; z=Lambda_changes(j,5); // special for sizefreq switch(k) { case 0: // do nothing {break;} case 1: // survey {surv_lambda(f)(s,max_lambda_phase)=temp; break;} case 2: // discard {disc_lambda(f)(s,max_lambda_phase)=temp; break;} case 3: // meanbodywt {mnwt_lambda(f)(s,max_lambda_phase)=temp; break;} case 4: // lengthcomp {length_lambda(f)(s,max_lambda_phase)=temp; break;} case 5: // agecomp {age_lambda(f)(s,max_lambda_phase)=temp; break;} case 6: // sizefreq comp { z=Lambda_changes(j,5); // sizefreq method if(z>SzFreq_Nmeth) {N_warn++; cout<<" EXIT - see warning "< Nmeth "<0) {echoinput<0) echoinput<0) echoinput<0) echoinput<0) { if(Selex_Std_Pick(1)<=0) // then self-generate even bin selection { if(Selex_Std_AL==1) { j=nlength/(Selex_Std_Cnt-1); Selex_Std_Pick(1)=j/2; for(i=2;i<=Selex_Std_Cnt-1;i++) Selex_Std_Pick(i)=Selex_Std_Pick(i-1)+j; Selex_Std_Pick(Selex_Std_Cnt)=nlength; } else { j=nages/(Selex_Std_Cnt-1); Selex_Std_Pick(1)=j/2; for(i=2;i<=Selex_Std_Cnt-1;i++) Selex_Std_Pick(i)=Selex_Std_Pick(i-1)+j; Selex_Std_Pick(Selex_Std_Cnt)=nages; } } Extra_Std_N=gender*Selex_Std_Cnt; } if(Do_Growth_Std>0) { if(Growth_Std_Pick(1)<=0) { Growth_Std_Pick(1)=AFIX; Growth_Std_Pick(Growth_Std_Cnt)=nages; if(Growth_Std_Cnt>2) { k=Growth_Std_Cnt/2; for(i=2;i<=k;i++) Growth_Std_Pick(i)=Growth_Std_Pick(i-1)+1; j=(nages-Growth_Std_Pick(k))/(Growth_Std_Cnt-k); for(i=k+1;i<=Growth_Std_Cnt-1;i++) Growth_Std_Pick(i)=Growth_Std_Pick(i-1)+j; } } } Extra_Std_N+=gender*Growth_Std_Cnt; if(Do_NatAge_Std!=0) { if(NatAge_Std_Pick(1)<=0) { NatAge_Std_Pick(1)=1; NatAge_Std_Pick(NatAge_Std_Cnt)=nages; if(NatAge_Std_Cnt>2) { k=NatAge_Std_Cnt/2; for(i=2;i<=k;i++) NatAge_Std_Pick(i)=NatAge_Std_Pick(i-1)+1; j=(nages-NatAge_Std_Pick(k))/(NatAge_Std_Cnt-k); for(i=k+1;i<=NatAge_Std_Cnt-1;i++) NatAge_Std_Pick(i)=NatAge_Std_Pick(i-1)+j; } } } Extra_Std_N+=gender*NatAge_Std_Cnt; if(Extra_Std_N==0) Extra_Std_N=1; // assign a minimum length to dimension the sdreport vector Selex_Std echoinput<<"After processing"<0) echoinput<0) echoinput<0) echoinput<0) { N_STD_Mgmt_Quant=16; } else {N_STD_Mgmt_Quant=1;} Fcast_catch_start=N_STD_Mgmt_Quant; if(Do_Forecast>0) {N_STD_Mgmt_Quant+=N_Fcast_Yrs*(1+Do_Retain)+N_Fcast_Yrs;} k=ParCount+2*N_STD_Yr+N_STD_Yr_Dep+N_STD_Yr_Ofish+N_STD_Yr_F+N_STD_Mgmt_Quant+gender*Selex_Std_Cnt+gender*Growth_Std_Cnt; echoinput<<"N parameters: "<0 && MGparm_PH(k)>0) MGparm_PH(k)++; // add 1 to phase if using depletion fleet if(MGparm_PH(k) > Turn_off_phase) MGparm_PH(k) =-1; if(MGparm_PH(k) > max_phase) max_phase=MGparm_PH(k); if(MGparm_PH(k)>=0) { active_count++; active_parm(active_count)=ParCount; } } if(depletion_fleet>0 && MGparm_dev_PH>0) MGparm_dev_PH++; // add 1 to phase if using depletion fleet if(MGparm_dev_PH>Turn_off_phase) MGparm_dev_PH =-1; if(MGparm_dev_PH>max_phase) max_phase=MGparm_dev_PH; for(k=1;k<=N_MGparm_dev_tot;k++) { ParCount++; if(MGparm_dev_PH>=0) { active_count++; active_parm(active_count)=ParCount; } } for(j=1;j<=SRvec_PH.indexmax();j++) { ParCount++; if(SRvec_PH(j)==-9999) {SR_parm_1(j,3)=prof_var(prof_var_cnt); prof_var_cnt+=1;} if(depletion_fleet>0 && SRvec_PH(j)>0) SRvec_PH(j)++; // add 1 to phase if using depletion fleet if(depletion_fleet>0 && j==1) SRvec_PH(1)=1; // if(SRvec_PH(j) > Turn_off_phase) SRvec_PH(j) =-1; if(SRvec_PH(j) > max_phase) max_phase=SRvec_PH(j); if(SRvec_PH(j)>=0) { active_count++; active_parm(active_count)=ParCount; } } if(recdev_cycle>0) { for(y=1;y<=recdev_cycle;y++) { ParCount++; recdev_cycle_LO(y)=recdev_cycle_parm_RD(y,1); recdev_cycle_HI(y)=recdev_cycle_parm_RD(y,2); recdev_cycle_PH(y)=recdev_cycle_parm_RD(y,7); if(depletion_fleet>0 && recdev_cycle_PH(y)>0) recdev_cycle_PH(y)++; // add 1 to phase if using depletion fleet if(recdev_cycle_PH(y) > Turn_off_phase) recdev_cycle_PH(y) =-1; if(recdev_cycle_PH(y) > max_phase) max_phase=recdev_cycle_PH(y); if(recdev_cycle_PH(y)>=0) {active_count++; active_parm(active_count)=ParCount;} } } if(depletion_fleet>0 && recdev_early_PH>0) recdev_early_PH++; // add 1 to phase if using depletion fleet if(recdev_early_PH > Turn_off_phase) recdev_early_PH =-1; if(recdev_early_PH > max_phase) max_phase=recdev_early_PH; if(recdev_do_early>0) { for(y=recdev_early_start;y<=recdev_early_end;y++) { ParCount++; if(recdev_early_PH>=0) {active_count++; active_parm(active_count)=ParCount;} } } if(depletion_fleet>0 && recdev_PH>0) recdev_PH++; // add 1 to phase if using depletion fleet if(recdev_PH > Turn_off_phase) recdev_PH =-1; if(recdev_PH > max_phase) max_phase=recdev_PH; if(do_recdev>0) { for(y=recdev_start;y<=recdev_end;y++) { ParCount++; if(recdev_PH>=0) {active_count++; active_parm(active_count)=ParCount;} } } Fcast_recr_PH2=max_phase+1; if(Do_Forecast>0) { if(Turn_off_phase>0) { if(Fcast_recr_PH!=0) // read value for forecast_PH { Fcast_recr_PH2=Fcast_recr_PH; if(depletion_fleet>0 && Fcast_recr_PH2>0) Fcast_recr_PH2++; if(Fcast_recr_PH2 > Turn_off_phase) Fcast_recr_PH2 =-1; if(Fcast_recr_PH2 > max_phase) max_phase=Fcast_recr_PH2; } for(y=recdev_end+1;y<=YrMax;y++) { ParCount++; if(Fcast_recr_PH2>-1) {active_count++; active_parm(active_count)=ParCount;} } } else { Fcast_recr_PH2=-1; } for(y=endyr+1;y<=YrMax;y++) { ParCount++; if(Do_Impl_Error>0 && Fcast_recr_PH2>-1) {active_count++; active_parm(active_count)=ParCount;} } } else {Fcast_recr_PH2=-1;} for(f=1;f<=Nfleet;f++) { ParCount++; if(init_F_PH(f)==-9999) {init_F_parm_1(f,3)=prof_var(prof_var_cnt); init_F_RD(f)=init_F_parm_1(f,3); prof_var_cnt++;} if(depletion_fleet>0 && init_F_PH(f)>0) init_F_PH(f)++; if(init_F_PH(f) > Turn_off_phase) init_F_PH(f) =-1; if(init_F_PH(f) > max_phase) max_phase=init_F_PH(f); if(init_F_PH(f)>=0) { active_count++; active_parm(active_count)=ParCount; } } if(F_Method==2) { for(g=1;g<=Nfleet*(TimeMax-styr+1);g++) { ParCount++; if(depletion_fleet>0 && have_catch(g)>0) have_catch(g)++; if(have_catch(g) > Turn_off_phase) have_catch(g) =-1; if(have_catch(g) > max_phase) max_phase=have_catch(g); if(have_catch(g)>=0) { active_count++; active_parm(active_count)=ParCount; } } } for(f=1;f<=Q_Npar;f++) { ParCount++; if(Q_parm_PH(f)==-9999) {Q_parm_1(f,3)=prof_var(prof_var_cnt); prof_var_cnt++;} if(depletion_fleet>0 && Q_parm_PH(f)>0) Q_parm_PH(f)++; if(Q_parm_PH(f) > Turn_off_phase) Q_parm_PH(f) =-1; if(Q_parm_PH(f) > max_phase) max_phase=Q_parm_PH(f); if(Q_parm_PH(f)>=0) { active_count++; active_parm(active_count)=ParCount; } } // ProgLabel_4.14.1.1 Auto-generate cubic spline setup while inside this parameter counting loop Ip=0; int N_knots; for (f=1;f<=2*Ntypes;f++) // check for cubic spline setup { if(f<=Ntypes) {fs=f;} else {fs=f-Ntypes;} if(seltype(f,1)==27) // reset the cubic spline knots for size or age comp { k=int(selparm_RD(Ip+1)); // setup method N_knots=seltype(f,4); // number of knots if(k==0) {} // do nothing else if(k==1 || k==2) // get new knots according to cumulative distribution of data { echoinput<<"Adjust the cubic_spline setup for fleet: "<=3) { temp=0.025; temp1=0.950/float(N_knots-1); // increment } else { N_warn++; cout<<" EXIT - see warning "<1) {selparm_RD(Ip+s)=len_bins_dat(z-1)+(temp-obs_l_all(2,f,z-1))/(obs_l_all(2,f,z)-obs_l_all(2,f,z-1))*(len_bins_dat(z)-len_bins_dat(z-1));} else {selparm_RD(Ip+s)=len_bins_dat(z);} s++; temp+=temp1; } echoinput<<"len_bins_dat: "<1) {selparm_RD(Ip+s)=age_bins(z-1)+(temp-obs_a_all(2,fs,z-1))/(obs_a_all(2,fs,z)-obs_a_all(2,fs,z-1))*(age_bins(z)-age_bins(z-1));} else {selparm_RD(Ip+s)=age_bins(z);} s++; temp+=temp1; } echoinput<<"age_bins: "<=3) { selparm_RD(p)=-0.001; // small negative gradient at top selparm_PR(p)=0.; selparm_PRtype(p)=1; selparm_CV(p)=0.001; selparm_PH(p)=3; } else { selparm_RD(p)=0.00; selparm_PR(p)=0.; selparm_PRtype(p)=-1; selparm_CV(p)=0.; selparm_PH(p)=-99; } for(z=Ip+1;z<=Ip+3+2*N_knots;z++) { selparm_1(z,1)=selparm_LO(z); selparm_1(z,2)=selparm_HI(z); selparm_1(z,3)=selparm_RD(z); selparm_1(z,4)=selparm_PR(z); selparm_1(z,5)=selparm_PRtype(z); selparm_1(z,6)=selparm_CV(z); selparm_1(z,7)=selparm_PH(z); } } } } Ip+=N_selparmvec(f); } for(k=1;k<=selparm_PH.indexmax();k++) { ParCount++; if(selparm_PH(k)==-9999) {selparm_RD(k)=prof_var(prof_var_cnt); prof_var_cnt++;} if(depletion_fleet>0 && selparm_PH(k)>0) selparm_PH(k)++; if(selparm_PH(k) > Turn_off_phase) selparm_PH(k) =-1; if(selparm_PH(k) > max_phase) max_phase=selparm_PH(k); if(selparm_PH(k)>=0) { active_count++; active_parm(active_count)=ParCount; } } if(depletion_fleet>0 && selparm_dev_PH>0) selparm_dev_PH++; if(selparm_dev_PH > Turn_off_phase) selparm_dev_PH =-1; if(selparm_dev_PH > max_phase) max_phase=selparm_dev_PH; for(k=1;k<=N_selparm_dev_tot;k++) { ParCount++; if(selparm_dev_PH>=0) { active_count++; active_parm(active_count)=ParCount; } } if(Do_TG>0) { for(k=1;k<=3*N_TG+2*Nfleet;k++) { ParCount++; if(depletion_fleet>0 && TG_parm_PH(k)>0) TG_parm_PH(k)++; if(TG_parm_PH(k) > Turn_off_phase) TG_parm_PH(k) =-1; if(TG_parm_PH(k) > max_phase) max_phase=TG_parm_PH(k); if(TG_parm_PH(k)>=0) { active_count++; active_parm(active_count)=ParCount; } } } if(Do_Forecast>0 && Turn_off_phase>0) { if(Fcast_recr_PH==0) // read value for forecast_PH. This code is repeats earlier code in case other parameters have changed maxphase { Fcast_recr_PH2=max_phase+1; } } echoinput<<"Active parameters: "<0) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; if(y==styr-2) {ParmLabel+="SPB_Virgin";} else if(y==styr-1) {ParmLabel+="SPB_Initial";} else { // _itoa(y,onenum,10); sprintf(onenum, "%d", y); ParmLabel+="SPB_"+onenum+CRLF(1); } } } for(y=styr-2;y<=YrMax;y++) { if(STD_Yr_Reverse(y)>0) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; if(y==styr-2) {ParmLabel+="Recr_Virgin"; } else if(y==styr-1) {ParmLabel+="Recr_Initial"; } else { // _itoa(y,onenum,10); sprintf(onenum, "%d", y); ParmLabel+="Recr_"+onenum+CRLF(1); } } } for(y=styr;y<=YrMax;y++) { if(STD_Yr_Reverse_Ofish(y)>0) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; // _itoa(y,onenum,10); sprintf(onenum, "%d", y); ParmLabel+="SPRratio_"+onenum+CRLF(1); } } //F_std for(y=styr;y<=YrMax;y++) { if(STD_Yr_Reverse_F(y)>0) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; // _itoa(y,onenum,10); sprintf(onenum, "%d", y); ParmLabel+="F_"+onenum+CRLF(1); } } for(y=styr;y<=YrMax;y++) { if(STD_Yr_Reverse_Dep(y)>0) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; // _itoa(y,onenum,10); sprintf(onenum, "%d", y); ParmLabel+="Bratio_"+onenum+CRLF(1); } } // create labels for Mgmt_Quant if(Do_Benchmark>0) { ParmLabel+="SSB_Unfished"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="TotBio_Unfished"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="SmryBio_Unfished"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="Recr_Unfished"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="SSB_Btgt"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="SPR_Btgt"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="Fstd_Btgt"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="TotYield_Btgt"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="SSB_SPRtgt"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="Fstd_SPRtgt"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="TotYield_SPRtgt"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="SSB_MSY"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="SPR_MSY"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="Fstd_MSY"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="TotYield_MSY"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="RetYield_MSY"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; } else { ParmLabel+="Bzero_again"+CRLF(1); CoVar_Count++; j++; active_parm(CoVar_Count)=j; } if(Do_Forecast>0) { for(y=endyr+1;y<=YrMax;y++) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; sprintf(onenum, "%d", y); ParmLabel+="ForeCatch_"+onenum+CRLF(1); } for(y=endyr+1;y<=YrMax;y++) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; sprintf(onenum, "%d", y); ParmLabel+="OFLCatch_"+onenum+CRLF(1); } if(Do_Retain==1) { for(y=endyr+1;y<=YrMax;y++) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; sprintf(onenum, "%d", y); ParmLabel+="ForeCatchret_"+onenum+CRLF(1); } } } // do labels for Selex_Std if(Do_Selex_Std>0) { for(g=1;g<=gender;g++) for(i=1;i<=Selex_Std_Cnt;i++) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; if(Selex_Std_AL==1) { if(Selex_Std_Pick(i)>nlength) { N_warn++; cout<<" EXIT - see warning "< "<nages) { N_warn++; cout<<" EXIT - see warning "< "<0) { for(g=1;g<=gender;g++) for(i=1;i<=Growth_Std_Cnt;i++) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="Grow_std_"+NumLbl(Do_Growth_Std)+"_"+GenderLbl(g)+"_A_"+NumLbl(age_vector(Growth_Std_Pick(i)))+CRLF(1); } } if(Do_NatAge_Std!=0) { for(g=1;g<=gender;g++) for(i=1;i<=NatAge_Std_Cnt;i++) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; if(Do_NatAge_Std>0) {ParmLabel+="NatAge_std_"+NumLbl(Do_NatAge_Std)+"_"+GenderLbl(g)+"_A_"+NumLbl(age_vector(NatAge_Std_Pick(i)))+CRLF(1);} else {ParmLabel+="NatAge_std_All_"+GenderLbl(g)+"_A_"+NumLbl(age_vector(NatAge_Std_Pick(i)))+CRLF(1);} } } if(Do_Selex_Std==0 && Do_Growth_Std==0 && Do_NatAge_Std==0) { CoVar_Count++; j++; active_parm(CoVar_Count)=j; ParmLabel+="Bzero_again"+CRLF(1); } sprintf(onenum, "%d", int(100*depletion_level)); switch(depletion_basis) { case 0: { depletion_basis_label+="no_depletion_basis"; break; } case 1: { depletion_basis_label+=" "+onenum+"%*Virgin_Biomass"; break; } case 2: { depletion_basis_label+=" "+onenum+"%*B_MSY"; break; } case 3: { depletion_basis_label+=" "+onenum+"%*StartYr_Biomass"; break; } } switch (SPR_reporting) { case 0: // keep as raw value { SPR_report_label+=" raw_SPR"; break; } case 1: // compare to SPR { sprintf(onenum, "%d", int(100.*SPR_target)); SPR_report_label+=" (1-SPR)/(1-SPR_"+onenum+"%)"; break; } case 2: // compare to SPR_MSY { SPR_report_label+=" (1-SPR)/(1-SPR_MSY)"; break; } case 3: // compare to SPR_Btarget { sprintf(onenum, "%d", int(100.*BTGT_target)); SPR_report_label+=" (1-SPR)/(1-SPR_at_B"+onenum+"%)"; break; } case 4: { SPR_report_label+=" 1-SPR"; break; } } switch (F_report_basis) { case 0: // raw { F_report_label="_abs_F"; break; } case 1: { sprintf(onenum, "%d", int(100.*SPR_target)); F_report_label="(F)/(F"+onenum+"%SPR)"; break; } case 2: { F_report_label="(F)/(Fmsy)"; break; } case 3: { sprintf(onenum, "%d", int(100.*BTGT_target)); F_report_label="(F)/(F_at_B"+onenum+"%)"; break; } } switch (F_reporting) { case 0: // keep as raw value { F_report_label+=";_no_F_report"; break; } case 1: // exploitation rate in biomass { F_report_label+=";_with_F=Exploit(bio)"; break; } case 2: // exploitation rate in numbers { F_report_label+=";_with_F=Exploit(num)"; break; } case 3: // sum of F mults { F_report_label+=";_with_F=sum(full_Fs)"; break; } case 4: // F=Z-M for specified ages { F_report_label+=";_with_F=Z-M;_for_ages_"; sprintf(onenum, "%d", int(F_reporting_ages(1))); F_report_label+=onenum; sprintf(onenum, "%d", int(F_reporting_ages(2))); F_report_label+="_"+onenum; break; } } echoinput<<"Active parameters plus derived quantities: "<0) { ad_comm::change_datafile_name("wtatage.ss"); k1=2; } else { k1=0; N_WTage_rd=0; N_WTage_maxage=0; } END_CALCS init_vector junkvec(1,k1) LOCAL_CALCS if(k1>0) { echoinput<<"WT-at-age input"< 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 LOCAL_CALCS if(k1>0) { echoinput<<"Wt_age input"<nages) N_WTage_maxage=nages; // so extra ages being read will be ignored for(i=1;i<=N_WTage_rd;i++) { y=abs(WTage_in(i,1)); if(y0) { for(s=0;s<=nseas-1;s++) { junkvec2.initialize(); for(t=Bmark_t(1);t<=Bmark_t(2);t+=nseas) {junkvec2+=WTage_emp(t,GP3(g),f);} WTage_emp(styr-3*nseas+s,GP3(g),f)=junkvec2/temp; } } } } END_CALCS //**************************************** // INITIALIZATION_SECTION (not used in SS) INITIALIZATION_SECTION // ProgLabel_5.0 PARAMETER_SECTION PARAMETER_SECTION // ProgLabel_5.0.1 setup convergence critera and max func evaluations LOCAL_CALCS if(readparfile>=1) {cout<<" read parm file"<0) {SR_autocorr=1;} else {SR_autocorr=0;} // flag for recruitment autocorrelation if(SR_parm_1(N_SRparm2,3)!=0.0 || SR_parm_1(N_SRparm2,7)>0) {SR_autocorr=1;} else {SR_autocorr=0;} // flag for recruitment autocorrelation echoinput<<" Do recruitment_autocorr: "<0) // {k=max_phase+1;} {k=Fcast_recr_PH2;} else {k=-1;} END_CALCS init_bounded_vector Fcast_impl_error(endyr+1,YrMax,-1,1,k) number SPB_current; // Spawning biomass number SPB_vir_LH number Recr_virgin number SPB_virgin number SPR_unf number SPR_trial // vector S1(0,1); 3darray SPB_pop_gp(styr-3,YrMax,1,pop,1,N_GP) //Spawni Output vector SPB_yr(styr-3,YrMax) vector SPB_B_yr(styr-3,YrMax) // mature biomass (no fecundity) vector SPB_N_yr(styr-3,YrMax) // mature numbers number equ_mat_bio number equ_mat_num !!k=0; !!if(Hermaphro_Option>0) k=1; 3darray MaleSPB(styr-3,YrMax*k,1,pop,1,N_GP) //Male Spawning biomass matrix SPB_equil_pop_gp(1,pop,1,N_GP); matrix MaleSPB_equil_pop_gp(1,pop,1,N_GP); number SPB_equil; number SPR_temp; // used to pass quantity into Equil_SpawnRecr number Recruits; // Age0 Recruits matrix Recr(1,pop,styr-3,YrMax) //Recruitment matrix exp_rec(styr-3,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) vector agetemp(0,gender*nages+gender-1) 4darray Save_PopLen(styr-3*nseas,TimeMax_Fcast_std+1,1,2*pop,1,gmorph,1,nlength) 4darray Save_PopWt(styr-3*nseas,TimeMax_Fcast_std+1,1,2*pop,1,gmorph,1,nlength) 4darray Save_PopAge(styr-3*nseas,TimeMax_Fcast_std+1,1,2*pop,1,gmorph,0,nages) number ave_age // average age of fish in unfished population; used to weight R1 // ProgLabel_5.1.3 create F parameters and associated arrays and constants init_bounded_number_vector init_F(1,Nfleet,init_F_LO,init_F_HI,init_F_PH) vector est_equ_catch(1,Nfleet) !!if(Do_Forecast>0) {k=TimeMax_Fcast_std+1;} else {k=TimeMax+nseas;} 4darray natage(styr-3*nseas,k,1,pop,1,gmorph,0,nages) // add +1 year 4darray catage(styr-nseas,TimeMax,1,Nfleet,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 Hrate(1,Nfleet,styr-3*nseas,k) //Harvest Rate for each fleet 3darray catch_fleet(styr-3*nseas,TimeMax_Fcast_std,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,YrMax,1,6) // same six as above matrix annual_F(styr,YrMax,1,2) // 1=sum of hrate (if Pope fmethod) or sum hrate*seasdur if F; 2=Z-M for selected ages matrix equ_catch_fleet(1,Nfleet,1,6) 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) 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 birthseason) number catch_mnage; // mean age of the catch (not accounting for birthseason or season of the catch) number catch_mnage_d; // total catch numbers for calc of mean age number harvest_rate; // Harvest rate number maxpossF; vector Get_EquilCalc(1,2); 4darray Z_rate(styr-3*nseas,k,1,pop,1,gmorph,0,nages) 3darray Zrate2(1,pop,1,gmorph,0,nages) LOCAL_CALCS if(F_Method==2) // continuous F {k=Nfleet*(TimeMax-styr+1);} else {k=-1;} END_CALCS init_bounded_number_vector F_rate(1,k,0.,F_rate_max,have_catch) vector Nmigr(1,pop); number Nsurvive; number YPR_tgt_enc; number YPR_tgt_dead; number YPR_tgt_N_dead; number YPR_tgt_ret; number YPR_spr; number Vbio_spr; number Vbio1_spr; number SPR_actual; number YPR_Btgt_enc; number YPR_Btgt_dead; number YPR_Btgt_N_dead; number YPR_Btgt_ret; number YPR_Btgt; number Vbio_Btgt; number Vbio1_Btgt; number Btgt; number Btgttgt; number SPR_Btgt; number Btgt_Rec; number Bspr; number Bspr_rec; number YPR // variable still used in SPR series 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_enc; number YPR_dead; number YPR_N_dead; number YPR_ret; number MSY_Fmult; number SPR_Fmult; number Btgt_Fmult; 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); number alpha; number beta; number MSY_SPR; number GenTime; vector cumF(1,gmorph); vector maxF(1,gmorph); number Yield; number Adj4010; // !!k1 = styr+(endyr-styr)*nseas-1 + nseas + 1; // !!y=k1+N_Fcast_Yrs*nseas-1; // ProgLabel_5.1.4 create Q_parm and associated arrays init_bounded_number_vector Q_parm(1,Q_Npar,Q_parm_LO,Q_parm_HI,Q_parm_PH) matrix log_q_cr(1,Ntypes,1,nyr_cr); matrix q_cr(1,Ntypes,1,nyr_cr); matrix se_cr_use(1,Ntypes,1,nyr_cr) matrix exp_cr(1,Ntypes,1,nyr_cr) // will store expected survey vector surv_like(1,Ntypes) // likelihood of the indices matrix Q_dev_like(1,Ntypes,1,2) // likelihood of the Q deviations vector disc_like(1,Ntypes) // likelihood of the discard biomass vector mnwt_like(1,Ntypes) // likelihood of the mean body wt matrix exp_disc(1,Ntypes,1,nyr_disc) 3darray retain(styr-3,endyr+1,1,Ntypes,1,nlength2) vector retain_M(1,nlength) 3darray discmort(styr-3,endyr+1,1,Ntypes,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); // ProgLabel_5.1.5 Selectivity-related parameters init_bounded_number_vector selparm(1,N_selparm2,selparm_LO,selparm_HI,selparm_PH) matrix selparm_trend(1,N_selparm_trend,styr,endyr); matrix selparm_block_val(1,N_selparm,styr,endyr); 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) 4darray sel_l(styr-3,endyr+1,1,Ntypes,1,gender,1,nlength) 4darray sel_l_r(styr-3,endyr+1,1,Ntypes,1,gender,1,nlength) // selex x retained 4darray discmort2(styr-3,endyr+1,1,Ntypes,1,gender,1,nlength) 4darray sel_a(styr-3,endyr+1,1,Ntypes,1,gender,0,nages) vector sel(1,nlength) // used to multiply by ALK // ProgLabel_5.1.6 create TG_parm 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 vector TG_like1(1,N_TG2) vector TG_like2(1,N_TG2) number overdisp // overdispersion LOCAL_CALCS k=Do_TG*(3*N_TG+2*Nfleet); END_CALCS init_bounded_number_vector TG_parm(1,k,TG_parm_LO,TG_parm_HI,TG_parm_PH); LOCAL_CALCS if(Do_Forecast>0) {k=TimeMax_Fcast_std+1;} else {k=TimeMax+nseas;} END_CALCS // ProgLabel_5.2 Create arrays for storing derived selectivity quantities for use in mortality calculations 4darray fish_body_wt(styr-3*nseas,k,1,gmorph,1,Nfleet,0,nages); // wt (adjusted for size selex) 4darray sel_al_1(1,nseas,1,gmorph,1,Nfleet,0,nages); // selected * wt 4darray sel_al_2(1,nseas,1,gmorph,1,Nfleet,0,nages); // selected * retained * wt 4darray sel_al_3(1,nseas,1,gmorph,1,Nfleet,0,nages); // selected numbers 4darray sel_al_4(1,nseas,1,gmorph,1,Nfleet,0,nages); // selected * retained numbers 4darray deadfish(1,nseas,1,gmorph,1,Nfleet,0,nages); // sel * (retain + (1-retain)*discmort) 4darray deadfish_B(1,nseas,1,gmorph,1,Nfleet,0,nages); // sel * (retain + (1-retain)*discmort) * wt 4darray save_sel_fec(styr-3*nseas,TimeMax_Fcast_std+nseas,1,gmorph,0,Nfleet,0,nages) // save sel_al_3 (Asel_2) and save fecundity for output; +nseas covers no forecast setups 4darray Sel_for_tag(TG_timestart*Do_TG,TimeMax*Do_TG,1,gmorph*Do_TG,1,Nfleet,0,nages) vector TG_report(1,Nfleet*Do_TG); vector TG_rep_decay(1,Nfleet*Do_TG); 3darray save_sp_len(styr,endyr+1,1,2*Ntypes,1,90); // use to output selex parm values after adjustment 3darray exp_l(1,Ntypes,1,Nobs_l,1,nlen_bin2) matrix neff_l(1,Ntypes,1,Nobs_l) vector tempvec_l(1,nlength); vector exp_l_temp(1,nlength2); vector exp_l_temp_ret(1,nlength2); // retained lengthcomp vector exp_l_temp_dat(1,nlen_bin2); vector offset_l(1,Ntypes) // Compute OFFSET for multinomial (i.e, value for the multinonial function vector length_like(1,Ntypes) // 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,Ntypes,1,Nobs_a,1,n_abins2) 3darray exp_meanage(1,Ntypes,1,Nobs_a,1,3) // will hold mean age' and 95% range for the range of sizes identified for this age comp observation vector exp_a_temp(1,n_abins2) vector tempvec_a(0,nages) matrix neff_a(1,Ntypes,1,Nobs_a) vector offset_a(1,Ntypes) // Compute OFFSET for multinomial (i.e, value for the multinonial function vector age_like(1,Ntypes) // likelihood of the age-frequency data vector sizeage_like(1,Ntypes) // likelihood of the age-frequency data 3darray exp_ms(1,Ntypes,1,Nobs_ms,1,n_abins2) 3darray exp_ms_sq(1,Ntypes,1,Nobs_ms,1,n_abins2) number Morphcomp_like number equ_catch_like vector catch_like(1,Ntypes) number recr_like number Fcast_recr_like number parm_like number parm_dev_like 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 // ProgLabel_5.1.7 create matrix called smry to store derived quantities of interest matrix Smry_Table(styr-3,YrMax,1,20+2*gmorph); // 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_SPB_virgin, 12=equ_S1, 13=Gentime, 14=YPR, 15=meanage_spawners, 16=meanage_smrynums, 17=meanage_catch // 18, 19, 20 not used // 21+cumF-bymorph, maxF-by morph matrix env_data(styr-1,YrMax,-2,N_envvar) matrix TG_save(1,N_TG,1,3+TG_endtime) // ProgLabel_5.1.8 create sdreport vectors sdreport_vector SPB_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) // ProgLabel_5.1.9 create logLikelihood vectors vector MGparm_Like(1,N_MGparm2) vector init_F_Like(1,Nfleet) vector Q_parm_Like(1,Q_Npar) vector selparm_Like(1,N_selparm2) vector SR_parm_Like(1,N_SRparm2) vector recdev_cycle_Like(1,recdev_cycle) !! k=Do_TG*(3*N_TG+2*Nfleet); vector TG_parm_Like(1,k); objective_function_value obj_fun number last_objfun vector phase_output(1,max_phase+1) !!echoinput<<"end of parameter section"<retro_yr) F_ballpark_yr=endyr; if(F_ballpark_yr0) { for (i=1; i<=nyr_cr(f); i++) { if(yr_cr_use(f,i)>0) { Ln_obs_cr(f,i)=obs_cr(f,i); if(cr_errtype(f)>=0) // lognormal or lognormal T_dist { if(obs_cr(f,i)<=0.0) {N_warn++; cout<<" EXIT - see warning "<0) { for (i=1; i<=nyr_disc(f); i++) { if(yr_disc_use(f,i)>=0.) { if(cv_disc(f,i)<=0.0) cv_disc(f,i)=0.001; if(disc_errtype(f)>=0) {sd_disc(f,i)=cv_disc(f,i)*obs_disc(f,i);} else {sd_disc(f,i)=cv_disc(f,i);} sd_disc(f,i)+=var_adjust(2,f); // note that adjustment is to the sd, not the CV if(sd_disc(f,i)<0.001) sd_disc(f,i)=0.001; } } } echoinput<<" discard stderr has been set-up "<0. && mnwtdata(3,i)>0.) // used observation { mnwtdata(6,i)+=var_adjust(3,mnwtdata(3,i)); if(mnwtdata(6,i)<=0.0) mnwtdata(6,i)=0.001; mnwtdata(7,i)=mnwtdata(5,i)*mnwtdata(6,i); mnwtdata(8,i)=DF_bodywt*square(mnwtdata(7,i)); mnwtdata(9,i)=sd_offset*log(mnwtdata(7,i)); } } echoinput<<" mean bodywt stderr has been set-up "<0) for (f=1; f <= Ntypes; f++) for (i=1; i <= Nobs_l(f); i++) if(header_l(f,i,3)>0) { nsamp_l(f,i)*=var_adjust(4,f); {if(nsamp_l(f,i)<=1.0) nsamp_l(f,i)=1.;} // adjust sample size if(gen_l(f,i) !=2) offset_l(f) -= nsamp_l(f,i) * obs_l(f,i)(tails_l(f,i,1),tails_l(f,i,2))*log(obs_l(f,i)(tails_l(f,i,1),tails_l(f,i,2))); if(gen_l(f,i) >=2 && gender==2) offset_l(f) -= nsamp_l(f,i) * obs_l(f,i)(tails_l(f,i,3),tails_l(f,i,4))*log(obs_l(f,i)(tails_l(f,i,3),tails_l(f,i,4))); } echoinput<<" length_comp offset: "<0) { echoinput<<"Create superperiod sample weights for survey obs"<0) { echoinput<<"Create superperiod sample weights for discard obs"<0) { echoinput<<"Create superperiod sample weights for length obs"<0) { echoinput<<"Create superperiod sample weights for age obs"<0) { echoinput<<"Create superperiod sample weights for meansize obs"<0) { echoinput<<"Create superperiod sample weights for sizecomp obs "<0) for (f=1; f <= Ntypes; f++) for (i=1; i <= Nobs_a(f); i++) if(nsamp_a(f,i)>0 && header_a(f,i,3)>0) { nsamp_a(f,i)*=var_adjust(5,f); {if(nsamp_a(f,i)<=1.0) nsamp_a(f,i)=1.;} // adjust sample size if(gen_a(f,i) !=2) offset_a(f) -= nsamp_a(f,i) * obs_a(f,i)(tails_a(f,i,1),tails_a(f,i,2))*log(obs_a(f,i)(tails_a(f,i,1),tails_a(f,i,2))); if(gen_a(f,i) >=2 && gender==2) offset_a(f) -= nsamp_a(f,i) * obs_a(f,i)(tails_a(f,i,3),tails_a(f,i,4))*log(obs_a(f,i)(tails_a(f,i,3),tails_a(f,i,4))); } echoinput<<" agecomp offset "<0) {for (f=1; f <= Ntypes; f++) for (i=1; i <= Nobs_ms(f); i++) for(b=1;b<=n_abins2;b++) { if(obs_ms_n(f,i,b)>0) { obs_ms_n(f,i,b)=sqrt(var_adjust(6,f)*obs_ms_n(f,i,b)); if(obs_ms_n(f,i,b)<=1.0) obs_ms_n(f,i,b)=1.; } } } echoinput<<" setup stderr for mean size-at-age: "<0) for (i=1; i<=nyr_cr(f); i++) { if(yr_cr_y(f,i)>=styr && yr_cr_y(f,i)<=retro_yr) { if(yr_cr2(f,yr_cr(f,i))>0) { cout<<" EXIT - see warning "<0) for (i=1; i<=nyr_disc(f); i++) {yr_disc2(f,yr_disc(f,i))=i; have_data(f,yr_disc(f,i))=1; } echoinput<<"Create reverse pointers to discard observations"<0) // no reverse pointer here because cannot use it for both superperiods and for replicate obs for (i=1; i<=Nobs_l(f); i++) { have_data(f,yr_l_t(f,i))=1; } if(Nobs_a(f)>0) for (i=1; i <= Nobs_a(f); i++) { have_data(f,yr_a_t(f,i))=1; } if(Nobs_ms(f)>0) for (i=1; i <= Nobs_ms(f); i++) { have_data(f,yr_ms_t(f,i))=1; } } for (f=1;f<=Nfleet;f++) if(obs_equ_catch(f)<=0.001) {init_F(f)=0.0;} // ProgLabel_6.4 conditionally copy the initial parameter values read from the "CTL" file into the parameter arrays // skip this assignment if the parameters are being read from a "SS2.PAR" file if(readparfile==0) { echoinput<< " set parms to init values in CTL file "<0) { for(y=1;y<=recdev_cycle;y++) { recdev_cycle_parm(y)=recdev_cycle_parm_RD(y,3); } } if(recdev_do_early>0) recdev_early.initialize(); if(Do_Forecast>0) Fcast_recruitments.initialize(); if(Do_Forecast>0) Fcast_impl_error.initialize(); if(do_recdev==1) {recdev1.initialize();} // set devs to zero else if(do_recdev==2) {recdev2.initialize();} // set devs to zero if(recdev_read>0) { for(j=1;j<=recdev_read;j++) { y=recdev_input(j,1); if(y>=recdev_first && y<=YrMax) { if(y0) echoinput<< " Q_parms OK "<0.) //have_catch { F_rate(g)=F_setup(1); Hrate(f,t)=F_setup(1); } else {F_rate(g)=0.; Hrate(f,t)=0.0;} } if(F_detail>0) { for(k=1;k<=F_detail;k++) { f=F_setup2(k,1); y=F_setup2(k,2); s=F_setup2(k,3); t=styr+(y-styr)*nseas+s-1; g=(f-1)*(TimeMax-styr+1)+(y-styr)*nseas+s; if(F_setup2(k,4)!=-999) {F_rate(g)=F_setup2(k,4); Hrate(f,t)=F_setup2(k,4);} } } echoinput<< " Fmort_parms have been reset "<0) { k=Do_TG*(3*N_TG+2*Nfleet); for(i=1;i<=k;i++) { TG_parm(i)=TG_parm2(i,3); } echoinput<< " Tag_parms OK "<0) {MGparm(i)=Check_Parm(MGparm_LO(i),MGparm_HI(i), jitter, MGparm(i));} echoinput<< " MG_parms OK "<0) {SR_parm(i) = Check_Parm(SR_parm_1(i,1),SR_parm_1(i,2), jitter, SR_parm(i));} echoinput<< " SRR_parms OK "<0 && recdev_early_PH>0) { for(y=recdev_early_start;y<=recdev_early_end;y++) {recdev_early(y) = Check_Parm(recdev_LO, recdev_HI, jitter, recdev_early(y));} // recdev_early -=sum(recdev_early)/(recdev_early_end-recdev_early_start+1); } if(recdev_PH>0 && do_recdev>0) { if(do_recdev==1) { for(i=recdev_start;i<=recdev_end;i++) {recdev1(i) = Check_Parm(recdev_LO, recdev_HI, jitter, recdev1(i));} recdev1 -=sum(recdev1)/(recdev_end-recdev_start+1); } else { for(i=recdev_start;i<=recdev_end;i++) {recdev2(i) = Check_Parm(recdev_LO, recdev_HI, jitter, recdev2(i));} // recdev2 -=sum(recdev2)/(recdev_end-recdev_start+1); } } echoinput<< " rec_devs OK "<0) { for(i=1;i<=Q_Npar;i++) if(Q_parm_1(i,7)>0) {Q_parm(i) = Check_Parm(Q_parm_1(i,1),Q_parm_1(i,2), jitter, Q_parm(i));} echoinput<< " Q_parms OK "<0) {init_F(i) = Check_Parm(init_F_LO(i),init_F_HI(i), jitter, init_F(i));} echoinput<< " initF_parms OK "<0) {selparm(i)=Check_Parm(selparm_LO(i),selparm_HI(i), jitter, selparm(i));} echoinput<< " selex_parms OK "<0) { k=Do_TG*(3*N_TG+2*Nfleet); for(i=1;i<=k;i++) { if(TG_parm_PH(i)>0) {TG_parm(i)=Check_Parm(TG_parm_LO(i),TG_parm_HI(i), jitter, TG_parm(i));} } echoinput<< " Tag_parms OK "<=1) { for (y=styr-1;y<=(YrMax);y++) for(j=1;j<=N_envvar;j++) {env_data(y,j)=env_data_RD(y,j);} } // ProgLabel_6.7 initialize several items if(Rebuild_Ydecl==-1) Rebuild_Ydecl=1999; if(Rebuild_Yinit==-1) Rebuild_Yinit=endyr+1; if(Rebuild_Ydecl>YrMax) Rebuild_Ydecl=YrMax; if(Rebuild_Yinit>YrMax) Rebuild_Yinit=YrMax; migrrate.initialize(); depletion.initialize(); sel_l.initialize(); sel_a.initialize(); retain.initialize(); discmort.initialize(); discmort2.initialize(); for(f=1;f<=Ntypes;f++) for(y=styr;y<=endyr+1;y++) for(gg=1;gg<=gender;gg++) { discmort2(y,f,gg)=1.0; if(y<=endyr+1) { discmort(y,f)=1.0; retain(y,f)=1.0; } } Richards=1.0; // ProgLabel_6.8 go thru biological calculations once, with do_once flag=1 echoinput<10.0) {N_warn++; warning<<" Minimum size bin is:_"<10cm, which is large for use as size-at-age 0.0 recruitment"<0.95*len_bins(nlength)) {N_warn++; warning<<" Maximum size at age: "<0) // set up migration rates { get_migration(); migrrate=value(migrrate); } // ProgLabel_6.8.8 call fxn get_age_age() if(N_ageerr>0) { AgeKey_StartAge=0; AgeKey_Linear1=1; AgeKey_Linear2=1; for(j=1;j<=N_ageerr;j++) { if(j!=Use_AgeKeyZero) { age_err(j)=age_err_rd(j); // this is an age err definition that has been read } else { AgeKey_StartAge=int(value(mgp_adj(AgeKeyParm))); if(mgp_adj(AgeKeyParm+3)==0.0000) {AgeKey_Linear1=1;} else {AgeKey_Linear1=0;} if(mgp_adj(AgeKeyParm+6)==0.0000) {AgeKey_Linear2=1;} else {AgeKey_Linear2=0;} } get_age_age(j,AgeKey_StartAge,AgeKey_Linear1,AgeKey_Linear2); // call function to get the age_age key } age_age=value(age_age); // because these are not based on parameters } echoinput<<" made the age_age' key "<0) ParmTrace<<"Phase Iter ObjFun Change SPB_start SPB_end BiasAdj_st BiasAdj_max BiasAdj_end "; if(Do_ParmTrace==1 || Do_ParmTrace==4) { for(i=1;i<=active_count;i++) {ParmTrace<<" "<=2) { for(i=1;i<=ParCount;i++) {ParmTrace<<" "<0) SzFreq_exp.initialize(); if(mceval_phase() ) mceval_counter ++; // increment the counter if(mcmcFlag==1) // so will do mcmc this run or is in mceval { if(Do_ParmTrace==1) Do_ParmTrace=4; // to get all iterations if(Do_ParmTrace==2) Do_ParmTrace=3; // to get all iterations if(mcmc_counter>10 || mceval_counter>10) Do_ParmTrace=0; } // ProgLabel_7.1 set up bias_adj vector sigmaR=SR_parm(N_SRparm2-3); two_sigmaRsq=2.0*sigmaR*sigmaR; half_sigmaRsq=0.5*sigmaR*sigmaR; if(initial_params::mc_phase==1) mcmc_counter++; biasadj.initialize(); if(mcmcFlag==1) // so will do mcmc this run or is in mceval { biasadj_full=1.0; } else if(recdev_adj(5)<0.0) { biasadj_full=1.0; } else { for (y=styr-nages; y<=YrMax; y++) { if(y0 && recdev_options(2)>=0 ) // do logic on basis of recdev_options(2), which is read, not recdev_PH which can be reset to a neg. value { for(i=recdev_early_start;i<=recdev_early_end;i++) {biasadj(i)=biasadj_full(i);} } if(do_recdev>0 && recdev_PH_rd>=0 ) { for(i=recdev_start;i<=recdev_end;i++) {biasadj(i)=biasadj_full(i);} } if(Do_Forecast>0 && recdev_options(3)>=0 ) { for(i=recdev_end+1;i<=YrMax;i++) {biasadj(i)=biasadj_full(i);} } if(recdev_read>0) { for(j=1;j<=recdev_read;j++) { y=recdev_input(j,1); if(y>=recdev_first && y<=YrMax) biasadj(y)=biasadj_full(y); } } } if(do_once==1) echoinput<<"bias_adjustment vector: "<0) {recdev(recdev_early_start,recdev_early_end)=recdev_early(recdev_early_start,recdev_early_end);} if(do_recdev==1) {recdev(recdev_start,recdev_end)=recdev1(recdev_start,recdev_end);} else if(do_recdev==2) {recdev(recdev_start,recdev_end)=recdev2(recdev_start,recdev_end);} if(Do_Forecast>0) recdev(recdev_end+1,YrMax)=Fcast_recruitments(recdev_end+1,YrMax); // only needed here for reporting // ProgLabel_7.3 reset Fmethod 2 to Fmethod 3 according to the phase if(F_Method==2) { F_Method_use=2; if(current_phase() < F_setup(2)) F_Method_use=3; // use hybrid } else { F_Method_use=F_Method; } // ProgLabel_7.4 Do the calculations if(mceval_counter==0 || (mceval_counter>burn_intvl && ((double(mceval_counter)/double(thin_intvl)) - double((mceval_counter/thin_intvl))==0) )) // check to see if burn in period is over { y=styr; // ProgLabel_7.4.1 call fxn get_initial_conditions() get_initial_conditions(); if(do_once==1) cout<<" OK with initial conditions "<0) { // if(save_for_report>0 || last_phase() || current_phase()==max_phase || ((sd_phase() || mceval_phase()) && (initial_params::mc_phase==0))) { // ProgLabel_7.5.1 calc average selectivity to use in forecast; store in endyr+1 temp=float(Fcast_Sel_yr2-Fcast_Sel_yr1+1.); for(gg=1;gg<=gender;gg++) for(f=1;f<=Nfleet;f++) { tempvec_l.initialize(); for(y=Fcast_Sel_yr1;y<=Fcast_Sel_yr2;y++) {tempvec_l+=sel_l(y,f,gg);} sel_l(endyr+1,f,gg)=tempvec_l/temp; tempvec_l.initialize(); for(y=Fcast_Sel_yr1;y<=Fcast_Sel_yr2;y++) {tempvec_l+=sel_l_r(y,f,gg);} sel_l_r(endyr+1,f,gg)=tempvec_l/temp; tempvec_l.initialize(); for(y=Fcast_Sel_yr1;y<=Fcast_Sel_yr2;y++) {tempvec_l+=discmort2(y,f,gg);} discmort2(endyr+1,f,gg)=tempvec_l/temp; tempvec_a.initialize(); for(y=Fcast_Sel_yr1;y<=Fcast_Sel_yr2;y++) {tempvec_a+=sel_a(y,f,gg);} sel_a(endyr+1,f,gg)=tempvec_a/temp; } // ProgLabel_7.5.2 set-up relative F among fleets and seasons for forecast if(Fcast_RelF_Basis==1) // set allocation according to range of years { temp=0.0; Fcast_RelF_Use.initialize(); for(y=Fcast_RelF_yr1;y<=Fcast_RelF_yr2;y++) for(f=1;f<=Nfleet;f++) for(s=1;s<=nseas;s++) { t=styr+(y-styr)*nseas+s-1; Fcast_RelF_Use(s,f)+=Hrate(f,t); } temp=sum(Fcast_RelF_Use); if(temp==0.0) { Fcast_RelF_Use(1,1)=1.0; Fcurr_Fmult=0.0; } else { Fcast_RelF_Use/=temp; Fcurr_Fmult=temp/float(Fcast_RelF_yr2-Fcast_RelF_yr1+1); } } else // Fcast_RelF_Basis==2 so set to values that were read { temp=0.0; for(f=1;f<=Nfleet;f++) for(s=1;s<=nseas;s++) { temp+=Fcast_RelF_Input(s,f); } Fcast_RelF_Use=Fcast_RelF_Input/temp; Fcurr_Fmult=temp; } } // end being in a phase for these calcs } // end getting quantities for forecasts // ProgLabel_7.5.3 calc average selectivity to use in benchmarks; store in styr-3 // Bmark_Yr(1,6)<<" Benchmark years: beg-end bio; beg-end selex; beg-end alloc"<0) { // if(save_for_report>0 || last_phase() || current_phase()==max_phase || ((sd_phase() || mceval_phase()) && (initial_params::mc_phase==0))) { // calc average body size to use in equil; store in styr-3 temp=float(Bmark_Yr(2)-Bmark_Yr(1)+1.); // get denominator for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { for(s=0;s<=nseas-1;s++) { tempvec_a.initialize(); for(t=Bmark_t(1);t<=Bmark_t(2);t+=nseas) {tempvec_a+=Ave_Size(t+s,0,g);} Ave_Size(styr-3*nseas+s,0,g)=tempvec_a/temp; tempvec_a.initialize(); for(t=Bmark_t(1);t<=Bmark_t(2);t+=nseas) {tempvec_a+=Ave_Size(t+s,1,g);} Ave_Size(styr-3*nseas+s,1,g)=tempvec_a/temp; for(f=0;f<=Nfleet;f++) { tempvec_a.initialize(); for(t=Bmark_t(1);t<=Bmark_t(2);t+=nseas) {tempvec_a+=save_sel_fec(t+s,g,f);} save_sel_fec(styr-3*nseas+s,g,f)=tempvec_a/temp; } } } if(do_migration>0) { temp=float(Bmark_Yr(2)-Bmark_Yr(1)+1.); // get denominator for(j=1;j<=do_migr2;j++) { tempvec_a.initialize(); for(y=Bmark_Yr(1);y<=Bmark_Yr(2);y++) {tempvec_a+=migrrate(y,j);} migrrate(styr-3,j)=tempvec_a/temp; } } // calc average selectivity to use in equil; store in styr-1 temp=float(Bmark_Yr(4)-Bmark_Yr(3)+1.); // get denominator for(gg=1;gg<=gender;gg++) for(f=1;f<=Nfleet;f++) { tempvec_l.initialize(); for(y=Bmark_Yr(3);y<=Bmark_Yr(4);y++) {tempvec_l+=sel_l(y,f,gg);} sel_l(styr-3,f,gg)=tempvec_l/temp; tempvec_l.initialize(); for(y=Bmark_Yr(3);y<=Bmark_Yr(4);y++) {tempvec_l+=sel_l_r(y,f,gg);} sel_l_r(styr-3,f,gg)=tempvec_l/temp; tempvec_l.initialize(); for(y=Bmark_Yr(3);y<=Bmark_Yr(4);y++) {tempvec_l+=discmort2(y,f,gg);} discmort2(styr-3,f,gg)=tempvec_l/temp; tempvec_a.initialize(); for(y=Bmark_Yr(3);y<=Bmark_Yr(4);y++) {tempvec_a+=sel_a(y,f,gg);} sel_a(styr-3,f,gg)=tempvec_a/temp; } // set-up relative F among fleets and seasons if(Bmark_RelF_Basis==1) // set allocation according to range of years { temp=0.0; Bmark_RelF_Use.initialize(); for(y=Bmark_Yr(5);y<=Bmark_Yr(6);y++) for(f=1;f<=Nfleet;f++) for(s=1;s<=nseas;s++) { t=styr+(y-styr)*nseas+s-1; Bmark_RelF_Use(s,f)+=Hrate(f,t); } temp=sum(Bmark_RelF_Use); if(temp==0.0) { Bmark_RelF_Use(1,1)=1.0; } else { Bmark_RelF_Use/=temp; } } else // Bmark_RelF_Basis==2 so set same as forecast { Bmark_RelF_Use=Fcast_RelF_Use; } } // end being in a phase for these calcs } // end getting quantities for benchmarks // ProgLabel_7.6 if sdphase or mcevalphase, do benchmarks and forecast and derived quantities if( (sd_phase() || mceval_phase()) && (initial_params::mc_phase==0)) { // ProgLabel_7.6.1 call fxn Get_Benchmarks() if(Do_Benchmark>0) { Get_Benchmarks(); did_MSY=1; } else {Mgmt_quant(1)=SPB_virgin;} if(mceval_phase()==0) {show_MSY=1;} // ProgLabel_7.6.2 call fxn Get_Forecast() if(Do_Forecast>0) { report5<<"THIS FORECAST FOR PURPOSES OF STD REPORTING"<1) { if(nobs_cr>0) cout<<" CPUE " <0) cout<<" Disc " <0) cout<<" MnWt " <0) cout<<" LEN " <0) cout<<" AGE " <0) cout<<" L-at-A " <0) cout<<" sizefreq "<0) cout<<" TG-fleetcomp "<1) {cout<<"Catch "<0) { temp=norm2(recdev(recdev_start,recdev_end)); temp=sqrt((temp+0.0000001)/(double(recdev_end-recdev_start+1))); if(mcmc_counter==0 && mceval_counter==0) {cout<0) {cout<<" MCMC: "<0) {cout<<" MCeval: "<1 && sum(catch_like)>0.01) {cout<<" cat "<0.01) {cout<<" crash "<=0) {ParmTrace<<" "<0 && N_MGparm_dev>0) { for(j=1;j<=N_MGparm_dev;j++) {ParmTrace<=0) {ParmTrace<<" "<0) { for(j=1;j<=recdev_cycle;j++) { if(recdev_cycle_PH(j)>=0) {ParmTrace<<" "<0) {ParmTrace<<" "<0) { if(do_recdev==1) {ParmTrace<<" "<0) ParmTrace<0 && Do_Impl_Error>0) ParmTrace<0) {ParmTrace<<" "<0) {ParmTrace<<" "<0) {ParmTrace<<" "<0) {ParmTrace<<" "<0 && N_selparm_dev>0) { for(j=1;j<=N_selparm_dev;j++) {ParmTrace<0) {ParmTrace<<" "<0) ParmTrace<0) { for(j=1;j<=N_MGparm_dev;j++) {ParmTrace<0) ParmTrace<0) ParmTrace<0) ParmTrace<0) ParmTrace<0) { for(j=1;j<=N_selparm_dev;j++) {ParmTrace<0) ParmTrace< #include time_t start,finish; long hour,minute,second; double elapsed_time; // ProgLabel_10.1 open output files using ofstream ofstream warning("warning.sso"); ofstream echoinput("echoinput.sso"); ofstream ParmTrace("ParmTrace.sso"); ofstream report5("Forecast-report.sso"); ofstream report2("CumReport.sso",ios::app); ofstream bodywtout("wtatage.ss_new"); ofstream SS2out; // this is just a create // ProgLabel_10.2 define some adstring variables adstring_array ParmLabel; // extendable array to hold the parameter labels adstring_array fleetname; adstring depletion_basis_label; adstring F_report_label; adstring SPR_report_label; adstring onenum(4); adstring anystring; adstring anystring2; adstring version_info; adstring version_info_short; adstring_array Starter_Comments; adstring_array Data_Comments; adstring_array Control_Comments; adstring_array Forecast_Comments; random_number_generator radm(long(time(&start))); // ProgLabel_11. BETWEEN_PHASES_SECTION BETWEEN_PHASES_SECTION int j_phase=current_phase(); // this is the phase to come // ProgLabel_11.1 if(j_phase>1) { last_objfun=obj_fun; } // ProgLabel_11.2 for Fmethod=2, set parameter values (F_rate) equal to Hrate array calculated using hybrid method in previous phase if(F_Method==2) { if(F_setup(2)>1 && j_phase==F_setup(2) && readparfile==0) // so now start doing F as parameters { g=0; for(f=1;f<=Nfleet;f++) for(t=styr;t<=TimeMax;t++) { g++; F_rate(g)=Hrate(f,t); } } } // ProgLabel_12. FINAL_SECTION FINAL_SECTION int jj; // ProgLabel_12.1 get run ending time time(&finish); elapsed_time = difftime(finish,start); hour = long(elapsed_time)/3600; minute = long(elapsed_time)%3600/60; second = (long(elapsed_time)%3600)%60; cout<gmax << endl<gmax >final_conv) {N_warn++; warning<<"Final gradient: "<gmax <<" is larger than final_conv: "<0) { if(did_MSY==0) Get_Benchmarks(); } else {Mgmt_quant(1)=SPB_virgin;} cout<<"Finished benchmark"<0) { report5<<"THIS FORECAST FOR PURPOSES OF GETTING DISPLAY QUANTITIES"<0) write_summaryoutput(); cout<<" finished summary report "<0 && mceval_counter<=1) write_rebuilder_output(); cout<<" finished rebuilder report "<0) {N_warn++; warning<<"Reminder: Number of lamdas !=0.0 and !=1.0: "<0) N_warn++; if(N_warn>0) {cout<<"See warning.sso for N warnings: "<0) report<<" CPUE " <0) report<<" Disc " <0) report<<" MnWt " <0) report<<" LEN " <0) report<<" AGE " <0) report<<" L-at-A " <1) {report<<"Catch "<0) report<<" sizefreq "<0) report<<" TG-fleetcomp "<0) { for (gg=1;gg<=gender;gg++) report<10) { for (gg=1;gg<=gender;gg++) report<0) { save_for_report=1; CrashPen.initialize(); save_gparm=0; y=styr; get_initial_conditions(); get_time_series(); evaluate_the_objective_function(); write_bigoutput(); save_for_report=0; SS2out.close(); } //********************************************************************* /* ProgLabel_FUNCTION 14 get_MGsetup : apply time-varying factors this year to the MG parameters to create mgp_adj vector */ FUNCTION void get_MGsetup() { mgp_adj=MGparm; int y1; // ProgLabel_14.1 calculate any trends that will be needed for any of the MG parameters if(N_MGparm_trend>0) { for(f=1;f<=N_MGparm_trend;f++) { j=MGparm_trend_rev(f); // parameter affected k=MGparm_trend_rev_1(f); // base index for trend parameters if(y==styr) { // calc endyr value, but use logistic transform to keep with bounds of the base parameter if(MGparm_1(j,13)==-1) { temp=log((MGparm_1(j,2)-MGparm_1(j,1)+0.0000002)/(MGparm(j)-MGparm_1(j,1)+0.0000001)-1.)/(-2.); // transform the base parameter temp+=MGparm(k+1); // add the offset Note that offset value is in the transform space temp1=MGparm_1(j,1)+(MGparm_1(j,2)-MGparm_1(j,1))/(1.+mfexp(-2.*temp)); // backtransform } else if(MGparm_1(j,13)==-2) { temp1=MGparm(k+1); // set ending value directly } if(MGparm_HI(k+2)<=1.1) // use max bound as switch {temp3=r_years(styr)+MGparm(k+2)*(r_years(endyr)-r_years(styr));} // infl year else {temp3=MGparm(k+2);} temp2=cumd_norm((r_years(styr)-temp3)/MGparm(k+3)); // cum_norm at styr temp=(temp1-MGparm(j)) / (cumd_norm((r_years(endyr)-temp3)/MGparm(k+3))-temp2); // delta in cum_norm between styr and endyr for(int y1=styr;y1<=YrMax;y1++) { if(y1<=endyr) {MGparm_trend(f,y1)=MGparm(j) + temp * (cumd_norm((r_years(y1)-temp3)/MGparm(k+3) )-temp2);} else {MGparm_trend(f,y1)=MGparm_trend(f,y1-1);} } } mgp_adj(j)=MGparm_trend(MGparm_trend_point(j),y); } } // ProgLabel_14.2 else create MGparm block values else if (N_MGparm_blk>0) { for(j=1;j<=N_MGparm;j++) { z=MGparm_1(j,13); // specified block pattern if(z>0) // uses blocks { if(y==styr) // set up the block values time series { g=1; if(MGparm_1(j,14)<3) { for(a=1;a<=Nblk(z);a++) { for(int y1=Block_Design(z,g);y1<=Block_Design(z,g+1);y1++) // loop years for this block { k=Block_Defs_MG(j,y1); // identifies parameter that holds the block effect MGparm_block_val(j,y1)=MGparm(k); } g+=2; } } else { temp=0.0; for(a=1;a<=Nblk(z);a++) { y1=Block_Design(z,g); // first year of block k=Block_Defs_MG(j,y1); // identifies parameter that holds the block effect temp+=MGparm(k); // increment by the block delta for(int y1=Block_Design(z,g);y1<=Block_Design(z,g+1);y1++) // loop years for this block { MGparm_block_val(j,y1)=temp; } g+=2; } } } // end block setup } // end uses blocks } // end parameter loop } // end block section // ProgLabel_14.3 create MGparm dev randwalks if needed if(N_MGparm_dev>0 && y==styr) { for(k=1;k<=N_MGparm_dev;k++) { if(MGparm_dev_type(k)==3) { MGparm_dev_rwalk(k,MGparm_dev_minyr(k))=MGparm_dev(k,MGparm_dev_minyr(k)); j=MGparm_dev_minyr(k); for (j=MGparm_dev_minyr(k)+1;j<=MGparm_dev_maxyr(k);j++) { MGparm_dev_rwalk(k,j)=MGparm_dev_rwalk(k,j-1)+MGparm_dev(k,j); } } } } // ProgLabel_14.4 switch(MG_adjust_method) switch(MG_adjust_method) { case 3: { // no break statement, so will execute case 1 code } // ProgLabel_14.4.1 standard MG_adjust_method (1 or 3), loop MGparms case 1: { for(f=1;f<=N_MGparm;f++) { // ProgLabel_14.4.1.1 adjust for blocks if(MGparm_1(f,13)>0) // blocks { if(Block_Defs_MG(f,yz)>0) { if(MGparm_1(f,14)==0) {mgp_adj(f) *= mfexp(MGparm_block_val(f,yz));} else if(MGparm_1(f,14)==1) {mgp_adj(f) += MGparm_block_val(f,yz);} else if(MGparm_1(f,14)==2) {mgp_adj(f) = MGparm_block_val(f,yz);} else if(MGparm_1(f,14)==3) // additive based on delta approach {mgp_adj(f) += MGparm_block_val(f,yz);} } } // ProgLabel_14.4.1.2 adjust for env linkage if(MGparm_env(f)>0) { if(MGparm_envtype(f)==1) {mgp_adj(f)*=mfexp(MGparm(MGparm_env(f))*env_data(yz,MGparm_envuse(f)));} else {mgp_adj(f)+=MGparm(MGparm_env(f))*env_data(yz,MGparm_envuse(f));} } // ProgLabel_14.4.1.3 adjust for Annual deviations k=MGparm_dev_select(f); if(k>0) { if(yz>=MGparm_dev_minyr(k) && yz<=MGparm_dev_maxyr(k)) { if(MGparm_dev_type(k)==1) // multiplicative {mgp_adj(f) *= mfexp(MGparm_dev(k,yz));} else if(MGparm_dev_type(k)==2) // additive {mgp_adj(f) += MGparm_dev(k,yz);} else if(MGparm_dev_type(k)==3) // additive rwalk {mgp_adj(f) += MGparm_dev_rwalk(k,yz);} } } // ProgLabel_14.4.1.4 do bound check if MG_adjust_method=1 if(MG_adjust_method==1 && (save_for_report==1 || do_once==1)) // so does not check bounds if MG_adjust_method==3 { if(mgp_adj(f)MGparm_1(f,2)) { N_warn++; warning<<" adjusted MGparm out of bounds (parm#, yr, min, max, base, adj_value) "<0) // blocks { if(Block_Defs_MG(f,yz)>0) { j=1; // change is being made if(MGparm_1(f,14)==1) {temp+=MGparm_block_val(f,yz);} else if(MGparm_1(f,14)==2) // block as replacement {temp=log((MGparm_HI(f)-MGparm_LO(f)+0.0000002)/(MGparm_block_val(f,yz)-MGparm_LO(f)+0.0000001)-1.)/(-2.);} else if(MGparm_1(f,14)==3) // additive based on delta approach {temp += MGparm_block_val(f,yz);} } } // ProgLabel_14.4.2.2 adjust for env linkage if(MGparm_env(f)>0) // do environmental effect; only additive allowed for adjustment method=2 {j=1; temp+=MGparm(MGparm_env(f))* env_data(yz,MGparm_envuse(f));} // ProgLabel_14.4.2.3 adjust for annual deviations k=MGparm_dev_select(f); if(k>0) { if(yz>=MGparm_dev_minyr(k) && yz<=MGparm_dev_maxyr(k)) { j=1; if(MGparm_dev_type(k)==2) {temp += MGparm_dev(k,yz);} else if(MGparm_dev_type(k)==3) {temp += MGparm_dev_rwalk(k,yz);} // note that only additive effect is allowed } } if(j==1) mgp_adj(f)=MGparm_LO(f)+(MGparm_HI(f)-MGparm_LO(f))/(1.+mfexp(-2.*temp)); // backtransform } // end parameter loop (f) break; } // end case 2 } // end switch method // if direct estimation (no offsets) is used; then look for M and growth parameters // for which male value is set equal to female value // ProgLabel_14.5 if MGparm method =1 (no offsets), then do direct assignment if parm value is 0.0. if(MGparm_def==1) { for(j=1;j<=N_GP*gender*MGparm_per_def;j++) { if(MGparm_offset(j)>0) mgp_adj(j) = mgp_adj(MGparm_offset(j)); } } if(save_for_report>0) mgp_save(yz)=value(mgp_adj); } //********************************************************************* /* ProgLabel_FUNCTION 15 get_growth1 */ FUNCTION void get_growth1() { // ProgLabel_15.1 create seasonal effects for growth K, and for wt_len parameters if(MGparm_doseas>0) { if(MGparm_seas_effects(10)>0) // for seasonal K { VBK_seas(0)=0.0; for(s=1;s<=nseas;s++) { VBK_seas(s)=mfexp(MGparm(MGparm_seas_effects(10)+s)); VBK_seas(0)+=VBK_seas(s)*seasdur(s); } } else { VBK_seas=sum(seasdur); // set vector to null effect } for(j=1;j<=8;j++) { if(MGparm_seas_effects(j)>0) { wtlen_seas(0,j)=0.0; for(s=1;s<=nseas;s++) { wtlen_seas(s,j)=mfexp(MGparm(MGparm_seas_effects(j)+s)); wtlen_seas(0,j)+=wtlen_seas(s,j)*seasdur(s); } } else { for(s=0;s<=nseas;s++) {wtlen_seas(s,j)=1.0;} } } } else { VBK_seas=sum(seasdur); // set vector to null effect wtlen_seas=1.0; // set vector to null effect } // ProgLabel_15.2 create variability of size-at-age factors using direct assignment or offset approaches Ip=1-MGparm_per_def; for (gp=1;gp<=N_GP*gender;gp++) { Ip+=MGparm_per_def; j=Ip+MGparm_per_def-2; // index for CVmin k=j+1; // index for CVmax switch(MGparm_def) // for CV of size-at-age { case 1: // direct { if(MGparm(j)>0) {CVLmin(gp)=MGparm(j);} else {CVLmin(gp)=MGparm(MGparm_per_def-1);} if(MGparm(k)>0) {CVLmax(gp)=MGparm(k);} else {CVLmax(gp)=MGparm(MGparm_per_def);} break; } case 2: // offset { if(gp==1) {CVLmin(gp)=MGparm(j); CVLmax(gp)=MGparm(k);} else {CVLmin(gp)=CVLmin(1)*mfexp(MGparm(j)); CVLmax(gp)=CVLmax(1)*mfexp(MGparm(k));} break; } case 3: // offset like SS2 V1.23 { if(gp==1) {CVLmin(gp)=MGparm(j); CVLmax(gp)=CVLmin(1)*mfexp(MGparm(k));} else {CVLmin(gp)=CVLmin(1)*mfexp(MGparm(j)); CVLmax(gp)=CVLmin(gp)*mfexp(MGparm(k));} break; } } // end switch if((CVLmin(gp)!=CVLmax(gp)) || active(MGparm(MGparm_per_def)) || active(MGparm(k))) {CV_const(gp)=1;} else {CV_const(gp)=0;} } } //********************************************************************* /* ProgLabel_FUNCTION 16 get_growth2 */ FUNCTION void get_growth2() { // progress mean growth through time series, accounting for seasonality and possible change in parameters // get mean size at the beginning and mid-point of the season dvariable grow; dvariable growhalf; dvar_vector CV_delta(1,N_GP*gender); dvariable LminR; dvariable LmaxR; dvariable LinfR; dvariable inv_Richards; int k2; // ProgLabel_16.1 create Cohort_Growth offset for the cohort borne (age 0) this year if(CGD>0) // cohort specific growth multiplier { temp=mgp_adj(MGP_CGD); k=min(nages,(YrMax-y)); for(a=0;a<=k;a++) {Cohort_Growth(y+a,a)=temp;} } Ip=N_natMparms+1; // first growth parameter for (gp=1;gp<=N_GP*gender;gp++) { // ProgLabel_16.2 loop growth patterns (N_GP * gender) // ProgLabel_16.2.1 set Lmin, Lmax, VBK, Richards to this year's values for mgp_adj if(MGparm_def>1 && gp>1) // switch for growth parms { Lmin(gp)=Lmin(1)*mfexp(mgp_adj(Ip)); Lmax_temp(gp)=Lmax_temp(1)*mfexp(mgp_adj(Ip+1)); VBK(gp)=VBK(1)*mfexp(mgp_adj(Ip+2)); // assigns to all ages if(Grow_type==2) Richards(gp)=Richards(1)*mfexp(mgp_adj(Ip+3)); } else { Lmin(gp)=mgp_adj(Ip); Lmax_temp(gp)=mgp_adj(Ip+1); VBK(gp)=-mgp_adj(Ip+2); // because always used as negative; assigns to all ages if(Grow_type==2) Richards(gp)=mgp_adj(Ip+3); } if(Grow_type==3) // age specific k { j=1; for(a=1;a<=nages;a++) { if(a==Age_K_points(j)) { VBK(gp,a)=VBK(gp,a-1)*mgp_adj(Ip+2+j); if(j0) { if(CV_depvar_a==0) {CV_delta(gp)=(CVLmax(gp)-CVLmin(gp))/(Lmax_temp(gp)-Lmin(gp));} else {CV_delta(gp)=(CVLmax(gp)-CVLmin(gp))/(AFIX2_forCV-AFIX);} } else { CV_delta(gp)=0.0; CV_G(gp)=CVLmin(gp); // sets all seasons and whole age range } g=(gp-1)*nseas*N_platoon+int(N_platoon/2)+1-N_platoon; // find the mid-morph being processed // note that an index may have been created in data section for the above statement for(birthseas=1;birthseas<=nseas;birthseas++) { // ProgLabel_16.2.3 loop birth seasons (really looping more morphs) g+=N_platoon; if(use_morph(g)>0) { // ProgLabel_16.2.3.1 if y=styr, get size-at-age in first season of this first year if(y==styr) { if(docheckup==1) echoinput<<" growth in start year for platoon: "<=-1.0 for the young ages if(lin_grow_beg(g,1,a)>=-1.0) // younger or equal to AFIX, so use youngest age groups VBK { Ave_Size(styr,0,g,a) = Lmin(gp) + (Lmin(gp)-L_inf(gp))* (mfexp(VBK(gp,0)*VBK_seas(0)*(curr_age_beg(g,1,a)-AFIX))-1.0); } else { Ave_Size(styr,0,g,a) = Ave_Size(styr,0,g,a-1) + (Ave_Size(styr,0,g,a-1)-L_inf(gp))* (mfexp(VBK(gp,a-1)*VBK_seas(0))-1.0); } } // done ageloop if(birthseas>1) Ave_Size(styr,0,g,0)=len_bins(1); if(docheckup==1) echoinput<<" size_at_age w/o linear ramp overlay: "<=0.0) // in linear phase for begin seas { Ave_Size(t,0,g,a) = len_bins(1)+lin_grow_beg(g,s,a)*(Cohort_Lmin(gp,y,a)-len_bins(1)); // begin of season } if(lin_grow_mid(g,s,a)>=0.0) // in linear phase for midseas { Ave_Size(t,1,g,a) = len_bins(1)+lin_grow_mid(g,s,a)*(Cohort_Lmin(gp,y,a)-len_bins(1)); // mid season } growhalf = (mfexp(VBK(gp,a)*seasdur_half(s)*VBK_seas(s))-1.0); // NOTE: there is no seasonal interpolation, or real age adjustment for age-specific K. Maybe someday.... if(lin_grow_beg(g,s,a)==-1.0) // first time point beyond AFIX { Ave_Size(t,0,g,a) = Cohort_Lmin(gp,y,a) + (Cohort_Lmin(gp,y,a)-L_inf(gp))* (mfexp(VBK(gp,a)*(curr_age_beg(g,s,a)-AFIX)*VBK_seas(s))-1.0)*Cohort_Growth(y,a); } if(lin_grow_mid(g,s,a)<0.0) // so doing growth curve by mid of this seas, so project with growth to begin of next { if(lin_grow_mid(g,s,a)==-1.0) // first time point beyond AFIX { Ave_Size(t,1,g,a) = Cohort_Lmin(gp,y,a) + (Cohort_Lmin(gp,y,a)-L_inf(gp))* (mfexp(VBK(gp,a)*(curr_age_mid(g,s,a)-AFIX)*VBK_seas(s))-1.0)*Cohort_Growth(y,a); } else // calc midseas size starting from size at beginning of this season { t2=Ave_Size(t,0,g,a)-L_inf(gp); // remaining growth potential if(time_vary_MG(y,2)>0 && t2>-1.) { join1=1.0/(1.0+mfexp(-(50.*t2/(1.0+fabs(t2))))); // note the logit transform is not perfect, so growth near Linf will not be exactly same as with native growth function t2*=(1.-join1); // trap to prevent decrease in size-at-age } Ave_Size(t,1,g,a) = Ave_Size(t,0,g,a)+growhalf * t2*Cohort_Growth(y,a); } // ProgLabel_16.2.3.2.1.2 calc size at end of the season, which will be size at begin of next season using current seasons growth parms if(a0 && t2>-1.) { join1=1.0/(1.0+mfexp(-(50.*t2/(1.0+fabs(t2))))); // note the logit transform is not perfect, so growth near Linf will not be exactly same as with native growth function t2*=(1.-join1); // trap to prevent decrease in size-at-age } temp1 = Ave_Size(t,1,g,a)+growhalf * t2*Cohort_Growth(y,a); if((a=0.0) // in linear phase for begin seas { Ave_Size(t,0,g,a) = len_bins(1)+lin_grow_beg(g,s,a)*(Cohort_Lmin(gp,y,a)-len_bins(1)); // begin of season } if(lin_grow_mid(g,s,a)>=0.0) // in linear phase for midseas { Ave_Size(t,1,g,a) = len_bins(1)+lin_grow_mid(g,s,a)*(Cohort_Lmin(gp,y,a)-len_bins(1)); // mid season } if(lin_grow_beg(g,s,a)==-1.0) // first time point beyond AFIX { temp=pow(Cohort_Lmin(gp,y,a),Richards(gp)); temp1=temp+(temp-LinfR)*(mfexp(VBK(gp,nages)*(curr_age_beg(g,s,a)-AFIX)*VBK_seas(s))-1.0)*Cohort_Growth(y,a); Ave_Size(t,0,g,a) = pow(temp1,inv_Richards); } if(lin_grow_mid(g,s,a)<0.0) // so doing growth curve by mid of this seas, so project with growth to begin of next { if(lin_grow_mid(g,s,a)==-1.0) // first time point beyond AFIX { temp=pow(Cohort_Lmin(gp,y,a),Richards(gp)); temp1=temp+(temp-LinfR)*(mfexp(VBK(gp,nages)*(curr_age_mid(g,s,a)-AFIX)*VBK_seas(s))-1.0)*Cohort_Growth(y,a); Ave_Size(t,1,g,a) = pow(temp1,inv_Richards); } else // calc midseas size starting from size at beginning of this season { temp=pow(Ave_Size(t,0,g,a),Richards(gp)); t2=temp-LinfR; // remaining growth potential if(time_vary_MG(y,2)>0 && t2>-1.) { join1=1.0/(1.0+mfexp(-(50.*t2/(1.0+fabs(t2))))); // note the logit transform is not perfect, so growth near Linf will not be exactly same as with native growth function t2*=(1.-join1); // trap to prevent decrease in size-at-age } Ave_Size(t,1,g,a) = pow((temp+growhalf*(t2)*Cohort_Growth(y,a)),inv_Richards); } // ProgLabel_16.2.3.2.2.2 calc size at end of the season, which will be size at begin of next season using current seasons growth parms if(a0 && t2>-1.) { join1=1.0/(1.0+mfexp(-(50.*t2/(1.0+fabs(t2))))); // note the logit transform is not perfect, so growth near Linf will not be exactly same as with native growth function t2*=(1.-join1); // trap to prevent decrease in size-at-age } temp1 = pow((temp+growhalf*t2*Cohort_Growth(y,a)),inv_Richards); if((a0 && y==styr) { for (a=0;a<=nages;a++) { if(curr_age_beg(g,s,a)=AFIX2_forCV) {CV_G(gp,s,a)=CVLmax(gp);} else if(CV_depvar_a==0) {CV_G(gp,s,a)=CVLmin(gp) + (Ave_Size(t,0,g,a)-Lmin(gp))*CV_delta(gp);} else {CV_G(gp,s,a)=CVLmin(gp) + (curr_age_beg(g,s,a)-AFIX)*CV_delta(gp);} if(curr_age_mid(g,s,a)=AFIX2_forCV) {CV_G(gp,smid,a)=CVLmax(gp);} else if(CV_depvar_a==0) {CV_G(gp,smid,a)=CVLmin(gp) + (Ave_Size(t,1,g,a)-Lmin(gp))*CV_delta(gp);} else {CV_G(gp,smid,a)=CVLmin(gp) + (curr_age_mid(g,s,a)-AFIX)*CV_delta(gp);} } // end age loop } else { // already set constant to CVLmi } // ProgLabel_16.2.3.2.3.2 calc stddev of size-at-age from CV_G(gp,s,a) and Ave_Size(t,g,a) if(CV_depvar_b==0) { Sd_Size_within(s,g)=SD_add_to_LAA+elem_prod(CV_G(gp,s),Ave_Size(t,0,g)); Sd_Size_within(smid,g)=SD_add_to_LAA+elem_prod(CV_G(gp,smid),Ave_Size(t,1,g)); } else { Sd_Size_within(s,g)=SD_add_to_LAA+CV_G(gp,s); Sd_Size_within(smid,g)=SD_add_to_LAA+CV_G(gp,smid); } // ProgLabel_16.2.3.2.3.3 if platoons being used, calc the stddev between platoons if(N_platoon>1) { Sd_Size_between(s,g)=Sd_Size_within(s,g)*sd_between_platoon; Sd_Size_between(smid,g)=Sd_Size_within(smid,g)*sd_between_platoon; Sd_Size_within(s,g)*=sd_within_platoon; Sd_Size_within(smid,g)*=sd_within_platoon; } if(docheckup==1) { echoinput<0) } // end loop of birthseasons Ip+=MGparm_per_def; } // end loop of growth patterns, gp // end do growth } //********************************************************************* // ProgLabel_FUNCTION 17 get_natmort FUNCTION void get_natmort() { dvariable Loren_M1; dvariable Loren_temp; dvariable Loren_temp2; dvariable t_age; int Do_AveAge; Do_AveAge=0; t_base=styr+(yz-styr)*nseas-1; Ip=-MGparm_per_def; // start counter for MGparms // ProgLabel_17.1 loop growth patterns N_GP*gender for (gp=1;gp<=N_GP*gender;gp++) { if(N_natMparms>0) { // ProgLabel_17.1.1 copy parameter values from mgp_adj to natMparms(gp), doing direct or offset for gp>1 Ip+=MGparm_per_def; for(j=1;j<=N_natMparms;j++) natMparms(j,gp)=mgp_adj(Ip+j); switch(MGparm_def) // switch for natmort parms { case 1: // direct { for(j=1;j<=N_natMparms;j++) { if(natMparms(j,gp)<0) natMparms(j,gp)=natMparms(j,1); } break; } case 2: // offset { if(gp>1) { for(j=1;j<=N_natMparms;j++) { natMparms(j,gp)=natMparms(j,1)*mfexp(natMparms(j,gp)); } } break; } case 3: // offset like SS2 V1.23 { if(gp>1) natMparms(1,gp)=natMparms(1,1)*mfexp(natMparms(1,gp)); if(N_natMparms>1) { for(j=2;j<=N_natMparms;j++) { natMparms(j,gp)=natMparms(j-1,gp)*mfexp(natMparms(j,gp)); } } break; } } // end switch } // end have natmort parms g=(gp-1)*nseas*N_platoon+int(N_platoon/2)+1-N_platoon; for(birthseas=1;birthseas<=nseas;birthseas++) // loop birth seasons (really looping more morphs) { // ProgLabel_17.1.2 loop birthseasons g+=N_platoon; gg=GP3(g); // gpattern*gender*birthseason if(use_morph(g)>0) { switch(natM_type) { // ProgLabel_17.1.2.0 case 0: constant M case 0: // constant M { for(s=1;s<=nseas;s++) { natM(s,gg)=natMparms(1,gp); surv1(s,gg)=mfexp(-natMparms(1,gp)*seasdur_half(s)); // refers directly to the constant value surv2(s,gg)=square(surv1(s,gg)); } break; } // ProgLabel_17.1.2.1 case 1: N breakpoints case 1: // breakpoints { dvariable natM1; dvariable natM2; for(s=1;s<=nseas;s++) { if(s>=Bseas(g)) {a=0; t_age=azero_seas(s)-azero_G(g);} else {a=1; t_age=1.0+azero_seas(s)-azero_G(g);} natM_amax=NatM_break(1); natM2=natMparms(1,gp); k=a; for(loop=1;loop<=N_natMparms+1;loop++) { natM_amin=natM_amax; natM1=natM2; if(loop<=N_natMparms) { natM_amax=NatM_break(loop); natM2=natMparms(loop,gp); } else { natM_amax=r_ages(nages)+1.; } if(natM_amax>natM_amin) {temp=(natM2-natM1)/(natM_amax-natM_amin);} // calc the slope else {temp=0.0;} while(t_age=1;s--) { smid=s+nseas; // mid-season size-at-age is stored in season s+nseas for (a=nages; a>=0;a--) { if(a==0 && s=Bseas(g)) { k=0; t_age=azero_seas(s)-azero_G(g); for (a=k;a<=nages-1;a++) { natM(s,gg,a) = Age_NatMort(gp,a)+t_age*(Age_NatMort(gp,a+1)-Age_NatMort(gp,a)); } // end age } else { k=1; t_age=azero_seas(s)+(1.-azero_G(g)); for (a=k;a<=nages-1;a++) { natM(s,gg,a) = Age_NatMort(gp,a)+t_age*(Age_NatMort(gp,a+1)-Age_NatMort(gp,a)); } // end age natM(s,gg,0)=natM(s,gg,1); } natM(s,gg,nages)=Age_NatMort(gp,nages); surv1(s,gg)=mfexp(-natM(s,gg)*seasdur_half(s)); surv2(s,gg)=square(surv1(s,gg)); } // end season break; } } // end natM_type switch // ProgLabel_17.2 calc an ave_age for the first gp as a scaling factor in logL for initial recruitment (R1) deviation if(Do_AveAge==0) { Do_AveAge=1; ave_age = 1.0/natM(1,gg,nages/2)-0.5; } } // end use of this morph } // end birthseason } // end growth pattern x gender loop // end nat mort } //********************************************************************* /* ProgLabel_FUNCTION 18 get_recr_distribution */ FUNCTION void get_recr_distribution() { dvar_vector recr_dist_parm(1,MGP_CGD-recr_dist_parms-1); recr_dist_calc.initialize(); // ProgLabel_18.1 set rec_dist_parms = exp(mgp_adj) for this year Ip=recr_dist_parms; for(f=1;f<=MGP_CGD-recr_dist_parms-1;f++) { recr_dist_parm(f)=mfexp(mgp_adj(Ip+f)); } // ProgLabel_18.2 loop gp * birthseas * area and multiply together the recr_dist_parm values for(gp=1;gp<=N_GP;gp++) for(s=1;s<=nseas;s++) // really looping birthseas for(p=1;p<=pop;p++) if(recr_dist_pattern(gp,s,p)>0) { recr_dist_calc(gp,s,p)=femfrac(gp)*recr_dist_parm(gp)*recr_dist_parm(N_GP+p)*recr_dist_parm(N_GP+pop+s); if(gender==2) recr_dist_calc(gp+N_GP,s,p)=femfrac(gp+N_GP)*recr_dist_parm(gp)*recr_dist_parm(N_GP+p)*recr_dist_parm(N_GP+pop+s); //males } // ProgLabel_18.3 if recr_dist_interaction is chosen, then multiply these in also if(recr_dist_inx==1) { f=N_GP+nseas+pop; for(gp=1;gp<=N_GP;gp++) for(s=1;s<=nseas;s++) for(p=1;p<=pop;p++) { f++; if(recr_dist_pattern(gp,s,p)>0) { recr_dist_calc(gp,s,p)*=recr_dist_parm(f); if(gender==2) recr_dist_calc(gp+N_GP,s,p)*=recr_dist_parm(f); } } } // ProgLabel_18.4 scale the recr_dist matrix to sum to 1.0 recr_dist_calc/=sum(recr_dist_calc); } //********************************************************************* /* ProgLabel_FUNCTION 19 get_wtlenet_wtlen, maturity, fecundity, hermaphroditism */ FUNCTION void get_wtlen() { // ProgLabel_19.1 set wtlen and maturity/fecundity factors equal to annual values from mgp_adj Ip=MGparm_per_def*N_GP*gender+1; for(f=0;f<=3+2*gender;f++) {wtlen_p(f+1)=mgp_adj(Ip+f);} for(s=1;s<=nseas;s++) { // ProgLabel_19.2 loop seasons t=styr+(y-styr)*nseas+s-1; // ProgLabel_19.2.1 calc wt_at_length for each season to include seasonal effects on wtlen if(MGparm_seas_effects(1)>0 || MGparm_seas_effects(2)>0 ) // get seasonal effect on fem wtlen parameters { wt_len(s,1)=(wtlen_p(1)*wtlen_seas(s,1))*pow(len_bins_m(1,nlength),(wtlen_p(2)*wtlen_seas(s,2))); wt_len_low(s)(1,nlength)=(wtlen_p(1)*wtlen_seas(s,1))*pow(len_bins2(1,nlength),(wtlen_p(2)*wtlen_seas(s,2))); } else { wt_len(s,1) = wtlen_p(1)*pow(len_bins_m(1,nlength),wtlen_p(2)); wt_len_low(s)(1,nlength) = wtlen_p(1)*pow(len_bins2(1,nlength),wtlen_p(2)); } wt_len2(s)(1,nlength)=wt_len(s,1)(1,nlength); // ProgLabel_19.2.2 calculate maturity and fecundity if seas = spawn_seas // these calculations are done in spawn_seas, but are not affected by spawn_time within that season // so age-specific inputs will assume to be at correct timing already; size-specific will later be adjusted to use size-at-age at the exact correct spawn_time_seas if(s==spawn_seas) // get biology of maturity and fecundity { for(gp=1;gp<=N_GP;gp++) { switch(Maturity_Option) { case 1: // Maturity_Option=1 length logistic { mat_len(gp) = 1./(1. + mfexp(wtlen_p(4)*(len_bins_m(1,nlength)-wtlen_p(3)))); break; } case 2: // Maturity_Option=2 age logistic { mat_age(gp) = 1./(1. + mfexp(wtlen_p(4)*(r_ages-wtlen_p(3)))); break; } case 3: // Maturity_Option=3 read age-maturity { mat_age(gp)=Age_Maturity(gp); break; } case 4: // Maturity_Option=4 read age-fecundity, so no age-maturity { break; } case 5: // Maturity_Option=5 read age-fecundity from wtatage.ss { break; } case 6: // Maturity_Option=6 read length-maturity { mat_len(gp)=Length_Maturity(gp); break; } } if(First_Mature_Age>0) {mat_age(gp)(0,First_Mature_Age-1)=0.;} switch (Fecund_Option) { case 1: // as eggs/kg (SS original configuration) { fec_len(gp) = wtlen_p(5)+wtlen_p(6)*wt_len(s,1); fec_len(gp) = elem_prod(wt_len(s,1),fec_len(gp)); break; } case 2: { // as eggs = f(length) fec_len(gp) = wtlen_p(5)*pow(len_bins_m,wtlen_p(6)); break; } case 3: { // as eggs = f(body weight) fec_len(gp) = wtlen_p(5)*pow(wt_len(s,1),wtlen_p(6)); break; } case 4: { // as eggs = a + b*Len fec_len(gp) = wtlen_p(5) + wtlen_p(6)*len_bins_m; if(wtlen_p(5)<0.0) { z=1; while(fec_len(gp,z)<0.0) { fec_len(gp,z)=0.0; z++; } } break; } case 5: { // as eggs = a + b*Wt fec_len(gp) = wtlen_p(5) + wtlen_p(6)*wt_len(s,1); if(wtlen_p(5)<0.0) { z=1; while(fec_len(gp,z)<0.0) { fec_len(gp,z)=0.0; z++; } } break; } } // combine length maturity and fecundity; but will be ignored if reading empirical age-fecundity mat_fec_len(gp) = elem_prod(mat_len(gp),fec_len(gp)); } } // ProgLabel_19.2.3 calculate male weight_at_length if(gender==2) { if(MGparm_seas_effects(7)>0 || MGparm_seas_effects(8)>0 ) // get seasonal effect on male wt-len parameters { wt_len(s,2) = (wtlen_p(7)*wtlen_seas(s,7))*pow(len_bins_m(1,nlength),(wtlen_p(8)*wtlen_seas(s,8))); wt_len_low(s)(nlength1,nlength2) = (wtlen_p(7)*wtlen_seas(s,7))*pow(len_bins2(nlength1,nlength2),(wtlen_p(8)*wtlen_seas(s,8))); } else { wt_len(s,2) = wtlen_p(7)*pow(len_bins_m(1,nlength),wtlen_p(8)); wt_len_low(s)(nlength1,nlength2) = wtlen_p(7)*pow(len_bins2(nlength1,nlength2),wtlen_p(8)); } wt_len2(s)(nlength1,nlength2)=wt_len(s,2).shift(nlength1); wt_len(s,2).shift(1); } // ProgLabel_19.2.4 calculate first diff of wt_len for use in generalized sizp comp bin calculations wt_len_fd(s)=first_difference(wt_len_low(s)); wt_len2_sq(s)=elem_prod(wt_len2(s),wt_len2(s)); if(gender==2) wt_len_fd(s,nlength)=wt_len_fd(s,nlength-1); // ProgLabel_19.2.5 Do Hermaphroditism (no seasonality and no gp differences) // should build seasonally component here if(Hermaphro_Option>0) { dvariable infl; // inflection dvariable stdev; // standard deviation dvariable maxval; // max value for(gp=1;gp<=N_GP; gp++) { infl=mgp_adj(MGparm_Hermaphro); // inflection stdev=mgp_adj(MGparm_Hermaphro+1); // standard deviation maxval=mgp_adj(MGparm_Hermaphro+2); // max value // minval is 0.0; temp2=cumd_norm((0.0-infl)/stdev); // cum_norm at age 0 temp=maxval / (cumd_norm((r_ages(nages)-infl)/stdev)-temp2); // delta in cum_norm between styr and endyr for(a=0; a<=nages; a++) { Hermaphro_val(gp,a)=0.0 + temp * (cumd_norm((r_ages(a)-infl)/stdev)-temp2); } } } } // end wt-len and fecundity } //********************************************************************* /* ProgLabel_FUNCTION 20 get_migration */ FUNCTION void get_migration() { Ip=MGP_CGD; // start counter for movement parms // ProgLabel_20.1 loop the needed movement rates for(k=1;k<=do_migr2;k++) // loop all movement rates for this year (includes seas, morphs) { t=styr+(yz-styr)*nseas+move_def2(k,1)-1; if(k<=do_migration) { // set some movement rates same as the first movement rate if(mgp_adj(Ip+1)==-9999.) mgp_adj(Ip+1)=mgp_adj(MGP_CGD+1); if(mgp_adj(Ip+2)==-9999.) mgp_adj(Ip+2)=mgp_adj(MGP_CGD+2); // ProgLabel_20.1.1 age-specific movement strength based on parameters for selected area pairs temp=1./(move_def2(k,6)-move_def2(k,5)); temp1=temp*(mgp_adj(Ip+2)-mgp_adj(Ip+1)); for (a=0;a<=nages;a++) { if(a<=move_def2(k,5)) {migrrate(yz,k,a) = mgp_adj(Ip+1);} else if(a>=move_def2(k,6)) {migrrate(yz,k,a) = mgp_adj(Ip+2);} else {migrrate(yz,k,a) = mgp_adj(Ip+1) + (r_ages(a)-move_def2(k,5))*temp1;} } // end age loop migrrate(yz,k)=mfexp(migrrate(yz,k)); Ip+=2; } else // ProgLabel_20.1.2 default movement strength =1.0 for other area pairs { migrrate(yz,k)=1.; } } // ProgLabel_20.2 loop seasons, GP, source areas for (s=1;s<=nseas;s++) { t=styr+(yz-styr)*nseas+s-1; for(gp=1;gp<=N_GP;gp++) { for (p=1;p<=pop;p++) { tempvec_a.initialize(); // zero out the summation vector for (p2=1;p2<=pop;p2++) { // ProgLabel_20.2.1 for each destination area, adjust movement rate by season duration and sum across all destination areas k=move_pattern(s,gp,p,p2); if(k>0) { if(p2!=p && nseas>1) migrrate(yz,k)*=seasdur(move_def2(k,1)); // fraction leaving an area is reduced if the season is short tempvec_a+=migrrate(yz,k); // sum of all movement weights for the p2 fish } } //end destination area // ProgLabel_20.2.2 now normalize for all movement from source area p for (p2=1;p2<=pop;p2++) { k=move_pattern(s,gp,p,p2); if(k>0) { migrrate(yz,k)=elem_div(migrrate(yz,k),tempvec_a); // ProgLabel_20.2.3 now set rate to 0.0 (or 1.0 for stay rates) below the start age for migration if(migr_start(s,gp)>0) { if(p!=p2) { migrrate(yz,k)(0,migr_start(s,gp)-1)=0.0; } else { migrrate(yz,k)(0,migr_start(s,gp)-1)=1.0; } } } } } // end source areas loop } // end growth pattern } // end season // ProgLabel_20.2.4 copy annual migration rates forward until first year with time-varying migration rates if(yz0) { for(s=1;s<=nseas;s++) { for(k=1;k<=8;k++) { save_seas_parm(s,k)=value(wtlen_p(k)*wtlen_seas(s,k)); } save_seas_parm(s,9)=value(Lmin(1)); save_seas_parm(s,10)=value(VBK(1,nages)*VBK_seas(s)); } } } //********************************************************************* /* ProgLabel_FUNCTION 22 get_selectivity */ FUNCTION void get_selectivity() { int Ip_env; int y1; int fs; dvariable t1; dvariable t2; dvariable t3; dvariable t4; dvariable Apical_Selex; dvariable t1min; dvariable t1max; dvariable t1power; dvariable t2min; dvariable t2max; dvariable t2power; dvariable final; dvariable sel_maxL; dvariable lastsel; dvariable lastSelPoint; dvariable SelPoint; dvariable finalSelPoint; dvariable asc; dvariable dsc; dvar_vector sp(1,199); // temporary vector for selex parms // begin new section for testing cubic spline // define vectors which form the basis for cubic spline selectivity // IMPORTANT: these vectors might need to be expanded to fit values for multiple fleets dvector splineX(1,200); dvar_vector splineY(1,200); splineX.initialize(); splineY.initialize(); // end section for testing cubic spline Ip=0; // dvariable temp3; // calculate any trends that will be needed for any of the selex parameters if(y==styr && N_selparm_trend>0) { for(f=1;f<=N_selparm_trend;f++) { j=selparm_trend_rev(f); // parameter affected; would include size selex, discard, discmort, ageselex k=selparm_trend_rev_1(f); // base index for trend parameters // calc endyr value, but use logistic transform to keep with bounds of the base parameter if(selparm_1(j,13)==-1) { temp=log((selparm_1(j,2)-selparm_1(j,1)+0.0000002)/(selparm(j)-selparm_1(j,1)+0.0000001)-1.)/(-2.); // transform the base parameter temp+=selparm(k+1); // add the offset Note that offset value is in the transform space temp1=selparm_1(j,1)+(selparm_1(j,2)-selparm_1(j,1))/(1.+mfexp(-2.*temp)); // backtransform } else if(selparm_1(j,13)==-2) { temp1=selparm(k+1); // set ending value directly } if(selparm_HI(k+2)<=1.1) // use max bound as switch {temp3=r_years(styr)+selparm(k+2)*(r_years(endyr)-r_years(styr));} // infl year else {temp3=selparm(k+2);} temp2=cumd_norm((r_years(styr)-temp3)/selparm(k+3)); // cum_norm at styr temp=(temp1-selparm(j)) / (cumd_norm((r_years(endyr)-temp3)/selparm(k+3))-temp2); // delta in cum_norm between styr and endyr for(int y1=styr;y1<=endyr;y1++) { selparm_trend(f,y1)=selparm(j) + temp * (cumd_norm((r_years(y1)-temp3)/selparm(k+3) )-temp2); } } } if (N_selparm_blk>0 && y==styr) // set up the block values time series { for(j=1;j<=N_selparm;j++) { z=selparm_1(j,13); // specified block pattern if(z>0) // uses blocks { // if(y==styr) { g=1; if(selparm_1(j,14)<3) // not as offset from previous block { for(a=1;a<=Nblk(z);a++) { for(int y1=Block_Design(z,g);y1<=Block_Design(z,g+1);y1++) // loop years for this block { if(y1<=endyr) { k=Block_Defs_Sel(j,y1); // identifies parameter that holds the block effect selparm_block_val(j,y1)=selparm(k); } } g+=2; } } else // as additive offset to previous block { temp=0.0; for(a=1;a<=Nblk(z);a++) { y1=Block_Design(z,g); // first year of block k=Block_Defs_Sel(j,y1); // identifies parameter that holds the block effect temp+=selparm(k); // increment by the block delta for(int y1=Block_Design(z,g);y1<=Block_Design(z,g+1);y1++) // loop years for this block { if(y1<=endyr) selparm_block_val(j,y1)=temp; } g+=2; } } } // end block setup } // end uses blocks } // end parameter loop } // end block section if(N_selparm_dev>0 && y==styr) { for(k=1;k<=N_selparm_dev;k++) { if(selparm_dev_type(k)==3) { selparm_dev_rwalk(k,selparm_dev_minyr(k))=selparm_dev(k,selparm_dev_minyr(k)); j=selparm_dev_minyr(k); for (j=selparm_dev_minyr(k)+1;j<=selparm_dev_maxyr(k);j++) { selparm_dev_rwalk(k,j)=selparm_dev_rwalk(k,j-1)+selparm_dev(k,j); } } } } // ** Do Selectivity for (f=1;f<=2*Ntypes;f++) // loops twice, first for size then for age { fs=f-Ntypes; //index for saving age info in the fleet arrays if(time_vary_sel(y,f)==1 || save_for_report>0) { // recalculate the selex in this year x type if(N_selparmvec(f)>0) // type has parms, so look for adjustments { for(j=1;j<=N_selparmvec(f);j++) { if(selparm_1(Ip+j,13)<0) {sp(j)=selparm_trend(selparm_trend_point(Ip+j),y);} else {sp(j)=selparm(Ip+j);} } switch(selparm_adjust_method) { default: { break; } case 0: { break; } case 3: { // no break, so will do the case 1 code } case(1): { for(j=1;j<=N_selparmvec(f);j++) { if(selparm_1(Ip+j,13)>0) // uses blocks { blkparm=Block_Defs_Sel(Ip+j,y); if(blkparm>0) { k=selparm_1(Ip+j,14); if(k==0) // multiplicative {sp(j) *= mfexp(selparm_block_val(Ip+j,y));} else if(k==1) // additive {sp(j) += selparm_block_val(Ip+j,y);} else if(k==2) // replacement {sp(j) = selparm_block_val(Ip+j,y);} else if(k==3) // additive, but additions are cumulative {sp(j) += selparm_block_val(Ip+j,y);} } } if(selparm_env(Ip+j)>0) // if env then modify sp { if(selparm_envtype(Ip+j)==1) {sp(j) *= mfexp(selparm(selparm_env(Ip+j))* env_data(y,selparm_envuse(Ip+j)));} else {sp(j) += selparm(selparm_env(Ip+j))* env_data(y,selparm_envuse(Ip+j));} } k=selparm_dev_select(Ip+j); // if dev then modify sp if(k>0) { if(y>=selparm_dev_minyr(k) && y<=selparm_dev_maxyr(k)) { if(selparm_dev_type(k)==1) {sp(j) *= mfexp(selparm_dev(k,y));} else if(selparm_dev_type(k)==2) {sp(j) += selparm_dev(k,y);} else if(selparm_dev_type(k)==3) {sp(j)+=selparm_dev_rwalk(k,y);} } } if(selparm_adjust_method==1 && (save_for_report>0 || do_once==1)) // so does not check bounds if adjust_method==3 { if(sp(j)selparm_1(Ip+j,2)) { N_warn++; warning<<" adjusted selparm out of bounds (Parm#, yr, min, max, base, value) "<< Ip+j<<" "<0) // blocks { blkparm=Block_Defs_Sel(Ip+j,y); // identifies parameter that holds the block effect if(blkparm>0) { k=selparm_1(Ip+j,14); doit=1; if(k==1) {temp += selparm_block_val(Ip+j,y);} else if (k==2) // replacement {temp=log((selparm_1(Ip+j,2)-selparm_1(Ip+j,1)+0.0000002)/(selparm_block_val(Ip+j,y)-selparm_1(Ip+j,1)+0.0000001)-1.)/(-2.);} // block as replacement else if(k==3) // additive, but based on cumulative blocks {temp += selparm_block_val(Ip+j,y);} else {N_warn++; warning<<" disabled multiplicative block effect with logistic approach"<0) // do environmental effect only additive allowed {doit=1;temp += selparm(selparm_env(Ip+j))* env_data(y,selparm_envuse(Ip+j));} k=selparm_dev_select(Ip+j); // Annual deviations; use kth dev series if(k>0) { if(y>=selparm_dev_minyr(k) && y<=selparm_dev_maxyr(k)) { doit=1; if(selparm_dev_type(k)==2) {temp += selparm_dev(k,y);} else if(selparm_dev_type(k)==3) {temp += selparm_dev_rwalk(k,y);} } } if(doit==1) sp(j)=selparm_1(Ip+j,1)+(selparm_1(Ip+j,2)-selparm_1(Ip+j,1))/(1+mfexp(-2.*temp)); // backtransform } // end parameter loop j break; } } if(save_for_report>0 || do_once==1) {for(j=1;j<=N_selparmvec(f);j++) save_sp_len(y,f,j)=sp(j);} } // end adjustment of parms if(f<=Ntypes) // do size selectivity, retention, discard mort { if(docheckup==1 && N_selparmvec(f)>0) echoinput<<"length selex parms: "<=3)) { switch(seltype(f,1)) // select the selectivity pattern { case 0: // *********** constant {sel = 1.;break;} case 1: // *********** logistic ProgLabel_055 { if(seltype(f,3)<3 || (gg==1 && seltype(f,3)==3) || (gg==2 && seltype(f,3)==4)) // do the primary gender {sel = 1./(1.+mfexp(neglog19*(len_bins_m-sp(1))/sp(2)));} else // do the offset gender { temp=sp(1)+sp(Maleselparm(f)); temp1=sp(2)+sp(Maleselparm(f)+1); sel = sp(Maleselparm(f)+2)/(1.+mfexp(neglog19*(len_bins_m-temp)/temp1)); } break; } case 2: // *******double logistic ProgLabel_056 { // 1=peak, 2=init, 3=infl, 4=slope, 5=final, 6=infl2, 7=slope2 N_warn++; cout<<" EXIT - see warning "<nlength) {N_warn++; cout<<" EXIT - see warning "<1) sel(1,k1-1) = 0.0; sel(k1,nlength) = elem_prod( (1/(1+mfexp(-sp(2)*(len_bins_m(k1,nlength)-sp(1)) ))), (1-1/(1+mfexp(-sp(4)*(len_bins_m(k1,nlength)-(sp(1)*sp(6)+sp(3))) ))) ); sel += 1.0e-6; sel /= max(sel); break; } //*********************************** case 21: // *******New non-parametric { j=1; z=1; k=seltype(f,4); // n points lastsel=0.0; lastSelPoint=0.0; if(do_once==1) { if(sp(k)>len_bins(nlength)) {N_warn++; cout<<" EXIT - see warning "< max_pop_lenbin"<len_bins(nlength-1)) {N_warn++; warning<<"Selex21: should not have selpoint(n-1) > pop_lenbin(nlength-1)"<1.0 { // if(gg==1 || seltype(f,3)<3) if(seltype(f,3)<3 || (gg==1 && seltype(f,3)==3) || (gg==2 && seltype(f,3)==4)) {peak=sp(1); upselex=mfexp(sp(3)); downselex=mfexp(sp(4)); final=sp(6);} else { // offset male parameters if seltype(f,3)==3 peak=sp(1)+sp(Maleselparm(f)); upselex=mfexp(sp(3)+sp(Maleselparm(f)+1)); downselex=mfexp(sp(4)+sp(Maleselparm(f)+2)); if(sp(6)>-999.) final=sp(6)+sp(Maleselparm(f)+3); } if(sp(5)<-1000.) { j1=-1001-int(value(sp(5))); // selex is nil thru bin j1, so set sp(5) equal to first bin with selex (e.g. -1002 to start selex at bin 2) sel(1,j1)=1.0e-06; } else { j1=startbin-1; // start selex at bin equal to min sizecomp databin (=j1+1) if(sp(5)>-999) { point1=1.0/(1.0+mfexp(-sp(5))); t1min=mfexp(-(square(len_bins_m(startbin)-peak)/upselex)); // fxn at first bin } } if(sp(6)<-1000.) { j2=-1000-int(value(sp(6))); // selex is constant beyond this sizebin, so set sp(6) equal to last bin with estimated selex } else {j2=nlength;} peak2=peak+binwidth2+ (0.99*len_bins_m(j2)-peak-binwidth2)/(1.+mfexp(-sp(2))); if(sp(6)>-999) { point2=final; t2min=mfexp(-(square(len_bins_m(j2)-peak2)/downselex)); // fxn at last bin } for(j=j1+1;j<=j2;j++) { t1=len_bins_m(j)-peak; t2=len_bins_m(j)-peak2; join1=1.0/(1.0+mfexp(-(20.*t1/(1.0+fabs(t1))))); // note the logit transform on t1 causes range of mfexp to be over -20 to 20 join2=1.0/(1.0+mfexp(-(20.*t2/(1.0+fabs(t2))))); if(sp(5)>-999) {asc=point1+(1.0-point1)*(mfexp(-square(t1)/upselex)-t1min)/(1.0-t1min);} else {asc=mfexp(-square(t1)/upselex);} if(sp(6)>-999) {dsc=1.0+(point2-1.0)*(mfexp(-square(t2)/downselex)-1.0 )/(t2min-1.0);} else {dsc=mfexp(-square(t2)/downselex);} sel(j)=asc*(1.0-join1)+join1*(1.0-join2+dsc*join2); } if(startbin>1 && sp(5)>=-1000.) { for(j=1;j<=startbin-1;j++) { sel(j)=square(len_bins_m(j)/len_bins_m(startbin))*sel(startbin); } } if(j2-999.) final=sp(6)+sp(Maleselparm(f)+3); Apical_Selex=sp(Maleselparm(f)+4); } if(sp(5)<-1000.) { j1=-1001-int(value(sp(5))); // selex is nil thru bin j1, so set sp(5) equal to first bin with selex (e.g. -1002 to start selex at bin 2) sel(1,j1)=1.0e-06; } else { j1=startbin-1; // start selex at bin equal to min sizecomp databin (=j1+1) if(sp(5)>-999) { point1=1.0/(1.0+mfexp(-sp(5))); t1min=mfexp(-(square(len_bins_m(startbin)-peak)/upselex)); // fxn at first bin } } if(sp(6)<-1000.) { j2=-1000-int(value(sp(6))); // selex is constant beyond this sizebin, so set sp(6) equal to last bin with estimated selex } else {j2=nlength;} peak2=peak+binwidth2+ (0.99*len_bins_m(j2)-peak-binwidth2)/(1.+mfexp(-sp(2))); if(sp(6)>-999) { point2=1.0/(1.0+mfexp(-final)); t2min=mfexp(-(square(len_bins_m(j2)-peak2)/downselex)); // fxn at last bin } for(j=j1+1;j<=j2;j++) { t1=len_bins_m(j)-peak; t2=len_bins_m(j)-peak2; join1=1.0/(1.0+mfexp(-(20.*t1/(1.0+fabs(t1))))); // note the logit transform on t1 causes range of mfexp to be over -20 to 20 join2=1.0/(1.0+mfexp(-(20.*t2/(1.0+fabs(t2))))); if(sp(5)>-999) {asc=point1+(Apical_Selex-point1)*(mfexp(-square(t1)/upselex)-t1min)/(1.0-t1min);} else {asc=Apical_Selex*mfexp(-square(t1)/upselex);} if(sp(6)>-999) {dsc=Apical_Selex+(point2-Apical_Selex)*(mfexp(-square(t2)/downselex)-1.0 )/(t2min-1.0);} else {dsc=Apical_Selex*mfexp(-square(t2)/downselex);} sel(j)=asc*(1.0-join1)+join1*(Apical_Selex*(1.0-join2)+dsc*join2); } if(startbin>1 && sp(5)>=-1000.) { for(j=1;j<=startbin-1;j++) { sel(j)=square(len_bins_m(j)/len_bins_m(startbin))*sel(startbin); } } if(j2splineX(k)) {z--;} j2=z+1; // first size bin beyond last node vcubic_spline_function splinefn=vcubic_spline_function(splineX(1,k),splineY(1,k),sp(2),sp(3)); tempvec_l = splinefn(len_bins_m); // interpolate selectivity at the mid-point of each population size bin temp=max(tempvec_l(1,j2)); tempvec_l-=temp; // rescale to get max of 0.0 tempvec_l(j2+1,nlength) = tempvec_l(j2); // set constant above last node sel = mfexp(tempvec_l); break; } case 30: { sel=1.0; break; } case 31: { sel=1.0; break; } case 32: { sel=1.0; break; } case 33: { sel=1.0; break; } case 34: { sel=1.0; break; } default: // seltype not found. But really need this check earlier when the N selex parameters are being processed. { N_warn++; cout<<"Critical error, see warning"<0) k+=seltype(f,2)*4; // first gender offset parm (skip over the retention parameters // if(seltype(f,1)==6) k += seltype(f,4); // for non-parametric in which N parm is stored in special column k=Maleselparm(f); temp=sp(k); temp1=1.; switch(seltype(f,3)) { case 1: { // do males relative to females for(j=1;j<=nlength;j++) { if(len_bins_m(j)<=temp) {sel(j)*=mfexp(sp(k+1)+(len_bins_m(j)-minL_m)/(temp-minL_m) * (sp(k+2)-sp(k+1)) );} else {sel(j)*=mfexp(sp(k+2)+(len_bins_m(j)-temp) /(maxL-temp) * (sp(k+3)-sp(k+2)) );} // if(sel(j)>temp1) temp1=sel(j); } sel_l(y,f,2)=sel; tempvec_a(1)=max(sel_l(y,f,1)); tempvec_a(2)=max(sel_l(y,f,2)); temp1=max(tempvec_a(1,2)); sel_l(y,f) /=temp1; break; } case 2: { // do females relative to males sel_l(y,f,2)=sel; for(j=1;j<=nlength;j++) { if(len_bins_m(j)<=temp) {sel(j)*=mfexp(sp(k+1)+(len_bins_m(j)-minL_m)/(temp-minL_m) * (sp(k+2)-sp(k+1)) );} else {sel(j)*=mfexp(sp(k+2)+(len_bins_m(j)-temp) /(maxL-temp) * (sp(k+3)-sp(k+2)) );} // if(sel(j)>temp1) temp1=sel(j); } sel_l(y,f,1)=sel; tempvec_a(1)=max(sel_l(y,f,1)); tempvec_a(2)=max(sel_l(y,f,2)); temp1=max(tempvec_a(1,2)); sel_l(y,f)/=temp1; break; } } // end switch } // end do gender selex as offset from other gender else if(seltype(f,3)!=3 && seltype(f,3)!=4) { sel_l(y,f,2)=sel; // set males = females, but also will set male selex to calculated selex if seltype(f,3)==3 } } // end doing males } // end loop of genders if(docheckup==1) echoinput<<"length selex: "<0) echoinput<<" age selex parms: "<=3)) // in age selex { switch(seltype(f,1)) { case 0: // constant age-specific selex {sel_a(y,fs,1)(0,nages)=1.00; break;} case 10: // constant age-specific selex {sel_a(y,fs,1)(1,nages)=1.00; break;} // change with version 1.21 to omit age 0 case 11: // selex=1.0 within a range of ages { a=int(value(sp(2))); if(a>nages) {a=nages;} sel_a(y,fs,1)(int(value(sp(1))),a)=1.; break; } case 12: // *********** logistic ProgLabel_055 { sel_a(y,fs,1) = 1/(1+mfexp(neglog19*(r_ages-sp(1))/sp(2))); break;} case 13: // *******double logistic ProgLabel_056 // 1=peak, 2=init, 3=infl, 4=slope, 5=final, 6=infl2, 7=slope2 { t1=0.+(1./(1.+mfexp(-sp(3))))*(sp(1)-0.); // INFL t1min=1./(1.+mfexp(-sp(4)*(0.-t1)))*0.9999999; // asc value at minage t1max=1./(1.+mfexp(-sp(4)*(sp(1)-t1)))*1.00001; // asc value at peak t1power=log(0.5)/log((0.5-t1min)/(t1max-t1min)); t2=(sp(1)+sp(8))+(1./(1.+mfexp(-sp(6))))*(r_ages(nages)-(sp(1)+sp(8))); // INFL t2min=1./(1.+mfexp(-sp(7)*(sp(1)+sp(8)-t2)))*0.9999; // asc value at peak+ t2max=1./(1.+mfexp(-sp(7)*(r_ages(nages)-t2)))*1.00001; // asc value at maxage t2power=log(0.5)/log((0.5-t2min)/(t2max-t2min)); final=1./(1.+mfexp(-sp(5))); k1=int(value(sp(1))); k2=int(value(sp(1)+sp(8))); for (a=0; a<=nages; a++) //calculate the value over ages { if (a < k1) // ascending limb { sel_a(y,fs,1,a) = sp(2) + (1. - sp(2)) * pow((( 1./(1.+mfexp(-sp(4)*(r_ages(a)-t1))) -t1min ) / (t1max-t1min) ),t1power); } else if (a > k2) // descending limb { sel_a(y,fs,1,a) = 1. + (final - 1.) * pow((( 1./(1.+mfexp(-sp(7)*(r_ages(a)-t2))) -t2min ) / (t2max-t2min) ),t2power); } else // at the peak { sel_a(y,fs,1,a) = 1.0;} } // end age loop break; } // end double logistic case 14: // separate parm for each age { temp=9.-max(sp(1,nages+1)); // this forces at least one age to have selex weight equal to 9 for (a=0;a<=nages;a++) { if(sp(a+1)>-999) {sel_a(y,fs,1,a) = 1./(1.+mfexp(-(sp(a+1)+temp)));} else {sel_a(y,fs,1,a) = sel_a(y,fs,1,a-1);} } break; } case 15: // mirror another selex // must refer to a lower numbered type (f) { sel_a(y,fs)=sel_a(y,seltype(f,4)); break; } case 16: // Coleraine - Gaussian { t1 = 1/(1+mfexp(-sp(1)))*nages; for (a=0;a<=nages;a++) { if(a-999.) {lastsel=sp(a+1);} // so, lastsel stays constant until changed, so could create a linear change in ln(selex) // use of (a+1) is because the first element, sp(1), is for age zero tempvec_a(a)=tempvec_a(a-1)+lastsel; // cumulative log(selex) } temp=max(tempvec_a); // find max so at least one age will have selex=1. sel_a(y,fs,1)=mfexp(tempvec_a-temp); a=0; while(sp(a+1)==-1000) // reset range of young ages to selex=0.0 { sel_a(y,fs,1,a)=0.0; a++; } if(lastage0) {sel_a(y,fs,1,a)=sel_a(y,fs,1,a-1);} else {sel_a(y,fs,1,a)=0.0;} } } break; } case 18: // *******double logistic with smooth transition // 1=peak, 2=init, 3=infl, 4=slope, 5=final, 6=infl2, 7=slope2 { t1=0.+(1./(1.+mfexp(-sp(3))))*(sp(1)-0.); // INFL t1min=1./(1.+mfexp(-sp(4)*(0.-t1)))*0.9999; // asc value at minsize t1max=1./(1.+mfexp(-sp(4)*(sp(1)-t1)))*1.00001; // asc value at peak t1power=log(0.5)/log((0.5-t1min)/(t1max-t1min)); t2=(sp(1)+sp(8))+(1./(1.+mfexp(-sp(6))))*(r_ages(nages)-(sp(1)+sp(8))); // INFL t2min=1./(1.+mfexp(-sp(7)*(sp(1)+sp(8)-t2)))*0.9999; // asc value at peak+ t2max=1./(1.+mfexp(-sp(7)*(r_ages(nages)-t2)))*1.00001; // asc value at maxage t2power=log(0.5)/log((0.5-t2min)/(t2max-t2min)); final=1./(1.+mfexp(-sp(5))); for (a=0; a<=nages; a++) //calculate the value over ages { sel_a(y,fs,1,a) = ( ( (sp(2) + (1.-sp(2)) * pow((( 1./(1.+mfexp(-sp(4)*(r_ages(a)-t1)))-t1min)/ (t1max-t1min)),t1power)) /(1.0+mfexp(30.*(r_ages(a)-sp(1)))) // scale ascending side + 1./(1.+mfexp(-30.*(r_ages(a)-sp(1)))) // flattop, with scaling ) /(1.+mfexp( 30.*(r_ages(a)-(sp(1)+sp(8))))) // scale combo of ascending and flattop + (1. + (final - 1.) * pow(fabs((( 1./(1.+mfexp(-sp(7)*(r_ages(a)-t2))) -t2min ) / (t2max-t2min) )),t2power)) /(1.+mfexp( -30.*(r_ages(a)-(sp(1)+sp(8))))) // scale descending ); } // end age loop break; } // end double logistic with smooth transition case 19: // *********** old double logistic TAG_069 { k1=int(value(sp(5))); sel_a(y,fs,1)(k1,nages) = elem_prod((1./(1.+mfexp(-sp(2)*(r_ages(k1,nages)-sp(1)) ))), (1.-1./(1.+mfexp(-sp(4)*(r_ages(k1,nages)-(sp(1)*sp(6)+sp(3))) ))) ); sel_a(y,fs,1)(k1,nages) /= max(sel_a(y,fs,1)(k1,nages)); if(k1>0) sel_a(y,fs,1)(0,k1-1)=1.0e-6; break; } // *************************************** case 20: // *******double_normal_plateau { if(seltype(f,3)<3 || (gg==1 && seltype(f,3)==3) || (gg==2 && seltype(f,3)==4)) {peak=sp(1); upselex=mfexp(sp(3)); downselex=mfexp(sp(4)); final=sp(6); Apical_Selex=1.0;} else { // offset male parameters if seltype(f,3)==3 peak=sp(1)+sp(Maleselparm(f)); upselex=mfexp(sp(3)+sp(Maleselparm(f)+1)); downselex=mfexp(sp(4)+sp(Maleselparm(f)+2)); if(sp(6)>-999.) final=sp(6)+sp(Maleselparm(f)+3); Apical_Selex=sp(Maleselparm(f)+4); } if(sp(5)<-1000.) { j=-1001-int(value(sp(5))); // selex is nil thru age j, so set sp(5) equal to first age with selex (e.g. -1002 to start selex at age 2) sel_a(y,fs,gg)(0,j)=1.0e-06; } else { j=-1; // start selex at age 0 if(sp(5)>-999) { point1=1./(1.+mfexp(-sp(5))); t1min=mfexp(-(square(0.-peak)/upselex)); // fxn at first bin } } if(sp(6)<-1000.) { j2=-1000-int(value(sp(6))); // selex is constant beyond this age, so set sp(6) equal to last age with estimated selex // (e.g. -1008 to be constant beyond age 8) } else {j2=nages;} peak2=peak+1.+(0.99*r_ages(j2)-peak-1.)/(1.+mfexp(-sp(2))); // note, this uses age=j2 as constraint on range of "peak2" // peak2=peak+.1+(0.99*r_ages(j2)-peak-.1)/(1.+mfexp(-sp(2))); // note, this uses age=j2 as constraint on range of "peak2" if(sp(6)>-999) { point2=1./(1.+mfexp(-final)); t2min=mfexp(-(square(r_ages(nages)-peak2)/downselex)); // fxn at last bin } for(a=j+1;a<=j2;a++) { t1=r_ages(a)-peak; t2=r_ages(a)-peak2; join1=1./(1.+mfexp(-(20./(1.+fabs(t1)))*t1)); join2=1./(1.+mfexp(-(20./(1.+fabs(t2)))*t2)); if(sp(5)>-999) {asc=point1+(Apical_Selex-point1)*(mfexp(-square(t1)/upselex )-t1min)/(1.-t1min);} else {asc=Apical_Selex*mfexp(-square(t1)/upselex);} if(sp(6)>-999) {dsc=Apical_Selex+(point2-Apical_Selex)*(mfexp(-square(t2)/downselex)-1. )/(t2min-1.);} else {dsc=Apical_Selex*mfexp(-square(t2)/downselex);} sel_a(y,fs,gg,a)=asc*(1.-join1)+join1*(Apical_Selex*(1.-join2)+dsc*join2); } if(j2splineX(k)) {z--;} j2=z+1; // first age beyond last node vcubic_spline_function splinefn=vcubic_spline_function(splineX(1,k),splineY(1,k),sp(2),sp(3)); tempvec_a= splinefn(r_ages); // interpolate selectivity at each age temp=max(tempvec_a(0,j2)); tempvec_a-=temp; // rescale to get max of 0.0 tempvec_a(j2+1,nages) = tempvec_a(j2); // set constant above last node sel_a(y,fs,1)=mfexp(tempvec_a); break; } default: // seltype not found. But really need this check earlier when the N selex parameters are being processed. { N_warn++; cout<<"Critical error, see warning"<temp1) temp1=sel_a(y,fs,2,a); } tempvec_a(1)=max(sel_a(y,fs,1)); tempvec_a(2)=max(sel_a(y,fs,2)); temp1=max(tempvec_a(1,2)); sel_a(y,fs)/=temp1; break; } case 2: { // do females relative to males sel_a(y,fs,2)=sel_a(y,fs,1); for(a=0;a<=nages;a++) // { if(r_ages(a)<=temp) {sel_a(y,fs,1,a)=sel_a(y,fs,2,a)*mfexp(sp(k+1)+(r_ages(a)-0.) /(temp-0.) * (sp(k+2)-sp(k+1)) );} else {sel_a(y,fs,1,a)=sel_a(y,fs,2,a)*mfexp(sp(k+2)+(r_ages(a)-temp) /(double(nages)-temp) * (sp(k+3)-sp(k+2)) );} // if(sel_a(y,fs,1,a)>temp1) temp1=sel_a(y,fs,1,a); } // sel_a(y,fs)/=temp1; tempvec_a(1)=max(sel_a(y,fs,1)); tempvec_a(2)=max(sel_a(y,fs,2)); temp1=max(tempvec_a(1,2)); sel_a(y,fs)/=temp1; break; } } } else if(seltype(f,3)!=3 && seltype(f,3)!=4 && seltype(f,1)!=15) { sel_a(y,fs,2)=sel_a(y,fs,1); } // set males = females } } // end gender if(docheckup==1) echoinput<<" age selex: "<=F_setup(2) || (readparfile==1 && current_phase()<=1)) // set Hrate = Frate parameters on first call if readparfile=1, or for advanced phases { g=0; for(f=1;f<=Nfleet;f++) for(t=styr;t<=TimeMax;t++) { g++; Hrate(f,t)=F_rate(g); } } } // Initial size-at-age distribution ProgLabel_091 y=styr; yz=styr; // t_base=styr+(y-styr)*nseas-1; t_base=styr-1; if(MG_active(0)>0 || save_for_report>0) get_MGsetup(); if(do_once==1) cout<<" MG setup OK "<0) get_growth1(); // seasonal effects and CV if(do_once==1) cout<<" growth OK"<0 || save_for_report>0) { get_growth2(); // do growth before natmort in case lorensen M is used } if(do_once==1) cout<<" growth-2 OK"<0) get_natmort(); if(do_once==1) cout<<" natmort OK"<0) get_wtlen(); if(MG_active(4)>0) get_recr_distribution(); if(MG_active(5)>0) get_migration(); if(do_once==1) cout<<" migr OK"<0) { if(MG_active(6)>0) get_age_age(Use_AgeKeyZero,AgeKey_StartAge,AgeKey_Linear1,AgeKey_Linear2); // call function to get the age_age key if(do_once==1) cout<<" ageerr_key OK"<0) get_saveGparm(); if(do_once==1) cout<<" growth OK, ready to call selex "<0 || MG_active(3)>0 || save_for_report>0 || WTage_rd>0) Make_AgeLength_Key(); for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { Make_FishSelex(); } } virg_fec = fec; if(do_once==1) cout<<" ready for virgin age struc "<0) { Mgmt_quant(2)=totbio; Mgmt_quant(3)=smrybio; Mgmt_quant(4)=Recr_virgin; } SPB_pop_gp(eq_yr)=SPB_equil_pop_gp; // dimensions of pop x N_GP if(Hermaphro_Option>0) MaleSPB(eq_yr)=MaleSPB_equil_pop_gp; SPB_yr(eq_yr)=SPB_equil; SPB_B_yr(eq_yr)=equ_mat_bio; SPB_N_yr(eq_yr)=equ_mat_num; t=styr-2*nseas-1; for(p=1;p<=pop;p++) for(g=1;g<=gmorph;g++) for(s=1;s<=nseas;s++) {natage(t+s,p,g)(0,nages)=value(equ_numbers(s,p,g)(0,nages));} //**************************************************************************** //Initial Age Structure; in equilibrium with init_equ_catch ProgLabel_093 if(do_once==1) cout<<" ready for initial age struc "<-999) // using the PR_type as a flag { // do initial equilibrium while maintain R1 based on offset from Recr_virgin R1_exp=Recr_virgin; exp_rec(eq_yr,1)=R1_exp; if(SR_env_target==2) {R1_exp*=mfexp(SR_parm(N_SRparm2-2)* env_data(eq_yr,SR_env_link));} exp_rec(eq_yr,2)=R1_exp; exp_rec(eq_yr,3)=R1_exp; R1 = R1_exp*mfexp(SR_parm(N_SRparm2-1)); exp_rec(eq_yr,4)=R1; equ_Recr=R1; // value to use in Do_Equil_Calc Do_Equil_Calc(); CrashPen += Equ_penalty; } else { // do initial equilibrium with R1 based on offset from spawner-recruitment curve, using same approach as the benchmark calculations // first get SPR for this init_F equ_Recr=Recr_virgin; Do_Equil_Calc(); CrashPen += Equ_penalty; SPR_temp=SPB_equil/equ_Recr; // spawners per recruit at initial F // next the rquilibrium SSB and recruitment from SPR_temp Get_EquilCalc = Equil_Spawn_Recr_Fxn(); // returns 2 element vector containing equilibrium biomass and recruitment at this SPR R1_exp=Get_EquilCalc(2); // set the expected recruitment equal to this equilibrium exp_rec(eq_yr,1)=R1_exp; if(SR_env_target==2) {R1_exp*=mfexp(SR_parm(N_SRparm2-2)* env_data(eq_yr,SR_env_link));} // adjust for environment exp_rec(eq_yr,2)=R1_exp; exp_rec(eq_yr,3)=R1_exp; equ_Recr = R1_exp*mfexp(SR_parm(N_SRparm2-1)); // apply R1 offset R1=equ_Recr; exp_rec(eq_yr,4)=equ_Recr; Do_Equil_Calc(); // calculated SPB_equil CrashPen += Equ_penalty; } SPB_pop_gp(eq_yr)=SPB_equil_pop_gp; // dimensions of pop x N_GP if(Hermaphro_Option>0) MaleSPB(eq_yr)=MaleSPB_equil_pop_gp; SPB_yr(eq_yr)=SPB_equil; SPB_yr(styr)=SPB_equil; SPB_B_yr(eq_yr)=equ_mat_bio; SPB_N_yr(eq_yr)=equ_mat_num; SPB_B_yr(styr)=equ_mat_bio; SPB_N_yr(styr)=equ_mat_num; for(f=1;f<=Nfleet;f++) { if(catchunits(f)==1) { est_equ_catch(f)=equ_catch_fleet(f,2); } else { est_equ_catch(f)=equ_catch_fleet(f,5); } } t=styr-nseas-1; if(save_for_report>0) { for(f=1;f<=Nfleet;f++) { catch_fleet(t+1,f)=equ_catch_fleet(f); // gets all 6 elements for(g=1;g<=gmorph;g++) for(s=1;s<=nseas;s++) {catage(t+s,f,g)=value(equ_catage(s,f,g)); } } } for(p=1;p<=pop;p++) for(g=1;g<=gmorph;g++) for(s=1;s<=nseas;s++) {natage(t+s,p,g)(0,nages)=equ_numbers(s,p,g)(0,nages);} natage(styr) = natage(t+1); if(docheckup==1) echoinput<<" init age comp"<=1; a--) { j=styr-a; natage(styr,p,g,a) *=mfexp(recdev(j)-biasadj(j)*half_sigmaRsq); } } // note: the above keeps SPB_pop_gp(styr) = SPB_equil. It does not adjust for initial agecomp, but probably should } //********************************************************************* /* ProgLabel_FUNCTION 24 get_time_series */ FUNCTION void get_time_series() { dvar_vector pre_AL(1,nlength); dvariable crashtemp; dvariable crashtemp1; dvariable Z_adjuster2; dvariable Z_adjuster; if(Do_Morphcomp) Morphcomp_exp.initialize(); //loop over time SPB_current = SPB_yr(styr); // need these initial assignments in case recruitment distribution occurs before spawnbio&recruits if(recdev_doit(styr-1)>0) { Recruits = R1 * mfexp(recdev(styr-1)-biasadj(styr-1)*half_sigmaRsq); } else { Recruits = R1;} for (y=styr;y<=endyr;y++) { yz=y; if(STD_Yr_Reverse_F(y)>0) F_std(STD_Yr_Reverse_F(y))=0.0; t_base=styr+(y-styr)*nseas-1; if(y>styr) { if(time_vary_MG(y,0)>0 || save_for_report>0) get_MGsetup(); // if(time_vary_MG(y,2)>0 || save_for_report>0) get_growth2(); // do growth before natmort in case lorensen M is used if(time_vary_MG(y,2)>0) { get_growth2(); // do growth before natmort in case lorensen M is used } if(time_vary_MG(y,1)>0) get_natmort(); if(time_vary_MG(y,3)>0) get_wtlen(); if(time_vary_MG(y,4)>0) get_recr_distribution(); if(time_vary_MG(y,5)>0) get_migration(); if(save_for_report>0) { if(time_vary_MG(y,1)>0 || time_vary_MG(y,2)>0 || time_vary_MG(y,3)>0) { get_saveGparm(); } } get_selectivity(); } // ProgLabel_ calculate average recruitment distributions to use in benchmark and forecast (V3.24P; Apr 24, 2013) if(y>=Bmark_Yr(1) && y<=Bmark_Yr(2)) { if(y==Bmark_Yr(1)) {recr_dist_benchmark.initialize();} for(gp=1;gp<=gender*N_GP;gp++) for(s=1;s<=nseas;s++) for(p=1;p<=pop;p++) { recr_dist_benchmark(gp,s,p)+=recr_dist_calc(gp,s,p); } if(y==Bmark_Yr(2)) {recr_dist_benchmark/=float(Bmark_Yr(2)-Bmark_Yr(1)+1.0);} } if(y>=Fcast_yr(1) && y<=Fcast_yr(2)) { if(y==Fcast_yr(1)) {recr_dist_forecast.initialize();} for(gp=1;gp<=gender*N_GP;gp++) for(s=1;s<=nseas;s++) for(p=1;p<=pop;p++) { recr_dist_forecast(gp,s,p)+=recr_dist_calc(gp,s,p); } if(y==Fcast_yr(2)) {recr_dist_forecast/=float(Fcast_yr(2)-Fcast_yr(1)+1.0);} } for (s=1;s<=nseas;s++) { t = t_base+s; smid=s+nseas; // if (do_once==1) cout<<" year, seas "<0 || time_vary_MG(y,3)>0 || save_for_report==1 || WTage_rd>0) // ProgLabel_102 { Make_AgeLength_Key(); // indexed by season and gmorph } if(y>styr) // because styr is done as part of initial conditions { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) {Make_FishSelex();} if(do_once==1 || MG_active(2)>0 || MG_active(3)>0) { Save_Wt_Age(t)=Wt_Age_beg(s); } } if(s==1) // calc some Smry_Table quantities that could be needed for exploitation rate calculations, but recalc these in the time_series report section { Smry_Table(y,2)=0.0; Smry_Table(y,3)=0.0; for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { for(p=1;p<=pop;p++) { Smry_Table(y,2)+=natage(t,p,g)(Smry_Age,nages)*Save_Wt_Age(t,g)(Smry_Age,nages); Smry_Table(y,3)+=sum(natage(t,p,g)(Smry_Age,nages)); //sums to accumulate across submorphs and birthseasons } } } // Compute spawning biomass if(s==spawn_seas && spawn_time_seas<0.0001) // compute spawning biomass if spawning at beginning of season so recruits could occur later this season { SPB_pop_gp(y).initialize(); SPB_B_yr(y).initialize(); SPB_N_yr(y).initialize(); for (p=1;p<=pop;p++) { for (g=1;g<=gmorph;g++) if(sx(g)==1 && use_morph(g)>0) // female { SPB_pop_gp(y,p,GP4(g)) += fec(g)*natage(t,p,g); // accumulates SSB by area and by growthpattern SPB_B_yr(y) += make_mature_bio(GP4(g))*natage(t,p,g); SPB_N_yr(y) += make_mature_numbers(GP4(g))*natage(t,p,g); } } SPB_current=sum(SPB_pop_gp(y)); SPB_yr(y)=SPB_current; if(Hermaphro_Option>0) // get male biomass { temp=0.0; MaleSPB(y).initialize(); for (p=1;p<=pop;p++) { for (g=1;g<=gmorph;g++) if(sx(g)==2 && use_morph(g)>0) // male; all assumed to be mature { MaleSPB(y,p,GP4(g)) += Save_Wt_Age(t,g)*natage(t,p,g); // accumulates SSB by area and by growthpattern temp += sum(natage(t,p,g)); } } if(Hermaphro_maleSPB==1) // add MaleSPB to female SSB { SPB_current+=sum(MaleSPB(y)); SPB_yr(y)=SPB_current; SPB_B_yr(y) += sum(MaleSPB(y)); SPB_N_yr(y) += temp; } } Recruits=Spawn_Recr(SPB_current); // calls to function Spawn_Recr } else { // spawning biomass and total recruits will be calculated later so they can use Z } // distribute Recruitment of age 0 fish among the pops and gmorphs // uses the most recent calculation of total recruits for (g=1;g<=gmorph;g++) if(use_morph(g)>0 && s==Bseas(g)) { for (p=1;p<=pop;p++) { natage(t,p,g,0) = Recruits*recr_dist_calc(GP(g),s,p)*submorphdist(GP2(g));} } for (p=1;p<=pop;p++) //loop over populations ProgLabel_104 { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { Nmid(g) = elem_prod(natage(t,p,g),surv1(s,GP3(g))); // get numbers-at-age(g,a) surviving to middle of time period if(docheckup==1) echoinput<0) { gg=sx(g); // ProgLabel_107 // use sel_l to get total catch and use sel_l_r to get retained vbio // note that vbio in numbers can be used for both survey abund and fishery available "biomass" // vbio is for retained catch only; harvest rate = retainedcatch/vbio; // then harvestrate*catage_w = total kill by this fishery for this morph catage_w(g)=elem_prod(Nmid(g),deadfish(s,g,f)); // total kill numbers at age if(docheckup==1) echoinput<<"killrate "<=2) {cout<0) { catage_w(g) *= harvest_rate; // Total catch at age catage_tot(g) += catage_w(g); //catch at age for all fleets gg=sx(g); catch_fleet(t,f,2)+=Hrate(f,t)*Nmid(g)*deadfish_B(s,g,f); // total fishery kill in biomass catch_fleet(t,f,5)+=Hrate(f,t)*Nmid(g)*deadfish(s,g,f); // total fishery kill in numbers catch_fleet(t,f,1)+=Hrate(f,t)*Nmid(g)*sel_al_1(s,g,f); // total fishery encounter in biomass catch_fleet(t,f,3)+=Hrate(f,t)*Nmid(g)*sel_al_2(s,g,f); // retained fishery kill in biomass catch_fleet(t,f,4)+=Hrate(f,t)*Nmid(g)*sel_al_3(s,g,f); // encountered numbers catch_fleet(t,f,6)+=Hrate(f,t)*Nmid(g)*sel_al_4(s,g,f); // retained fishery kill in numbers } // end g loop } // close fishery for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { for (a=0;a<=nages;a++) // check for negative abundance, starting at age 1 { crashtemp=max_harvest_rate-catage_tot(g,a)/(Nmid(g,a)+0.0000001); crashtemp1=posfun(crashtemp,0.000001,CrashPen); if(crashtemp<0.&&rundetail>=2) {cout<<" crash age "<0) { Z_rate(t,p,g)=natM(s,GP3(g)); for (f=1;f<=Nfleet;f++) //loop over fishing fleets to get Z ProgLabel_105 if (catch_seas_area(t,p,f)==1) { Z_rate(t,p,g)+=deadfish(s,g,f)*Hrate(f,t); } Zrate2(p,g)=elem_div( (1.-mfexp(-seasdur(s)*Z_rate(t,p,g))), Z_rate(t,p,g)); } for (f=1;f<=Nfleet;f++) //loop over fishing fleets ProgLabel_105 if (catch_seas_area(t,p,f)==1) { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { catch_fleet(t,f,1)+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_1(s,g,f))*Zrate2(p,g); catch_fleet(t,f,2)+=Hrate(f,t)*elem_prod(natage(t,p,g),deadfish_B(s,g,f))*Zrate2(p,g); catch_fleet(t,f,3)+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_2(s,g,f))*Zrate2(p,g); // retained bio catch_fleet(t,f,4)+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_3(s,g,f))*Zrate2(p,g); catch_fleet(t,f,5)+=Hrate(f,t)*elem_prod(natage(t,p,g),deadfish(s,g,f))*Zrate2(p,g); catch_fleet(t,f,6)+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_4(s,g,f))*Zrate2(p,g); // retained numbers catage(t,f,g)=Hrate(f,t)*elem_prod(elem_prod(natage(t,p,g),deadfish(s,g,f)),Zrate2(p,g)); } //close gmorph loop } // close fishery break; } // end continuous F method case 3: // hybrid F_method { // start by doing a Pope's approximation for (f=1;f<=Nfleet;f++) //loop over fishing fleets TAG_105 if (catch_seas_area(t,p,f)==1 && catch_se_rd(f)>0.0) // do exact catch for this fleet { vbio.initialize(); for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(catchunits(f)==1) {vbio+=Nmid(g)*sel_al_2(s,g,f);} // retained catch bio else {vbio+=Nmid(g)*sel_al_4(s,g,f);} // retained catch numbers } //close gmorph loop temp = catch_ret_obs(f,t)/(vbio+0.1*catch_ret_obs(f,t)); // Pope's rate robust join1=1./(1.+mfexp(30.*(temp-0.95))); // steep logistic joiner at harvest rate of 0.95 temp1=join1*temp + (1.-join1)*0.95; Hrate(f,t)=-log(1.-temp1)/seasdur(s); // initial estimate of F (even though labelled as Hrate) // done with starting values from Pope's approximation } else { // Hrate(f,t) previously set to zero or set to a parameter value } for(int tune_F=1;tune_F<=F_Tune;tune_F++) { // add F+M to get Z using both exact and parameter based F for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { Z_rate(t,p,g)=natM(s,GP3(g)); for (f=1;f<=Nfleet;f++) //loop over fishing fleets to get Z if (catch_seas_area(t,p,f)!=0) { Z_rate(t,p,g)+=deadfish(s,g,f)*Hrate(f,t); } Zrate2(p,g)=elem_div( (1.-mfexp(-seasdur(s)*Z_rate(t,p,g))), Z_rate(t,p,g)); } // now calc adjustment to Z based on changes to be made to Hrate if(tune_F0.0) { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(catchunits(f)==1) { Z_adjuster2+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_2(s,g,f))*Zrate2(p,g); // biomass basis } else { Z_adjuster2+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_4(s,g,f))*Zrate2(p,g); // numbers basis } } //close gmorph loop } // close fishery Z_adjuster = totcatch_byarea(t,p)/(Z_adjuster2+0.0001); // but this totcatch_byarea needs to exclude fisheries with F from param for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { Z_rate(t,p,g)=natM(s,GP3(g)) + Z_adjuster*(Z_rate(t,p,g)-natM(s,GP3(g))); // need to modify to only do the exact catches Zrate2(p,g)=elem_div( (1.-mfexp(-seasdur(s)*Z_rate(t,p,g))), Z_rate(t,p,g)); } for (f=1;f<=Nfleet;f++) //loop over fishing fleets TAG_105 if(catch_seas_area(t,p,f)==1 && catch_se_rd(f)>0.0) { Z_adjuster2=0.; // now use this to calc the available biomass to each fishery with the adjusted Zrate2 for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(catchunits(f)==1) { Z_adjuster2+=elem_prod(natage(t,p,g),sel_al_2(s,g,f))*Zrate2(p,g); } else { Z_adjuster2+=elem_prod(natage(t,p,g),sel_al_4(s,g,f))*Zrate2(p,g); } } //close gmorph loop temp=catch_ret_obs(f,t)/(Z_adjuster2+0.0001); join1=1./(1.+mfexp(30.*(temp-0.95*max_harvest_rate))); Hrate(f,t)=join1*temp + (1.-join1)*max_harvest_rate; } // close fishery } else { for (f=1;f<=Nfleet;f++) //loop over fishing fleets ProgLabel_105 if (catch_seas_area(t,p,f)==1) { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { catch_fleet(t,f,1)+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_1(s,g,f))*Zrate2(p,g); catch_fleet(t,f,2)+=Hrate(f,t)*elem_prod(natage(t,p,g),deadfish_B(s,g,f))*Zrate2(p,g); catch_fleet(t,f,3)+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_2(s,g,f))*Zrate2(p,g); catch_fleet(t,f,4)+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_3(s,g,f))*Zrate2(p,g); catch_fleet(t,f,5)+=Hrate(f,t)*elem_prod(natage(t,p,g),deadfish(s,g,f))*Zrate2(p,g); catch_fleet(t,f,6)+=Hrate(f,t)*elem_prod(natage(t,p,g),sel_al_4(s,g,f))*Zrate2(p,g); catage(t,f,g)=Hrate(f,t)*elem_prod(elem_prod(natage(t,p,g),deadfish(s,g,f)),Zrate2(p,g)); } //close gmorph loop } // close fishery } } break; } // end hybrid F_Method } // end F_Method switch } // end have some catch in this seas x area else { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) {Z_rate(t,p,g)=natM(s,GP3(g));} } // Compute spawning biomass if occurs after start of current season if(s==spawn_seas && spawn_time_seas>=0.0001) // compute spawning biomass { SPB_pop_gp(y).initialize(); SPB_B_yr(y).initialize(); SPB_N_yr(y).initialize(); for (p=1;p<=pop;p++) { for (g=1;g<=gmorph;g++) if(sx(g)==1 && use_morph(g)>0) // female { SPB_pop_gp(y,p,GP4(g)) += fec(g)*elem_prod(natage(t,p,g),mfexp(-Z_rate(t,p,g)*spawn_time_seas)); // accumulates SSB by area and by growthpattern SPB_B_yr(y) += make_mature_bio(GP4(g))*natage(t,p,g); SPB_N_yr(y) += make_mature_numbers(GP4(g))*natage(t,p,g); } } SPB_current=sum(SPB_pop_gp(y)); SPB_yr(y)=SPB_current; if(Hermaphro_Option>0) // get male biomass { MaleSPB(y).initialize(); temp=0.0; for (p=1;p<=pop;p++) { for (g=1;g<=gmorph;g++) if(sx(g)==2 && use_morph(g)>0) // male; all assumed to be mature { MaleSPB(y,p,GP4(g)) += Save_Wt_Age(t,g)*elem_prod(natage(t,p,g),mfexp(-Z_rate(t,p,g)*spawn_time_seas)); // accumulates SSB by area and by growthpattern temp += sum(natage(t,p,g)); } } if(Hermaphro_maleSPB==1) // add MaleSPB to female SSB { SPB_current+=sum(MaleSPB(y)); SPB_yr(y)=SPB_current; SPB_B_yr(y)+=sum(MaleSPB(y)); SPB_N_yr(y)+=temp; } } Recruits=Spawn_Recr(SPB_current); // calls to function Spawn_Recr // these will get distributed among morphs at beginning of next season } // check for data for (f=1;f<=Ntypes;f++) //loop over fleets and surveys with data ProgLabel_105 if (fleet_area(f)==p) { if(have_data(f,t)>0) // ProgLabel_106 make the age-length available pop summed over all growth morphs { if(docheckup==1) echoinput<<" have data for fleet "<0) { gg=sx(g); if(gg==2) { L1=nlength1; L2= nlength2; A2=nages+1;} // move over on length dimension to store males else { L1=1; L2=nlength; A2=0;} if(F_Method==1) // Pope's approximation { if(timing<0.0) // fishery catch { for (a=0;a<=nages;a++) { temp=Nmid(g,a)*sel_a(y,f,gg,a); // get numbers-at-age(g,a) surviving to middle of time period if(dolen(f)==1) {pre_AL.shift(1)=temp*elem_prod(ALK(smid,g,a),sel_l(y,f,gg));} else {pre_AL.shift(1)=temp*ALK(smid,g,a);} exp_AL(a+A2)(L1,L2) += pre_AL.shift(L1); // shifted to store males in right place and accumulated across morphs } // close age loop } else // use explicit timing { for (a=0;a<=nages;a++) { temp=(natage(t,p,g,a)*mfexp(-natM(s,GP3(g),a)*timing)-surveytime(f)*catage_tot(g,a))*sel_a(y,f,gg,a); if(dolen(f)==1) {pre_AL.shift(1)=temp*elem_prod(ALK(smid,g,a),sel_l(y,f,gg));} else {pre_AL.shift(1)=temp*ALK(smid,g,a);} exp_AL(a+A2)(L1,L2) += pre_AL.shift(L1); // shifted to store males in right place and accumulated across morphs } // close age loop } } // end Pope's approx else // continuous F { if(timing<0.0) // mimic fishery catch, but without Hrate so get available numbers { for (a=0;a<=nages;a++) { temp=natage(t,p,g,a)*Zrate2(p,g,a)*sel_a(y,f,gg,a); if(dolen(f)==1) {pre_AL.shift(1)=temp*elem_prod(ALK(smid,g,a),sel_l(y,f,gg));} else {pre_AL.shift(1)=temp*ALK(smid,g,a);} exp_AL(a+A2)(L1,L2) += pre_AL.shift(L1); // shifted to store males in right place and accumulated across morphs } // close age loop } else // use explicit timing { for (a=0;a<=nages;a++) { temp=natage(t,p,g,a)*mfexp(-Z_rate(t,p,g,a)*timing) *sel_a(y,f,gg,a); if(dolen(f)==1) {pre_AL.shift(1)=temp*elem_prod(ALK(smid,g,a),sel_l(y,f,gg));} else {pre_AL.shift(1)=temp*ALK(smid,g,a);} exp_AL(a+A2)(L1,L2) += pre_AL.shift(L1); // shifted to store males in right place and accumulated across morphs } // close age loop } } // end continuous F if(Do_Morphcomp) { if(Morphcomp_havedata(f,t,0)>0) { Morphcomp_exp(Morphcomp_havedata(f,t,0),5+GP4(g))+=sum(exp_AL); // total catch of this gpattern in this season x area } } } //close gmorph loop exp_l_temp=colsum(exp_AL); if(seltype(f,2)!=0) {exp_l_temp_ret=elem_prod(exp_l_temp,retain(y,f));} else {exp_l_temp_ret=exp_l_temp;} // end creation of selected A-L // expected discard amount ************************************* ProgLabel_109 if(yr_disc2(f,t)>0) { j=yr_disc2(f,t); if(catch_ret_obs(f,t)>0.0) { if(disc_units(f)==3) // numbers regardless of catchunits for retained catch { exp_disc(f,j)=catch_fleet(t,f,4)-catch_fleet(t,f,6); } else if(catchunits(f)==1) // biomass units for retained and discarded catch { exp_disc(f,j)=catch_fleet(t,f,1)-catch_fleet(t,f,3); // discard in biomass if(disc_units(f)==2) exp_disc(f,j) /= (catch_fleet(t,f,1) + 0.0000001); } else // numbers for retained and discarded catch { exp_disc(f,j)=catch_fleet(t,f,4)-catch_fleet(t,f,6); // discard in numbers if(disc_units(f)==2) exp_disc(f,j) /= (catch_fleet(t,f,4) + 0.0000001); } } else { exp_disc(f,j)=-1.; } } // expected mean weight *************************************** ProgLabel_109a if(nobs_mnwt>0) { j=yr_mnwt2(f,t,0); // sample from total catch if(j!=0) { if(j>0) {exp_mnwt(j) = (exp_l_temp*wt_len2(s)) / sum(exp_l_temp);} else {exp_mnwt(-j) = (exp_l_temp*len_bins_m2) / sum(exp_l_temp);} } j=yr_mnwt2(f,t,1); // sample from discard if(j!=0) { if(j>0) {exp_mnwt(j) = (exp_l_temp-exp_l_temp_ret)*wt_len2(s) / (sum(exp_l_temp)-sum(exp_l_temp_ret));} else {exp_mnwt(-j) = (exp_l_temp-exp_l_temp_ret)*len_bins_m2 / (sum(exp_l_temp)-sum(exp_l_temp_ret));} } j=yr_mnwt2(f,t,2); // sample from retained catch if(j!=0) { if(j>0) {exp_mnwt(j) = (exp_l_temp_ret*wt_len2(s)) / sum(exp_l_temp_ret);} else {exp_mnwt(-j) = (exp_l_temp_ret*len_bins_m2) / sum(exp_l_temp_ret);} } } // expected weight frequency ****************************************ProgLabel_041 if(SzFreq_Nmeth>0) // have some sizefreq data { // create the transition matrices to convert population length bins to weight freq for(SzFreqMethod=1;SzFreqMethod<=SzFreq_Nmeth;SzFreqMethod++) { SzFreqMethod_seas=nseas*(SzFreqMethod-1)+s; // index that combines sizefreqmethod and season and used in SzFreqTrans if(SzFreq_HaveObs2(SzFreqMethod,t)==f) // first occurrence of this method at this time is with fleet = f { if(do_once==1 || (MG_active(3)>0 && (time_vary_MG(y,3)>0 ))) // calc the matrix because it may have changed { for(gg=1;gg<=gender;gg++) { if(gg==1) {z1=1;z2=nlength;ibin=0; ibinsave=0;} // female else {z1=nlength1; z2=nlength2; ibin=0; ibinsave=SzFreq_Nbins(SzFreqMethod);} // male topbin=0.; botbin=0.; switch(SzFreq_units(SzFreqMethod)) // biomass vs. numbers { case(1): // units are biomass, so accumulate body weight into the bins; Assume that bin demarcations are also in biomass { if(SzFreq_Omit_Small(SzFreqMethod)==1) {while(wt_len_low(s,z1+1)=topbin) { ibin++; ibinsave++; } if(ibin>1) {botbin=SzFreq_bins2(SzFreqMethod,ibin);} if(ibin==SzFreq_Nbins(SzFreqMethod)) { SzFreqTrans(SzFreqMethod_seas,z,ibinsave)=wt_len2(s,z); topbin=99999.; } else { topbin=SzFreq_bins2(SzFreqMethod,ibin+1); if(wt_len_low(s,z)>=botbin && wt_len_low(s,z+1)<=topbin ) { SzFreqTrans(SzFreqMethod_seas,z,ibinsave)=wt_len2(s,z); } else { temp=(wt_len_low(s,z+1)-topbin)/wt_len_fd(s,z); // frac in pop bin above (data bin +1) temp1=wt_len_low(s,z)+(1.-temp*0.5)*wt_len_fd(s,z); // approx body wt for these fish temp2=wt_len_low(s,z)+(1.-temp)*0.5*wt_len_fd(s,z); // approx body wt for fish below SzFreqTrans(SzFreqMethod_seas,z,ibinsave+1)=temp*temp1; SzFreqTrans(SzFreqMethod_seas,z,ibinsave)=(1.-temp)*temp2; } } } } if(SzFreq_scale(SzFreqMethod)==2 && gg==gender) // convert to pounds { SzFreqTrans(SzFreqMethod_seas)/=0.4536; } break; } // end of units in biomass // NOTE: even though the transition matrix is currently in units of biomass distribution, there is no need to // normalize to sum to 1.0 here because the normalization will occur after it gets used to create SzFreq_exp case(2): // units are numbers { if(SzFreq_scale(SzFreqMethod)<=2) // bin demarcations are in weight units (1=kg, 2=lbs), so uses wt_len to compare to bins { if(SzFreq_Omit_Small(SzFreqMethod)==1) {while(wt_len_low(s,z1+1)=topbin) {ibin++; ibinsave++;} //echoinput<<" incr ibin "<1) {botbin=SzFreq_bins2(SzFreqMethod,ibin);} if(ibin==SzFreq_Nbins(SzFreqMethod)) // echoinput<<" got to last ibin, so put rest of popbins here"<=botbin && wt_len_low(s,z+1)<=topbin ) //echoinput<<" pop inside dat, put here"<=topbin) {ibin++; ibinsave++;} //echoinput<<" incr ibin "<1) {botbin=SzFreq_bins2(SzFreqMethod,ibin);} if(ibin==SzFreq_Nbins(SzFreqMethod)) // echoinput<<" got to last ibin, so put rest of popbins here"<=botbin && len_bins2(z+1)<=topbin ) //echoinput<<" pop inside dat, put here"<0) { for(iobs=SzFreq_HaveObs(f,SzFreqMethod,t,1);iobs<=SzFreq_HaveObs(f,SzFreqMethod,t,2);iobs++) { switch(SzFreq_obs_hdr(iobs,5)) // discard/retained partition { case(0): { SzFreq_exp(iobs)=trans(SzFreqTrans(SzFreqMethod_seas))*exp_l_temp; break; } case(1): { SzFreq_exp(iobs)=trans(SzFreqTrans(SzFreqMethod_seas))*(exp_l_temp-exp_l_temp_ret); break; } case(2): { SzFreq_exp(iobs)=trans(SzFreqTrans(SzFreqMethod_seas))*exp_l_temp_ret; break; } } if(gender==2) { k=SzFreq_obs_hdr(iobs,8); // max bins for this method switch(SzFreq_obs_hdr(iobs,4)) // combine, select or each gender { case(0): // combine genders { for(ibin=1;ibin<=k;ibin++) SzFreq_exp(iobs,ibin)+=SzFreq_exp(iobs,k+ibin); SzFreq_exp(iobs)(k+1,2*k)=0.0; SzFreq_exp(iobs)(1,k)/=sum(SzFreq_exp(iobs)(1,k)); if(SzFreq_mincomp(SzFreqMethod)>0.0) { SzFreq_exp(iobs)(1,k)+=SzFreq_mincomp(SzFreqMethod); SzFreq_exp(iobs)(1,k)/=sum(SzFreq_exp(iobs)(1,k)); } break; } case(1): // female only { SzFreq_exp(iobs)(k+1,2*k)=0.0; // zero out the males so will not interfere with data generation SzFreq_exp(iobs)(1,k)/=sum(SzFreq_exp(iobs)(1,k)); if(SzFreq_mincomp(SzFreqMethod)>0.0) { SzFreq_exp(iobs)(1,k)+=SzFreq_mincomp(SzFreqMethod); SzFreq_exp(iobs)(1,k)/=sum(SzFreq_exp(iobs)(1,k)); } break; } case(2): // male only { ibin=SzFreq_obs_hdr(iobs,7); SzFreq_exp(iobs)(1,ibin-1)=0.0; // zero out the females so will not interfere with data generation SzFreq_exp(iobs)(ibin,k)/=sum(SzFreq_exp(iobs)(ibin,k)); if(SzFreq_mincomp(SzFreqMethod)>0.0) { SzFreq_exp(iobs)(ibin,k)+=SzFreq_mincomp(SzFreqMethod); SzFreq_exp(iobs)(ibin,k)/=sum(SzFreq_exp(iobs)(ibin,k)); } break; } case(3): // each gender { SzFreq_exp(iobs)/=sum(SzFreq_exp(iobs)); if(SzFreq_mincomp(SzFreqMethod)>0.0) { SzFreq_exp(iobs)+=SzFreq_mincomp(SzFreqMethod); SzFreq_exp(iobs)/=sum(SzFreq_exp(iobs)); } break; } } // end gender switch } // end have 2 genders else { k=SzFreq_obs_hdr(iobs,8); // max bins for this method SzFreq_exp(iobs)(1,k)/=sum(SzFreq_exp(iobs)(1,k)); if(SzFreq_mincomp(SzFreqMethod)>0.0) { SzFreq_exp(iobs)(1,k)+=SzFreq_mincomp(SzFreqMethod); SzFreq_exp(iobs)(1,k)/=sum(SzFreq_exp(iobs)(1,k)); } } } // end loop of obs for fleet = f } // end having some obs for this method in this fleet } // end loop of sizefreqmethods } // end use of wt freq data // expected biomass index ************************************* ProgLabel_110 // NOTE that the Q scaler is factored in later on if(yr_cr2(f,t)>0) { j=yr_cr2(f,t); if (seltype(f,1)>=30) { if(docheckup==1) echoinput<<" special selex used "<=recdev_start && y<=recdev_end) {vbio=mfexp(recdev(y));} else {vbio=1.0;} break;} case 32: // recruitment without density-dependence (for pre-recruit survey) #32 { if(y>=recdev_start && y<=recdev_end) {vbio=SPB_current*mfexp(recdev(y));} else {vbio=SPB_current;} break;} case 33: // recruitment #33 {vbio=Recruits; break;} case 34: // spawning biomass depletion { if(pop==1 || fleet_area(f)==0) { vbio=(SPB_current+1.0e-06)/(SPB_virgin+1.0e-06); } else { vbio=(sum(SPB_pop_gp(y,fleet_area(f)))+1.0e-06)/(SPB_virgin+1.0e-06); } break; } } } else { if(cr_units(f)==1) { if(WTage_rd==1) // using empirical wt-at-age; note that this cannot use GP specific bodyweights { if(seltype(f,2)>=1) { agetemp = exp_AL * retain(y,f); // retained only } else { agetemp=rowsum(exp_AL); } vbio=0.0; for(a=0;a<=nages;a++) vbio+=WTage_emp(y,1,f,a)*agetemp(a); if(gender==2) { for(a=0;a<=nages;a++) vbio+=WTage_emp(y,2,f,a)*agetemp(a+nages+1); } } else {vbio=exp_l_temp_ret*wt_len2(s);} // biomass } else if(cr_units(f)==0) {vbio=sum(exp_l_temp_ret);} // numbers else if(cr_units(f)==2) {vbio=Hrate(f,t);} // F rate } vul_bio(f,j)=value(vbio); if(Q_setup(f,1)>0) vbio=pow(vbio,1.0+Q_parm(Q_setup_parms(f,1))); if(cr_errtype(f)>=0) // lognormal {exp_cr(f,j)=log(vbio+0.000001);} else {exp_cr(f,j)=vbio;} } // Calc expected size comp ************************************* ProgLabel_120 { for(i=1;i<=Nobs_l(f);i++) // loop all obs of this type if(yr_l_t(f,i)==t) { if(LenBin_option>1) { if(mkt_l(f,i)==0) {exp_l(f,i) = make_len_bin*exp_l_temp;} // expected size comp MAtrix * vector = vector else if(mkt_l(f,i)==1) {exp_l(f,i) = make_len_bin*(exp_l_temp-exp_l_temp_ret);} // discard sample else {exp_l(f,i) = make_len_bin*exp_l_temp_ret;} // retained only } else // using data_bins same as pop_bins { if(mkt_l(f,i)==0) {exp_l(f,i) = exp_l_temp;} // expected size comp MAtrix * vector = vector else if(mkt_l(f,i)==1) {exp_l(f,i) = (exp_l_temp-exp_l_temp_ret);} // discard sample else {exp_l(f,i) = exp_l_temp_ret;} // retained only } if(docheckup==1) echoinput<<" len obs "<0) { for(i=1;i<=Nobs_ms(f);i++) // loop obs in this type/time must be contiguous in list if(yr_ms_t(f,i)==t) { k=abs(ageerr_type_ms(f,i)); // age-err type where the sign selects length vs. weight if(ageerr_type_ms(f,i)>0) // values are length at age { if(mkt_ms(f,i)==0) { exp_a_temp = age_age(k) * rowsum(exp_AL); // numbers at binned age = age_age(bins,age) * sum(age) exp_ms(f,i) = age_age(k) * (exp_AL * len_bins_m2); // numbers * length exp_ms_sq(f,i) = age_age(k) * (exp_AL * len_bins_sq); // numbers * length^2 } if(mkt_ms(f,i)==1) { exp_a_temp = age_age(k) * (exp_AL * (1-retain(y,f))); // numbers at binned age = age_age(bins,age) * sum(age) exp_ms(f,i) = age_age(k) * (exp_AL * elem_prod((1-retain(y,f)),len_bins_m2)); // numbers * length exp_ms_sq(f,i) = age_age(k) * (exp_AL * elem_prod((1-retain(y,f)),len_bins_sq)); // numbers * length^2 } if(mkt_ms(f,i)==2) { exp_a_temp = age_age(k) * (exp_AL * retain(y,f) ); // numbers at binned age = age_age(bins,age) * sum(age) exp_ms(f,i) = age_age(k) * (exp_AL * elem_prod((retain(y,f)),len_bins_m2)); // numbers * length exp_ms_sq(f,i) = age_age(k) * (exp_AL * elem_prod((retain(y,f)),len_bins_sq)); // numbers * length^2 } } else // values are weight at age { if(mkt_ms(f,i)==0) { exp_a_temp = age_age(k) * rowsum(exp_AL); // numbers at binned age = age_age(bins,age) * sum(age) exp_ms(f,i) = age_age(k) * (exp_AL * wt_len2(s)); // numbers * bodywt exp_ms_sq(f,i) = age_age(k) * (exp_AL * wt_len2_sq(s)); // numbers * bodywt^2 } if(mkt_ms(f,i)==1) { exp_a_temp = age_age(k) * (exp_AL * (1-retain(y,f))); // numbers at binned age = age_age(bins,age) * sum(age) exp_ms(f,i) = age_age(k) * (exp_AL * elem_prod((1-retain(y,f)),wt_len2(s))); // numbers * bodywt exp_ms_sq(f,i) = age_age(k) * (exp_AL * elem_prod((1-retain(y,f)),wt_len2_sq(s))); // numbers * bodywt^2 } if(mkt_ms(f,i)==2) { exp_a_temp = age_age(k) * (exp_AL * retain(y,f) ); // numbers at binned age = age_age(bins,age) * sum(age) exp_ms(f,i) = age_age(k) * (exp_AL * elem_prod((retain(y,f)),wt_len2(s))); // numbers * bodywt exp_ms_sq(f,i) = age_age(k) * (exp_AL * elem_prod((retain(y,f)),wt_len2_sq(s))); // numbers * bodywt^2 } } exp_ms(f,i)+=1.0e-6; exp_a_temp+=1.0e-6; exp_ms_sq(f,i)+=1.0e-6; exp_ms_sq(f,i) = sqrt( elem_div( (exp_ms_sq(f,i) - elem_div(elem_prod(exp_ms(f,i),exp_ms(f,i)), exp_a_temp)), exp_a_temp ) ) + 0.000001; //std.err. of size at binned age = sqrt( (P2-P1*P1/P0) / P0 ) exp_ms(f,i) = elem_div(exp_ms(f,i), exp_a_temp); // mean size at binned age } } // end size-at-age // if (do_once==1) cout<<" got LAA "<0) { if(F_Method==1) // pope's { if(s1) echoinput<<"Zed: "<0) { if(Hermaphro_seas==-1 || Hermaphro_seas==s) { k=gmorph/2; for (p=1;p<=pop;p++) // area for (g=1;g<=k;g++) // loop females if(use_morph(g)>0) { for (a=1;a0) // movement between areas in time series { natage_temp=natage(t+1); natage(t+1)=0.0; for (p=1;p<=pop;p++) // source population for (p2=1;p2<=pop;p2++) // destination population for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { k=move_pattern(s,GP4(g),p,p2); if(k>0) natage(t+1,p2,g) += elem_prod(natage_temp(p,g),migrrate(y,k));} } // end migration // save selectivity*Hrate for tag-recapture if(Do_TG>0 && t>=TG_timestart) { for(g=1;g<=gmorph;g++) for(f=1;f<=Nfleet;f++) { Sel_for_tag(t,g,f) = sel_al_4(s,g,f)*Hrate(f,t); } } if(docheckup==1) echoinput<<" save some annual catch and F quantities "<0) || ((sd_phase() || mceval_phase()) && (initial_params::mc_phase==0)|| (F_ballpark_yr>=styr)) ) { for (f=1;f<=Nfleet;f++) { for (k=1;k<=6;k++) { annual_catch(y,k)+=catch_fleet(t,f,k); } if(F_Method==1) { annual_F(y,1)+=Hrate(f,t); } else { annual_F(y,1)+=Hrate(f,t)*seasdur(s); } } if(docheckup==1) echoinput<<" calculate the F reporting statistic "<0) { for(p=1;p<=pop;p++) { for(a=F_reporting_ages(1);a<=F_reporting_ages(2);a++) // should not let a go higher than nages-2 because of accumulator { temp1+=natage(t+1,p,g,a+1); if(nseas==1) { temp2+=natage(t,p,g,a)*mfexp(-seasdur(s)*natM(s,GP3(g),a)); } else { temp3=natage(t-nseas+1,p,g,a); // numbers at begin of year for(j=1;j<=nseas;j++) {temp3*=mfexp(-seasdur(j)*natM(j,GP3(g),a));} temp2+=temp3; } } } } annual_F(y,2) = log(temp2)-log(temp1); if(docheckup==1) echoinput<<" annual F "<0) // save selected std quantity { if(F_reporting<=1) { F_std(STD_Yr_Reverse_F(y))=annual_catch(y,2)/Smry_Table(y,2); // dead catch biomass/summary biomass // does not exactly correspond to F, which is for total catch } else if(F_reporting==2) { F_std(STD_Yr_Reverse_F(y))=annual_catch(y,5)/Smry_Table(y,3); // dead catch numbers/summary numbers } else if(F_reporting==3) { F_std(STD_Yr_Reverse_F(y))=annual_F(y,1); } else if(F_reporting==4) { F_std(STD_Yr_Reverse_F(y))=annual_F(y,2); } } } // end s==nseas } } //close season loop // calculate the SPR value for if( (save_for_report>0) || ((sd_phase() || mceval_phase()) && (initial_params::mc_phase==0)) ) { eq_yr=y; equ_Recr=Recr_virgin; bio_yr=y; Fishon=0; dvariable SPR_unf; Do_Equil_Calc(); // call function to do equilibrium calculation with current year's biology SPR_unf=SPB_equil; Smry_Table(y,11)=SPR_unf; Smry_Table(y,13)=GenTime; Fishon=1; Do_Equil_Calc(); // call function to do equilibrium calculation with current year's biology and F if(STD_Yr_Reverse_Ofish(y)>0) { SPR_std(STD_Yr_Reverse_Ofish(y))=SPB_equil/SPR_unf; } Smry_Table(y,9)=(totbio); Smry_Table(y,10)=(smrybio); Smry_Table(y,12)=(SPB_equil); Smry_Table(y,14)=(YPR_dead); for(g=1;g<=gmorph;g++) { Smry_Table(y,20+g)=(cumF(g)); Smry_Table(y,20+gmorph+g)=(maxF(g)); } } if(docheckup==1) echoinput<<" finished year "<0) { dvariable TG_init_loss; dvariable TG_chron_loss; TG_recap_exp.initialize(); for(TG=1;TG<=N_TG;TG++) { firstseas=int(TG_release(TG,4)); // release season t=int(TG_release(TG,5)); // release t index calculated in data section from year and season of release p=int(TG_release(TG,2)); // release area gg=int(TG_release(TG,6)); // gender (1=fem; 2=male; 0=both a1=int(TG_release(TG,7)); // age at release TG_alive.initialize(); if(gg==0) { for (g=1;g<=gmorph;g++) {TG_alive(p,g) = natage(t,p,g,a1);} // gets both genders } else { for (g=1;g<=gmorph;g++) { if(sx(g)==gg) {TG_alive(p,g) = natage(t,p,g,a1);} // only does the selected gender } } TG_init_loss = mfexp(TG_parm(TG))/(1.+mfexp(TG_parm(TG))); TG_chron_loss = mfexp(TG_parm(TG+N_TG))/(1.+mfexp(TG_parm(TG+N_TG))); for(f=1;f<=Nfleet;f++) { k=3*N_TG+f; TG_report(f) = mfexp(TG_parm(k))/(1.0+mfexp(TG_parm(k))); TG_rep_decay(f) = TG_parm(k+Nfleet); } TG_alive /= sum(TG_alive); // proportions across morphs at age a1 in release area p at time of release t TG_alive *= TG_release(TG,8); // number released as distributed across morphs TG_alive *= (1.-TG_init_loss); // initial mortality if(save_for_report>0) { TG_save(TG,1)=value(TG_init_loss); TG_save(TG,2)=value(TG_chron_loss); } TG_t=0; for(y=TG_release(TG,3);y<=endyr;y++) { for(s=firstseas;s<=nseas;s++) { if(save_for_report>0 && TG_t<=TG_endtime(TG)) {TG_save(TG,3+TG_t)=value(sum(TG_alive));} // OK to do simple sum because only selected morphs are populated for(p=1;p<=pop;p++) { for (g=1;g<=gmorph;g++) if(TG_use_morph(TG,g)>0) { for (f=1;f<=Nfleet;f++) //loop over fishing fleets ProgLabel_105 if (fleet_area(f)==p) { // calculate recaptures by fleet // NOTE: Sel_for_tag(t,g,f,a1) = sel_al_4(s,g,f,a1)*Hrate(f,t) if(F_Method==1) { TG_recap_exp(TG,TG_t,f)+=TG_alive(p,g) // tags recaptured *mfexp(-(natM(s,GP3(g),a1)+TG_chron_loss)*seasdur_half(s)) *Sel_for_tag(t,g,f,a1) *TG_report(f) *mfexp(TG_t*TG_rep_decay(f)); } else // use for method 2 and 3 { TG_recap_exp(TG,TG_t,f)+=TG_alive(p,g) *Sel_for_tag(t,g,f,a1)/(Z_rate(t,p,g,a1)+TG_chron_loss) *(1.-mfexp(-seasdur(s)*(Z_rate(t,p,g,a1)+TG_chron_loss))) *TG_report(f) *mfexp(TG_t*TG_rep_decay(f)); } if(docheckup==1) echoinput<<" TG_"<0) { if(Hermaphro_seas==-1 || Hermaphro_seas==s) { k=gmorph/2; for (p=1;p<=pop;p++) // area for (g=1;g<=k;g++) // loop females if(use_morph(g)>0) { TG_alive(p,g+k) += TG_alive(p,g)*Hermaphro_val(GP4(g),a1); // increment males TG_alive(p,g) *= (1.-Hermaphro_val(GP4(g),a1)); // decrement females } } } if(do_migration>0) // movement between areas of tags { TG_alive_temp=TG_alive; TG_alive=0.0; for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { for (p=1;p<=pop;p++) // source population for (p2=1;p2<=pop;p2++) // destination population { k=move_pattern(s,GP4(g),p,p2); if(k>0) TG_alive(p2,g) += TG_alive_temp(p,g)*migrrate(y,k,a1); } } if(docheckup==1) echoinput<<" Tag_alive after survival and movement "<max_lambda_phase) k_phase=max_lambda_phase; // Fit to indices ProgLabel_210 if(nobs_cr>0) { for(f=1;f<=Ntypes;f++) if(surv_lambda(f,k_phase)>0.0 || save_for_report>0) // skip if zero emphasis { if(nyr_cr(f)>0) { se_cr_use(f) = se_cr_obs(f); if(Q_setup(f,3)>0) se_cr_use(f)+=Q_parm(Q_setup_parms(f,3)); // add extra stderr for(j=1;j<=N_suprper_cr(f);j++) // do super years { temp=0.0; for(i=suprper_cr1(f,j);i<=suprper_cr2(f,j);i++) {temp+=exp_cr(f,i)*suprper_cr_sampwt(f,i);} // combine across range of observations // sampwt sums to 1.0, so temp contains the weighted average for(i=suprper_cr1(f,j);i<=suprper_cr2(f,j);i++) {exp_cr(f,i)=temp;} // assign average to each obs } if(Q_setup(f,4)==0 || Q_setup(f,4)==1 || Q_setup(f,4)==5 ) // do float option=automatic scaling // ProgLabel_211 { // NOTE: cannot use float option if error type is normal temp=0.; temp1=0.; temp2=0.; for (i=1;i<=nyr_cr(f);i++) { if(yr_cr_use(f,i) > 0) { temp2 += (Ln_obs_cr(f,i)-exp_cr(f,i))/square(se_cr_use(f,i)); temp += 1.0/square(se_cr_use(f,i)); temp1 += 1.; } } if(Q_setup(f,4)==0) // mean q, with nobiasadjustment {log_q_cr(f) = temp2/temp;} else // for value = 1 or 5 // mean q with variance bias adjustment {log_q_cr(f) = (temp2 + temp1*0.5)/temp;} if(Q_setup(f,4)==5) Q_parm(Q_setup_parms(f,4))=log_q_cr(f,1); // base Q } else if(Q_setup(f,4)<=-1) // mirror Q from lower numbered survey // because Q is a vector for each observation, the mirror is to the first observation's Q // so time-varying property cannot be mirrored {log_q_cr(f) = log_q_cr(-Q_setup(f,4),1);} else // Q from parameter { log_q_cr(f) = Q_parm(Q_setup_parms(f,4)); // base Q // note that Q is in log space even if normal error structure is used // trend or block effect on Q // seasonal or cyclic effect on Q // environmental effect on Q if(Q_setup(f,2)>0) // environ effect on log(q) multiplicative { for(i=1;i<=nyr_cr(f);i++) {log_q_cr(f,i) += Q_parm(Q_setup_parms(f,2)) * env_data(yr_cr_y(f,i),Q_setup(f,2));} // note that this environ effect is after the dev effect! } else if(Q_setup(f,2)<0) // environ effect on log(q) additive { for(i=1;i<=nyr_cr(f);i++) {log_q_cr(f,i) += Q_parm(Q_setup_parms(f,2)) + env_data(yr_cr_y(f,i),-Q_setup(f,2));} } // random deviations or random walk if(Q_setup(f,4)==3 || Q_setup(f,4)==4 ) { temp=0.0; temp2=0.0; temp1=0.; if(Q_setup(f,4)==3) // random devs { for(i=1;i<=nyr_cr(f);i++) { j=Q_setup_parms(f,4)+i; log_q_cr(f,i)+=Q_parm(j); temp+=Q_parm(j); temp2+=square(Q_parm(j)); temp1+=1.; } } else if(Q_setup(f,4)==4) // random walk { for(i=2;i<=nyr_cr(f);i++) { j=Q_setup_parms(f,4)+i-1; log_q_cr(f,i)=log_q_cr(f,i-1)+Q_parm(j); temp+=Q_parm(j); temp2+=square(Q_parm(j)); temp1+=1.; } } Q_dev_like(f,1)=square(1.+square(temp))-1.; // not used for randwalk if(temp1>0.0) Q_dev_like(f,2)=sqrt((temp2+0.0000001)/temp1); // this is calculated but not used because redundant with the prior penalty } } q_cr(f) = mfexp(log_q_cr(f)); // get q in arithmetic space // calculate the survey logL if(cr_errtype(f)==0) // lognormal { for(i=1;i<=nyr_cr(f);i++) if(yr_cr_use(f,i)>0) { surv_like(f) +=0.5*square( ( Ln_obs_cr(f,i)-exp_cr(f,i)-log_q_cr(f,i) ) / se_cr_use(f,i)) + sd_offset*log(se_cr_use(f,i)); // should add a term for 0.5*s^2 for bias adjustment so that parameter approach will be same as the biasadjusted scaling approach } } else if (cr_errtype(f)>0) // t-distribution { dvariable df = cr_errtype(f); for(i=1;i<=nyr_cr(f);i++) if(yr_cr_use(f,i)>0) { surv_like(f) +=((df+1.)/2.)*log((1.+square((Ln_obs_cr(f,i)-exp_cr(f,i)-log_q_cr(f,i) ))/(df*square(se_cr_use(f,i))) )) + sd_offset*log(se_cr_use(f,i)); } } else if(cr_errtype(f)==-1) // normal { for(i=1;i<=nyr_cr(f);i++) { if(yr_cr_use(f,i)>0) { surv_like(f) +=0.5*square( ( Ln_obs_cr(f,i)-exp_cr(f,i)*q_cr(f,i) ) / se_cr_use(f,i)) + sd_offset*log(se_cr_use(f,i)); } } } } // end having obs for this survey } if(do_once==1) cout<<" did survey obj_fun "<0) { for(f=1;f<=Nfleet;f++) if(disc_lambda(f,k_phase)>0.0 || save_for_report>0) { if(nyr_disc(f)>0) { for(j=1;j<=N_suprper_disc(f);j++) // do super years { temp=0.0; for(i=suprper_disc1(f,j);i<=suprper_disc2(f,j);i++) {temp+=exp_disc(f,i)*suprper_disc_sampwt(f,i);} // combine across range of observations for(i=suprper_disc1(f,j);i<=suprper_disc2(f,j);i++) {exp_disc(f,i)=temp;} // assign back to each obs } if(disc_errtype(f)>=1) // T -distribution { for (i=1;i<=nyr_disc(f);i++) if(yr_disc_use(f,i)>=0.0) { disc_like(f) +=0.5*(disc_errtype(f)+1.)*log((1.+square(obs_disc(f,i)-exp_disc(f,i))/(disc_errtype(f)*square(sd_disc(f,i))) )) + sd_offset*log(sd_disc(f,i)); } } else if (disc_errtype(f)==0) // normal error, with input CV { for (i=1;i<=nyr_disc(f);i++) if(yr_disc_use(f,i)>=0.0) { disc_like(f) +=0.5*square( (obs_disc(f,i)-exp_disc(f,i)) / sd_disc(f,i)) + sd_offset*log(sd_disc(f,i)); } } else if (disc_errtype(f)==-1) // normal error with input se { for (i=1;i<=nyr_disc(f);i++) if(yr_disc_use(f,i)>=0.0) { disc_like(f) +=0.5*square( (obs_disc(f,i)-exp_disc(f,i)) / sd_disc(f,i)) + sd_offset*log(sd_disc(f,i)); } } else // lognormal where input cv_disc must contain se in log space { for (i=1;i<=nyr_disc(f);i++) if(yr_disc_use(f,i)>=0.0) { disc_like(f) +=0.5*square( log(obs_disc(f,i)/exp_disc(f,i)) / sd_disc(f,i)) + sd_offset*log(sd_disc(f,i)); } } } } if(do_once==1) cout<<" did discard obj_fun "<0) { for(i=1;i<=nobs_mnwt;i++) if(mnwtdata(5,i)>0. && mnwtdata(3,i)>0.) { mnwt_like(mnwtdata(3,i)) +=0.5*(DF_bodywt+1.)*log(1.+square(mnwtdata(5,i)-exp_mnwt(i))/mnwtdata(8,i))+ mnwtdata(9,i); } // mnwtdata(6,i)+=var_adjust(3,mnwtdata(3,i)); adjusted input error as a CV // if(mnwtdata(6,i)<=0.0) mnwtdata(6,i)=0.001; // mnwtdata(7,i)=mnwtdata(5,i)*mnwtdata(6,i); se = obs*CV // mnwtdata(8,i)=DF_bodywt*square(mnwtdata(7,i)); error as T-dist // mnwtdata(9,i)=sd_offset*log(mnwtdata(7,i)); for the -log(s) component if(do_once==1) cout<<" did meanwt obj_fun "<0) { for(f=1;f<=Ntypes;f++) if(length_lambda(f,k_phase)>0.0 || save_for_report>0) { if(Nobs_l(f)>=1) { length_like(f) = -offset_l(f); for(j=1;j<=N_suprper_l(f);j++) // do each super period { exp_l_temp_dat.initialize(); for(i=suprper_l1(f,j);i<=suprper_l2(f,j);i++) { exp_l_temp_dat+=exp_l(f,i)*suprper_l_sampwt(f,i); // combine across range of observations } // exp_l_temp_dat/=sum(exp_l_temp_dat); // normalize not needed because converted to proportions later for(i=suprper_l1(f,j);i<=suprper_l2(f,j);i++) { exp_l(f,i)=exp_l_temp_dat; // assign back to all obs } } for(i=1;i<=Nobs_l(f);i++) { if(gender==2) { if(gen_l(f,i)==0) // combined sex observation ProgLabel_124 { for(z=1;z<=nlen_bin;z++) {exp_l(f,i,z)+=exp_l(f,i,z+nlen_bin);} exp_l(f,i)(nlen_binP,nlen_bin2)=0.00; } else if(gen_l(f,i)==1) // female only {exp_l(f,i)(nlen_binP,nlen_bin2)=0.00;} else if(gen_l(f,i)==2) // male only {exp_l(f,i)(1,nlen_bin)=0.00;} else if(gen_l(f,i)==3 && CombGender_l>0) { for(z=1;z<=CombGender_l;z++) {exp_l(f,i,z)+=exp_l(f,i,z+nlen_bin); exp_l(f,i,z+nlen_bin)=0.00;} } } exp_l(f,i) /= sum(exp_l(f,i)); tails_w=ivector(tails_l(f,i)); if(gen_l(f,i)!=2) // ProgLabel_126 { if(tails_w(1)>1) {exp_l(f,i,tails_w(1))=sum(exp_l(f,i)(1,tails_w(1))); exp_l(f,i)(1,tails_w(1)-1)=0.;} if(tails_w(2)=2) { if(tails_w(3)>nlen_binP) {exp_l(f,i,tails_w(3))=sum(exp_l(f,i)(nlen_binP,tails_w(3))); exp_l(f,i)(nlen_binP,tails_w(3)-1)=0.;} if(tails_w(4)0 && header_l(f,i,3)>0) { if(gen_l(f,i) !=2) length_like(f) -= nsamp_l(f,i) * obs_l(f,i)(tails_w(1),tails_w(2)) * log(exp_l(f,i)(tails_w(1),tails_w(2))); if(gen_l(f,i) >=2 && gender==2) length_like(f) -= nsamp_l(f,i) * obs_l(f,i)(tails_w(3),tails_w(4)) * log(exp_l(f,i)(tails_w(3),tails_w(4))); } } } } if(do_once==1) cout<<" did lencomp obj_fun "<0) { for(f=1;f<=Ntypes;f++) if(age_lambda(f,k_phase)>0.0 || save_for_report>0) { if(Nobs_a(f)>=1) { age_like(f) = -offset_a(f); for(j=1;j<=N_suprper_a(f);j++) // do super years Max of 20 allowed per type(f) { exp_a_temp.initialize(); for(i=suprper_a1(f,j);i<=suprper_a2(f,j);i++) { exp_a_temp+=exp_a(f,i)*suprper_a_sampwt(f,i); // combine across range of observations } // exp_a_temp/=(1.0e-15+sum(exp_a_temp)); // normalize for(i=suprper_a1(f,j);i<=suprper_a2(f,j);i++) exp_a(f,i)=exp_a_temp; // assign back to each original obs } for(i=1;i<=Nobs_a(f);i++) { if(gender==2) { if(gen_a(f,i)==0) // combined sex observation { for(z=1;z<=n_abins;z++) {exp_a(f,i,z)+=exp_a(f,i,z+n_abins);} exp_a(f,i)(n_abins1,n_abins2)=0.00; } else if(gen_a(f,i)==1) // female only {exp_a(f,i)(n_abins1,n_abins2)=0.00;} else if(gen_a(f,i)==2) // male only {exp_a(f,i)(1,n_abins)=0.00;} else if(gen_a(f,i)==3 && CombGender_a>0) { for(z=1;z<=CombGender_a;z++) {exp_a(f,i,z)+=exp_a(f,i,z+n_abins); exp_a(f,i,z+n_abins)=0.00;} } } exp_a(f,i) /= (1.0e-15+sum(exp_a(f,i))); // proportion at binned age if(save_for_report==1) { exp_a_temp=exp_a(f,i); exp_meanage(f,i,2)=sum(elem_prod(exp_a_temp,age_bins_mean)); // get mean age across both sexes before adding min_comp and compressing temp=exp_a_temp(1); temp1=0.0; if(gender==2) temp+=exp_a_temp(1+n_abins); z=1; while(temp<=0.05) { temp1=temp; z++; temp+=exp_a_temp(z); if(gender==2) temp+=exp_a_temp(z+n_abins); } if(z1) {exp_a(f,i,tails_w(1))=sum(exp_a(f,i)(1,tails_w(1))); exp_a(f,i)(1,tails_w(1)-1)=0.;} if(tails_w(2)=2) { if(tails_w(3)>n_abins1) {exp_a(f,i,tails_w(3))=sum(exp_a(f,i)(n_abins1,tails_w(3))); exp_a(f,i)(n_abins1,tails_w(3)-1)=0.;} if(tails_w(4)0 && header_a(f,i,3)>0) { if(gen_a(f,i) !=2) age_like(f) -= nsamp_a(f,i) * obs_a(f,i)(tails_w(1),tails_w(2)) * log(exp_a(f,i)(tails_w(1),tails_w(2))); if(gen_a(f,i) >=2 && gender==2) age_like(f) -= nsamp_a(f,i) * obs_a(f,i)(tails_w(3),tails_w(4)) * log(exp_a(f,i)(tails_w(3),tails_w(4))); } } } } if(do_once==1) cout<<" did agecomp obj_fun "<0) { for(f=1;f<=Ntypes;f++) if(Nobs_ms(f)>0 && sizeage_lambda(f,k_phase)>0.0) { for(j=1;j<=N_suprper_ms(f);j++) { exp_a_temp.initialize(); for(i=suprper_ms1(f,j);i<=suprper_ms2(f,j);i++) {exp_a_temp+=exp_ms(f,i)*suprper_ms_sampwt(f,i);} // combine across range of observations for(i=suprper_ms1(f,j);i<=suprper_ms2(f,j);i++) exp_ms(f,i)=exp_a_temp; // assign back to each original obs } for(i=1;i<=Nobs_ms(f);i++) if(use_ms(f,i)>0) { for(b=1;b<=n_abins2;b++) { if(obs_ms_n(f,i,b)>0 && obs_ms(f,i,b)>0) { sizeage_like(f) += 0.5*square((obs_ms(f,i,b) -exp_ms(f,i,b)) / (exp_ms_sq(f,i,b)/obs_ms_n(f,i,b))) + sd_offset*log(exp_ms_sq(f,i,b)/obs_ms_n(f,i,b)); // where: obs_ms_n(f,i,b)=sqrt(var_adjust(6,f)*obs_ms_n(f,i,b)); } } } } if(do_once==1) cout<<" did meanlength obj_fun "<0) // have some sizefreq data { // create super-period expected values for(j=1;j<=N_suprper_SzFreq;j++) { a=suprper_SzFreq_start(j); // get observation index SzFreq_exp(a)*=suprper_SzFreq_sampwt(a); // start creating weighted average for(iobs=a+1;iobs<=suprper_SzFreq_end(j);iobs++) {SzFreq_exp(a)+=SzFreq_exp(iobs)*suprper_SzFreq_sampwt(iobs);} // combine into the first obs of this superperiod for(iobs=a+1;iobs<=suprper_SzFreq_end(j);iobs++) {SzFreq_exp(iobs)=SzFreq_exp(a);} // assign back to all obs } SzFreq_like=-SzFreq_like_base; // initializes for(iobs=1;iobs<=SzFreq_totobs;iobs++) { if(SzFreq_obs_hdr(iobs,3)>0) { k=SzFreq_obs_hdr(iobs,6); f=abs(SzFreq_obs_hdr(iobs,3)); z1=SzFreq_obs_hdr(iobs,7); z2=SzFreq_obs_hdr(iobs,8); SzFreq_like(SzFreq_LikeComponent(f,k))-=SzFreq_sampleN(iobs)*SzFreq_obs(iobs)(z1,z2)*log(SzFreq_exp(iobs)(z1,z2)); } } if(do_once==1) cout<<" did sizefreq obj_fun: "<0) { for(iobs=1;iobs<=Morphcomp_nobs;iobs++) { k=5+Morphcomp_nmorph; Morphcomp_exp(iobs)(6,k) /= sum(Morphcomp_exp(iobs)(6,k)); Morphcomp_exp(iobs)(6,k) += Morphcomp_mincomp; Morphcomp_exp(iobs)(6,k) /= 1.+Morphcomp_mincomp*Morphcomp_nmorph; if(Morphcomp_obs(iobs,5)>0.) Morphcomp_like -= Morphcomp_obs(iobs,5)*Morphcomp_obs(iobs)(6,k) * log(elem_div(Morphcomp_exp(iobs)(6,k),Morphcomp_obs(iobs)(6,k))); } if(do_once==1) cout<<" did morphcomp obj_fun "<0) { for(TG=1;TG<=N_TG;TG++) { overdisp=TG_parm(2*N_TG+TG); for(TG_t=TG_mixperiod;TG_t<=TG_endtime(TG);TG_t++) { TG_recap_exp(TG,TG_t)(1,Nfleet)+=1.0e-6; // add a tiny amount TG_recap_exp(TG,TG_t,0) = sum(TG_recap_exp(TG,TG_t)(1,Nfleet)); TG_recap_exp(TG,TG_t)(1,Nfleet)/=TG_recap_exp(TG,TG_t,0); if(Nfleet>1) TG_like1(TG)-=TG_recap_obs(TG,TG_t,0)* (TG_recap_obs(TG,TG_t)(1,Nfleet) * log(TG_recap_exp(TG,TG_t)(1,Nfleet))); TG_like2(TG)-=log_negbinomial_density(TG_recap_obs(TG,TG_t,0),TG_recap_exp(TG,TG_t,0),overdisp); } } if(do_once==1) cout<<" did tag obj_fun "<0.0) { for(f=1;f<=Nfleet;f++) { if(catch_se_rd(f)>0.0 && obs_equ_catch(f)>0.0) // {equ_catch_like += 0.5*square( (log(obs_equ_catch(f)) -log(est_equ_catch(f)+0.000001)) / catch_se(styr-1,f));} {equ_catch_like += 0.5*square( (log(1.1*obs_equ_catch(f)) -log(est_equ_catch(f)+0.1*obs_equ_catch(f))) / catch_se(styr-1,f));} } if(do_once==1) cout<<" initequ_catch -log(L) "<1) { for(f=1;f<=Nfleet;f++) { if(catchunits(f)==1) {i=3;} // biomass else {i=6;} // numbers for(t=styr;t<=TimeMax;t++) { if(catch_se_rd(f)>0.0 && catch_ret_obs(f,t)>0.0) { // catch_like(f) += 0.5*square( (log(catch_ret_obs(f,t)) -log(catch_fleet(t,f,i)+0.000001)) / catch_se(t,f)); catch_like(f) += 0.5*square( (log(1.1*catch_ret_obs(f,t)) -log(catch_fleet(t,f,i)+0.1*catch_ret_obs(f,t))) / catch_se(t,f)); } } } } //The recruitment prior is assumed to be a lognormal pdf with expected // value equal to the deterministic stock-recruitment curve // ProgLabel_260 // R1 deviation is weighted by ave_age because R1 represents a time series of recruitments // SR_parm(N_SRparm+1) is sigmaR // SR_parm(N_SRparm+4) is rho, the autocorrelation coefficient // POP code from Ianelli // if (rho>0) // for (i=styr_rec+1;i<=endyr;i++) // rec_like(1) += square((chi(i)- rho*chi(i-1)) /(sqrt(1.-rho*rho))) / (2.*sigmaRsq) + log(sigr); // else // rec_like(1) = (norm2( chi + sigmaRsq/2. ) / (2*sigmaRsq)) / (2.*sigmaRsq) + size_count(chi)*log(sigr); if(recrdev_lambda(k_phase)>0.0 && (do_recdev>0 || recdev_do_early>0) ) { // where sd_offset_rec takes account for the number of recruitment years fully estimated // this is calculated as the sum of the biasadj vector if(SR_autocorr==0){ recr_like = sd_offset_rec * log(sigmaR); //# styr-nages,YrMax recr_like += norm2(recdev(recdev_first,recdev_end)) / two_sigmaRsq; }else{ rho=SR_parm(N_SRparm2); //recr_like = (biasadj(recdev_first)*sd_offset)*log(sigmaR) + (sd_offset_rec-biasadj(recdev_first)*sd_offset)*log(sigmaR*sqrt(1-rho*rho)); recr_like = sd_offset_rec * log(sqrt(1.0-rho*rho)*sigmaR); recr_like += square(recdev(recdev_first)) / ((1.0-rho*rho)*two_sigmaRsq); for(y=recdev_first+1;y<=recdev_end;y++){ recr_like += square(recdev(y)-rho*recdev(y-1)) / ((1.0-rho*rho)*two_sigmaRsq); } } recr_like += 0.5 * square( log(R1/R1_exp) / (sigmaR/ave_age) ); if(do_once==1) cout<<" did recruitdev obj_fun "<0) { if(recdev_end0) Fcast_recr_like+=(norm2(Fcast_impl_error(endyr+1,YrMax)))/(2.0*Impl_Error_Std*Impl_Error_Std); // implementation error } // ____________________________________________________ // likelihood for the parameter priors // ProgLabel_270 dvariable mu; dvariable tau; dvariable Aprior; dvariable Bprior; int Ptype; dvariable Pconst; Pconst=0.0001; if(parm_prior_lambda(k_phase)>0.0 || Do_all_priors>0) { for(i=1;i<=N_MGparm2;i++) if(MGparm_PRtype(i)>-1 && (active(MGparm(i))|| Do_all_priors>0)) { MGparm_Like(i)=Get_Prior(MGparm_PRtype(i), MGparm_LO(i), MGparm_HI(i), MGparm_PR(i), MGparm_CV(i), MGparm(i)); parm_like+=MGparm_Like(i); } for(i=1;i<=Nfleet;i++) if(init_F_PRtype(i)>-1 && (active(init_F(i))|| Do_all_priors>0)) { init_F_Like(i)=Get_Prior(init_F_PRtype(i), init_F_LO(i), init_F_HI(i), init_F_PR(i), init_F_CV(i), init_F(i)); parm_like+=init_F_Like(i); } for(i=1;i<=Q_Npar;i++) if(Q_parm_1(i,5)>-1 && (active(Q_parm(i))|| Do_all_priors>0)) { Q_parm_Like(i)=Get_Prior(Q_parm_1(i,5), Q_parm_1(i,1), Q_parm_1(i,2), Q_parm_1(i,4), Q_parm_1(i,6), Q_parm(i)); parm_like+=Q_parm_Like(i); } for(i=1;i<=N_selparm2;i++) if(selparm_PRtype(i)>-1 && (active(selparm(i))|| Do_all_priors>0)) { selparm_Like(i)=Get_Prior(selparm_PRtype(i), selparm_LO(i), selparm_HI(i), selparm_PR(i), selparm_CV(i), selparm(i)); parm_like+=selparm_Like(i); } if(Do_TG>0) { k=3*N_TG+2*Nfleet; for(i=1;i<=k;i++) if(TG_parm2(i,5)>-1 && (active(TG_parm(i))|| Do_all_priors>0)) { TG_parm_Like(i)=Get_Prior(TG_parm2(i,5), TG_parm_LO(i), TG_parm_HI(i), TG_parm2(i,4), TG_parm2(i,6), TG_parm(i)); parm_like+=TG_parm_Like(i); } } for(i=1;i<=N_SRparm2;i++) if(SR_parm_1(i,5)>-1 && (active(SR_parm(i))|| Do_all_priors>0)) { SR_parm_Like(i)=Get_Prior(SR_parm_1(i,5), SR_parm_1(i,1), SR_parm_1(i,2), SR_parm_1(i,4), SR_parm_1(i,6), SR_parm(i)); parm_like+=SR_parm_Like(i); } } if(recdev_cycle>0) { temp=0.0; temp1=0.0; for(i=1;i<=recdev_cycle;i++) { if(recdev_cycle_parm_RD(i,5)>-1 && (active(recdev_cycle_parm(i))|| Do_all_priors>0)) { recdev_cycle_Like(i)=Get_Prior(recdev_cycle_parm_RD(i,5), recdev_cycle_parm_RD(i,1), recdev_cycle_parm_RD(i,2), recdev_cycle_parm_RD(i,4), recdev_cycle_parm_RD(i,6), recdev_cycle_parm(i)); parm_like+=recdev_cycle_Like(i); temp+=mfexp(recdev_cycle_parm(i)); temp1+=1.0; } } temp-=temp1; parm_like+=10000.*temp*temp; // similar to ADMB's approach to getting zero-centered dev_vectors } // likelihood for the random parameter time series ProgLabel_280 if(MGparm_dev_PH>0 && parm_dev_lambda(k_phase)>0.0 ) { for(i=1;i<=N_MGparm_dev;i++) for(j=MGparm_dev_minyr(i);j<=MGparm_dev_maxyr(i);j++) {parm_dev_like += 0.5*square( MGparm_dev(i,j) / MGparm_dev_stddev(i) );} } for(f=1;f<=Ntypes;f++) if(Q_setup(f,4)==3) { parm_dev_like += Q_dev_like(f,1); // mean component for dev approach (var component is already in the parm priors) // do not include for randwalk (Qsetup==4) } if(selparm_dev_PH>0 && parm_dev_lambda(k_phase)>0.0 ) { for(i=1;i<=N_selparm_dev;i++) for(j=selparm_dev_minyr(i);j<=selparm_dev_maxyr(i);j++) {parm_dev_like += 0.5*square( selparm_dev(i,j) / selparm_dev_stddev(i) );} } if(F_ballpark_yr>=styr) { if(F_Method==1) {temp=annual_F(F_ballpark_yr,1);} // sum of H rates else {temp=annual_F(F_ballpark_yr,2);} // actual total F for specified age range // in future, could allow specification of a range of years for averaging the F statistic F_ballpark_like = 0.5*square( log((F_ballpark+1.0e-6)/(temp+1.0e-6)) / 1.0) + sd_offset*log(1.0); } else {F_ballpark_like=0.0;} // ******************************************* // Penalty for soft boundaries, uses the symmetric beta prior code if(SoftBound>0) { SoftBoundPen=0.0; for(i=1;i<=N_selparm2;i++) if(active(selparm(i))) {SoftBoundPen+=Get_Prior(1, selparm_LO(i), selparm_HI(i), 1., 0.001, selparm(i));} } // CrashPen = square(1.0+CrashPen)-1.0; this was used until V3.00L 7/10/2008 CrashPen = square(1.0+ (1000.*CrashPen/(1000.+CrashPen)))-1.0; // sum the likelihood components weighted by lambda factors // ProgLabel_290 // cout<<" obj_fun start "<0) obj_fun += SzFreq_like*column(SzFreq_lambda,k_phase); // cout<<" obj_fun sizefreq "<0) obj_fun += Morphcomp_lambda(k_phase)*Morphcomp_like; if(Do_TG>0 && Nfleet>1) obj_fun += TG_like1*column(TG_lambda1,k_phase); if(Do_TG>0) obj_fun += TG_like2*column(TG_lambda2,k_phase); // cout<<" obj_fun final "<0 && mceval_counter==0) cout<<" Process STD quant "<0) { SPB_std(STD_Yr_Reverse(y))=SPB_yr(y); recr_std(STD_Yr_Reverse(y))=exp_rec(y,4); } if(STD_Yr_Reverse_Dep(y)>0) {depletion(STD_Yr_Reverse_Dep(y))=SPB_yr(y);} } if(rundetail>0 && mceval_counter==0) cout<<" STD OK "<0 && mceval_counter==0) cout<<" depletion OK "<0 && mceval_counter==0) cout<<" SPR OK "<0) { for(i=1;i<=Selex_Std_Cnt;i++) { j=Selex_Std_Pick(i); if(Selex_Std_AL==1) { Extra_Std(i)=sel_l(Selex_Std_Year,Do_Selex_Std,1,j); if(gender==2) Extra_Std(i+Selex_Std_Cnt)=sel_l(Selex_Std_Year,Do_Selex_Std,2,j); } else { Extra_Std(i)=sel_a(Selex_Std_Year,Do_Selex_Std,1,j); if(gender==2) Extra_Std(i+Selex_Std_Cnt)=sel_a(Selex_Std_Year,Do_Selex_Std,2,j); } } } if(Growth_Std_Cnt>0) { for(i=1;i<=Growth_Std_Cnt;i++) { j=Growth_Std_Pick(i); // selected age k=GP_finder(Do_Growth_Std,1); // selected GP and gender gp3 Extra_Std(gender*Selex_Std_Cnt+i)=Ave_Size(t,1,k,j); if(gender==2) { k=GP_finder(Do_Growth_Std,2); // selected GP and gender gp3 Extra_Std(gender*Selex_Std_Cnt+Growth_Std_Cnt+i)=Ave_Size(t,1,k,j); } } } if(NatAge_Std_Cnt>0) { if(Do_NatAge_Std<0) // sum all areas { p1=1; p2=pop; } else // selected area { p1=Do_NatAge_Std; p2=Do_NatAge_Std; } y=NatAge_Std_Year; t=styr+(y-styr)*nseas; // first season of selected year for(i=1;i<=NatAge_Std_Cnt;i++) { a=NatAge_Std_Pick(i); // selected age temp=0.; for(p=p1;p<=p2;p++) { for(g=1;g<=gmorph;g++) if(sx(g)==1 && use_morph(g)>0) { temp+=natage(t,p,g,a); // note, uses season 1 only } } Extra_Std(gender*(Selex_Std_Cnt+Growth_Std_Cnt)+i)=temp; if(gender==2) { temp=0.; for(p=p1;p<=p2;p++) { for(g=1;g<=gmorph;g++) if(sx(g)==2 && use_morph(g)>0) { temp+=natage(t,p,g,a); // note, uses season 1 only } } Extra_Std(gender*(Selex_Std_Cnt+Growth_Std_Cnt)+NatAge_Std_Cnt+i)=temp; } } } if(Extra_Std_N==1) { Extra_Std(1)=SPB_virgin; } } //********************************************************************* /* ProgLabel_FUNCTION 27 Check_Parm */ FUNCTION dvariable Check_Parm(const double& Pmin, const double& Pmax, const double& jitter, const prevariable& Pval) { dvariable NewVal; dvariable temp; NewVal=Pval; if(Pmin>Pmax) {N_warn++; cout<<" EXIT - see warning "< parameter max "< "<Pmax) {N_warn++; warning<<" parameter init value is greater than parameter max "< "<0.0) { temp=log((Pmax-Pmin+0.0000002)/(NewVal-Pmin+0.0000001)-1.)/(-2.); // transform the parameter temp += randn(radm) * jitter; NewVal=Pmin+(Pmax-Pmin)/(1.+mfexp(-2.*temp)); if(Pmin==-99 || Pmax==99) {N_warn++; warning<<" use of jitter not advised unless parameter min & max are in reasonable parameter range "<0) { parmvar=CoVar(AC,1); SS2out<<" "<=0.99) {SS2out<<" HI "; Nparm_on_bound++;} else {SS2out<<" OK ";} } SS2out<<" "<=0) { switch (PR_T) { case 0: {SS2out<<" Normal "; break;} case 1: {SS2out<<" Sym_Beta "; break;} case 2: {SS2out<<" Full_Beta "; break;} case 3: {SS2out<<" Log_Norm "; break;} case 4: {SS2out<<" Log_Norm_w/biasadj "; break;} case 5: {SS2out<<" Gamma "; break;} } SS2out<<" "<Pmax) temp=Pmax; parm_val(i)=temp; prior_val(i)=Get_Prior(PR_T, Pmin, Pmax, PR, CV, temp); i=4; temp=Pmin+0.01*(Pmax-Pmin); parm_val(i)=temp; prior_val(i)=Get_Prior(PR_T, Pmin, Pmax, PR, CV, temp); i=14; temp=Pmax-0.01*(Pmax-Pmin); parm_val(i)=temp; prior_val(i)=Get_Prior(PR_T, Pmin, Pmax, PR, CV, temp); for(int i=5;i<=13;i++) { temp=Pmin+float(i-4)/10.0*(Pmax-Pmin); parm_val(i)=temp; prior_val(i)=Get_Prior(PR_T, Pmin, Pmax, PR, CV, temp); } SS2out<0.0 { mu=-(Psd*(log( (Pmax+Pmin)*0.5- Pmin)))- (Psd*(log(0.5))); Prior_Like = -(mu+ (Psd*(log(Pval-Pmin+Pconst)))+(Psd*(log(1.-((Pval-Pmin-Pconst)/(Pmax-Pmin)))))); break; } case 2: // CASAL's Beta; check to be sure that Aprior and Bprior are OK before running SS2! { mu=(Pr-Pmin) / (Pmax-Pmin); // CASAL's v tau=(Pr-Pmin)*(Pmax-Pr)/square(Psd)-1.0; Bprior=tau*mu; Aprior=tau*(1.0-mu); // CASAL's m and n if(Bprior<=1.0 || Aprior <=1.0) {warning<<" bad Beta prior "<0.0) {Prior_Like = 0.5*square((log(Pval)-Pr)/Psd);} else {N_warn++; warning<<" cannot do prior in log space for parm with min <=0.0" << endl;} break; } case 4: //lognormal with bias correction (from Larry Jacobson) { if(Pmin>0.0) Prior_Like=0.5*square((log(Pval)-Pr+0.5*square(Psd))/Psd); else {N_warn++; warning<<" cannot do prior in log space for parm with min <=0.0" << endl;} break; } case 5: //gamma (from Larry Jacobson) { double warnif=1e-15; if(Pmin<0.0) {N_warn++; warning<<"Lower bound for gamma prior must be >=0. Suggestion " << warnif*10.0 <0) MaleSPB_equil_pop_gp.initialize(); equ_mat_bio=0.0; equ_mat_num=0.0; equ_catch_fleet.initialize(); equ_numbers.initialize(); equ_catage.initialize(); equ_F_std=0.0; totbio=0.0; smrybio=0.0; smryage=0.0; smrynum=0.0; for (a=0;a<=3*nages;a++) // go to 3x nages to approximate the infinite tail, then add the infinite tail { if(a<=nages) {a1=a;} else {a1=nages;} // because selex and biology max out at nages for (s=1;s<=nseas;s++) { t=t_base+s; bio_t=bio_t_base+s; for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { gg=sx(g); // gender if(a==0 && s==Bseas(g)) { if(y==styr-3) // so in benchmark { for(p=1;p<=pop;p++) {equ_numbers(s,p,g,0) = equ_Recr*recr_dist_benchmark(GP(g),s,p)*submorphdist(GP2(g));} // get the age 0 recruits for season=recr_seas } else { for(p=1;p<=pop;p++) {equ_numbers(s,p,g,0) = equ_Recr*recr_dist_calc(GP(g),s,p)*submorphdist(GP2(g));} // get the age 0 recruits for season=recr_seas } } for (p=1;p<=pop;p++) { N_beg=equ_numbers(s,p,g,a); if(F_Method==1) // Pope's approx { N_mid = N_beg*surv1(s,GP3(g),a1); // numbers at middle of season Nsurvive=N_mid; // initial number of fishery survivors if(Fishon==1) { // remove catch this round // check to see if total harves would exceed max_harvest_rate crashtemp=0.; harvest_rate=1.0; for (f=1;f<=Nfleet;f++) if (fleet_area(f)==p && Hrate(f,t)>0.) { crashtemp+=Hrate(f,t)*deadfish(s,g,f,a1); } if(crashtemp>0.20) // only worry about this if the exploit rate is at all high { join1=1./(1.+mfexp(40.0*(crashtemp-max_harvest_rate))); // steep joiner logistic curve at limit upselex=1./(1.+mfexp(Equ_F_joiner*(crashtemp-0.2))); // value of a shallow logistic curve that goes through the limit harvest_rate = join1 + (1.-join1)*upselex/(crashtemp); // ratio by which all Hrates will be adjusted } for (f=1;f<=Nfleet;f++) if (fleet_area(f)==p && Hrate(f,t)>0.) { temp=N_mid*Hrate(f,t)*harvest_rate; // numbers that would be caught if fully selected Nsurvive-=temp*deadfish(s,g,f,a1); // survival from fishery kill equ_catch_fleet(f,2) += temp*deadfish_B(s,g,f,a1); equ_catch_fleet(f,5) += temp*deadfish(s,g,f,a1); equ_catch_fleet(f,3) += temp*sel_al_2(s,g,f,a1); // retained fishery kill in biomass equ_catch_fleet(f,1)+=temp*sel_al_1(s,g,f,a1); // total fishery encounter in biomass equ_catch_fleet(f,4)+=temp*sel_al_3(s,g,f,a1); // total fishery encounter in numbers equ_catch_fleet(f,6)+=temp*sel_al_4(s,g,f,a1); // retained fishery kill in numbers equ_catage(s,f,g,a1)+=temp*deadfish(s,g,f,a1); // dead catch numbers per recruit (later accumulate N in a1) } } // end removing catch Nsurvive *= surv1(s,GP3(g),a1); // decay to end of season if(a<=a1) { equ_Z(s,p,g,a1) = -(log((Nsurvive+1.0e-13)/(N_beg+1.0e-10)))/seasdur(s); Fishery_Survival = equ_Z(s,p,g,a1)-natM(s,GP3(g),a1); if(a>=Smry_Age) { cumF(g)+=Fishery_Survival*seasdur(s); if(Fishery_Survival>maxF(g)) maxF(g)=Fishery_Survival; } } } // end Pope's approx else // Continuous F for method 2 or 3 { equ_Z(s,p,g,a1)=natM(s,GP3(g),a1); if(Fishon==1) { if(a1<=nages) { for (f=1;f<=Nfleet;f++) //loop over fishing fleets to get Z if (fleet_area(f)==p && Hrate(f,t)>0.0) { equ_Z(s,p,g,a1)+=deadfish(s,g,f,a1)*Hrate(f,t); } if(save_for_report>0) { temp=equ_Z(s,p,g,a1)-natM(s,GP3(g),a1); if(a>=Smry_Age && a<=nages) cumF(g)+=temp*seasdur(s); if(temp>maxF(g)) maxF(g)=temp; } } } Nsurvive=N_beg*mfexp(-seasdur(s)*equ_Z(s,p,g,a1)); } // end F method Survivors(p,g)=Nsurvive; } // end pop } // end morph if(Hermaphro_Option>0) { if(Hermaphro_seas==-1 || Hermaphro_seas==s) { for(p=1;p<=pop;p++) { k=gmorph/2; for(g=1;g<=k;g++) if(use_morph(g)>0) { Survivors(p,g+k) += Survivors(p,g)*Hermaphro_val(GP4(g),a1); // increment males Survivors(p,g) *= (1.-Hermaphro_val(GP4(g),a1)); // decrement females } } } } if(do_migration>0) // movement between areas in equil calcs { Survivors2.initialize(); for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { for(p=1;p<=pop;p++) for(p2=1;p2<=pop;p2++) { k=move_pattern(s,GP4(g),p,p2); if(k>0) Survivors2(p2,g) += Survivors(p,g)*migrrate(bio_yr,k,a1); } // end destination pop } Survivors=Survivors2; } // end do migration for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { for(p=1;p<=pop;p++) { if(s==nseas) // into next age at season 1 { if(a==3*nages) { // end of the cohort } else if(a==(3*nages-1)) // do infinite tail; note that it uses Z from nseas as if it applies annually { if(F_Method==1) { // equ_numbers(1,p,g,a+1) = Survivors(p,g); // equ_numbers(1,p,g,a+1) = Survivors(p,g)/(1.-exp(-natM(s,GP3(g),nages))); equ_numbers(1,p,g,a+1) = Survivors(p,g)/(1.-exp(-equ_Z(nseas,p,g,nages))); } else { equ_numbers(1,p,g,a+1) = Survivors(p,g)/(1.-exp(-equ_Z(nseas,p,g,nages))); } } else { equ_numbers(1,p,g,a+1) = Survivors(p,g); } } else { equ_numbers(s+1,p,g,a) = Survivors(p,g); // same age, next season } } } } // end season } // end age // now calc contribution to catch and ssb for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { gg=sx(g); for(s=1;s<=nseas;s++) for(p=1;p<=pop;p++) { t=t_base+s; bio_t=bio_t_base+s; equ_numbers(s,p,g,nages)+=sum(equ_numbers(s,p,g)(nages+1,3*nages)); if(Fishon==1) { if(F_Method>=2) { Zrate2(p,g)=elem_div( (1.-mfexp(-seasdur(s)*equ_Z(s,p,g))), equ_Z(s,p,g)); if(s0.0) { equ_catch_fleet(f,2)+=Hrate(f,t)*elem_prod(equ_numbers(s,p,g)(0,nages),deadfish_B(s,g,f))*Zrate2(p,g); // dead catch bio equ_catch_fleet(f,5)+=Hrate(f,t)*elem_prod(equ_numbers(s,p,g)(0,nages),deadfish(s,g,f))*Zrate2(p,g); // deadfish catch numbers equ_catch_fleet(f,3)+=Hrate(f,t)*elem_prod(equ_numbers(s,p,g)(0,nages),sel_al_2(s,g,f))*Zrate2(p,g); // retained catch bio equ_catage(s,f,g)=elem_prod(elem_prod(equ_numbers(s,p,g)(0,nages),deadfish(s,g,f)) , Zrate2(p,g)); equ_catch_fleet(f,1)+=Hrate(f,t)*elem_prod(equ_numbers(s,p,g)(0,nages),sel_al_1(s,g,f))*Zrate2(p,g); // encountered catch bio equ_catch_fleet(f,4)+=Hrate(f,t)*elem_prod(equ_numbers(s,p,g)(0,nages),sel_al_3(s,g,f))*Zrate2(p,g); // encountered catch bio equ_catch_fleet(f,6)+=Hrate(f,t)*elem_prod(equ_numbers(s,p,g)(0,nages),sel_al_4(s,g,f))*Zrate2(p,g); // retained catch numbers } } else // F_method=1 { // already done in the age loop } } if(s==1) { totbio += equ_numbers(s,p,g)(0,nages)*Wt_Age_beg(s,g)(0,nages); smrybio += equ_numbers(s,p,g)(Smry_Age,nages)*Wt_Age_beg(s,g)(Smry_Age,nages); smrynum += sum(equ_numbers(s,p,g)(Smry_Age,nages)); smryage += equ_numbers(s,p,g)(Smry_Age,nages) * r_ages(Smry_Age,nages); } if(s==spawn_seas) { // need to adjust for spawn_time_seas if(gg==1) // compute equilibrium spawning biomass for females { SPB_equil_pop_gp(p,GP4(g))+=elem_prod(equ_numbers(s,p,g)(0,nages),mfexp(-spawn_time_seas*equ_Z(s,p,g)(0,nages)))*fec(g); equ_mat_bio+=elem_prod(equ_numbers(s,p,g)(0,nages),mfexp(-spawn_time_seas*equ_Z(s,p,g)(0,nages)))*make_mature_bio(GP4(g)); equ_mat_num+=elem_prod(equ_numbers(s,p,g)(0,nages),mfexp(-spawn_time_seas*equ_Z(s,p,g)(0,nages)))*make_mature_numbers(GP4(g)); GenTime+=equ_numbers(s,p,g)(0,nages)*elem_prod(fec(g),r_ages); } else if(Hermaphro_Option>0 && gg==2) { MaleSPB_equil_pop_gp(p,GP4(g))+=elem_prod(equ_numbers(s,p,g)(0,nages),mfexp(-spawn_time_seas*equ_Z(s,p,g)(0,nages)))*Wt_Age_beg(s,g)(0,nages); equ_mat_bio+=elem_prod(equ_numbers(s,p,g)(0,nages),mfexp(-spawn_time_seas*equ_Z(s,p,g)(0,nages)))*Wt_Age_beg(s,g); equ_mat_num+=sum(elem_prod(equ_numbers(s,p,g)(0,nages),mfexp(-spawn_time_seas*equ_Z(s,p,g)(0,nages)))); } } } } YPR_dead = sum(column(equ_catch_fleet,2)); // dead yield per recruit YPR_N_dead = sum(column(equ_catch_fleet,5)); // dead numbers per recruit YPR_enc = sum(column(equ_catch_fleet,1)); // encountered yield per recruit YPR_ret = sum(column(equ_catch_fleet,3)); // retained yield per recruit if(Fishon==1) { if(F_reporting<=1) { equ_F_std=YPR_dead/smrybio; } else if(F_reporting==2) { equ_F_std=YPR_N_dead/smrynum; } else if(F_reporting==3) { if(F_Method==1) { for(s=1;s<=nseas;s++) { t=t_base+s; for (f=1;f<=Nfleet;f++) { equ_F_std+=Hrate(f,t); } } } else { for(s=1;s<=nseas;s++) { t=t_base+s; for (f=1;f<=Nfleet;f++) { equ_F_std+=Hrate(f,t)*seasdur(s); } } } } else if(F_reporting==4) { temp1=0.0; temp2=0.0; for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { for(p=1;p<=pop;p++) { for(a=F_reporting_ages(1);a<=F_reporting_ages(2);a++) // should not let a go higher than nages-2 because of accumulator { if(nseas==1) { temp1+=equ_numbers(1,p,g,a+1); temp2+=equ_numbers(1,p,g,a)*mfexp(-seasdur(1)*natM(1,GP3(g),a)); } else { temp1+=equ_numbers(1,p,g,a+1); temp3=equ_numbers(1,p,g,a); // numbers at begin of year for(int kkk=1;kkk<=nseas;kkk++) {temp3*=mfexp(-seasdur(kkk)*natM(kkk,GP3(g),a));} temp2+=temp3; } } } } equ_F_std = log(temp2)-log(temp1); } } SPB_equil=sum(SPB_equil_pop_gp); GenTime/=SPB_equil; smryage /= smrynum; cumF/=(r_ages(nages)-r_ages(Smry_Age)+1.); if(Hermaphro_maleSPB==1) SPB_equil+=sum(MaleSPB_equil_pop_gp); } //********************************************************************* /* ProgLabel_FUNCTION 31 Make_AgeLength_Key */ FUNCTION void Make_AgeLength_Key() { dvar_vector templen(2,nlength); dvar_vector AL(1,nlength1); dvar_vector use_Ave_Size_W(0,nages); AL(1)=0.0; AL(nlength1)=1.0; int gstart; int gpattern; int sex; smid=s+nseas; ALK_yr=y; gp=0; // echoinput<0) { for(gp2=1;gp2<=N_platoon;gp2++) // loop the platoons { g=gstart+ishadow(gp2); use_Ave_Size_W=Ave_Size(t,0,gstart); if(N_platoon>1) use_Ave_Size_W += shadow(gp2)*Sd_Size_between(s,gstart); dvar_matrix ALK_w_beg=ALK(s,g); // shallow copy gg=sx(g); if(Grow_logN==0) { for (a=0;a<=nages;a++) { templen=(len_bins(2,nlength)-use_Ave_Size_W(a))/(Sd_Size_within(s,gstart,a)); for (z=2;z<=nlength;z++) {AL(z)= cumd_norm(templen(z));} ALK_w_beg(a)=first_difference(AL); } // end age loop } else // lognormal size-at-age { for (a=0;a<=nages;a++) { temp=log(use_Ave_Size_W(a))-0.5*Sd_Size_within(s,gstart,a)*Sd_Size_within(s,gstart,a); // line below erroneously used sd_size_within(smid) through version 3.24S templen=(log(len_bins(2,nlength))-temp)/(Sd_Size_within(s,gstart,a)); for (z=2;z<=nlength;z++) {AL(z)= cumd_norm(templen(z));} ALK_w_beg(a)=first_difference(AL); } // end age loop } if(s==spawn_seas && gg==1) // get fecundity at age from ALK and length-spec biology { switch(Maturity_Option) { case 1: // Maturity_Option=1 length logistic { fec(g) = elem_prod(ALK_w_beg*mat_fec_len(gpattern),mat_age(gpattern)); // reproductive output at age make_mature_numbers(g)=elem_prod(ALK_w_beg*mat_len(gpattern),mat_age(gpattern)); // mature numbers at age make_mature_bio(g)=elem_prod(ALK_w_beg*elem_prod(mat_len(gpattern),wt_len(s,gg)),mat_age(gpattern)); // mature biomass at age break; } case 2: // Maturity_Option=2 age logistic { fec(g) = elem_prod(ALK_w_beg*mat_fec_len(gpattern),mat_age(gpattern)); // reproductive output at age make_mature_numbers(g)=elem_prod(ALK_w_beg*mat_len(gpattern),mat_age(gpattern)); // mature numbers at age make_mature_bio(g)=elem_prod(ALK_w_beg*elem_prod(mat_len(gpattern),wt_len(s,gg)),mat_age(gpattern)); // mature biomass at age break; } case 3: // Maturity_Option=3 read age-maturity { fec(g) = elem_prod(ALK_w_beg*mat_fec_len(gpattern),mat_age(gpattern)); // reproductive output at age make_mature_numbers(g)=elem_prod(ALK_w_beg*mat_len(gpattern),mat_age(gpattern)); // mature numbers at age (Age_Maturity already copied to mat_age) make_mature_bio(g)=elem_prod(ALK_w_beg*elem_prod(mat_len(gpattern),wt_len(s,gg)),mat_age(gpattern)); // mature biomass at age break; } case 4: // Maturity_Option=4 read age-fecundity, so no age-maturity { fec(g)=Age_Maturity(gpattern); make_mature_numbers(g)=fec(g); // not defined make_mature_bio(g)=fec(g); // not defined break; } case 5: // Maturity_Option=5 read age-fecundity from wtatage.ss { fec(g)=WTage_emp(t,GP3(g),-2); make_mature_numbers(g)=fec(g); // not defined make_mature_bio(g)=fec(g); // not defined break; } case 6: // Maturity_Option=6 read length-maturity { fec(g) = elem_prod(ALK_w_beg*mat_fec_len(gpattern),mat_age(gpattern)); // reproductive output at age make_mature_numbers(g)=elem_prod(ALK_w_beg*mat_len(gpattern),mat_age(gpattern)); // mature numbers at age (Length_Maturity already copied to mat_len) make_mature_bio(g)=elem_prod(ALK_w_beg*elem_prod(mat_len(gpattern),wt_len(s,gg)),mat_age(gpattern)); // mature biomass at age break; } } save_sel_fec(t,g,0)= fec(g); // save sel_al_3 and save fecundity for output if(y==endyr) save_sel_fec(t+nseas,g,0)=fec(g); if(save_for_report==2 && ishadow(GP2(g))==0) bodywtout<<-y<<" "<1) use_Ave_Size_W += shadow(gp2)*Sd_Size_between(smid,gstart); if(Grow_logN==0) { for (a=0; a<=nages;a++) { templen=(len_bins(2,nlength)-use_Ave_Size_W(a))/(Sd_Size_within(smid,gstart,a)); for (z=2;z<=nlength;z++) {AL(z)=cumd_norm(templen(z));} // note that AL(1) = 0.0 and AL(nlength+1)=1.0 ALK_w(a)=first_difference(AL); if(WTage_rd==0) {Wt_Age_mid(s,g)=ALK_w*wt_len(s,gg);} // use for fisheries with no size selectivity else {Wt_Age_mid(s,g)=WTage_emp(t,GP3(g),-1);} } // end age loop } else // lognormal size-at-age { for (a=0; a<=nages;a++) { temp=log(use_Ave_Size_W(a))-0.5*Sd_Size_within(smid,gstart,a)*Sd_Size_within(smid,gstart,a); templen=(log(len_bins(2,nlength))-temp)/(Sd_Size_within(smid,gstart,a)); for (z=2;z<=nlength;z++) {AL(z)=cumd_norm(templen(z));} // note that AL(1) = 0.0 and AL(nlength+1)=1.0 ALK_w(a)=first_difference(AL); if(WTage_rd==0) {Wt_Age_mid(s,g)=ALK_w*wt_len(s,gg);} // use for fisheries with no size selectivity else {Wt_Age_mid(s,g)=WTage_emp(t,GP3(g),-1);} } // end age loop } if(save_for_report==2 && ishadow(GP2(g))==0) bodywtout<<-y<<" "<endyr) {yz=endyr; } else {yz=y;} if(y>endyr+1) {yf=endyr+1;} else {yf=y;} // yf stores in endyr+1 the average selex from a range of years tz=styr+(y-styr)*nseas+s-1; // can use y, not yf, because wtage_emp values are read in and can extend into forecast for(f=1;f<=Nfleet;f++) { // if(time_vary_sel(yz,f+Ntypes)>0 || time_vary_sel(yz,f)>0 || time_vary_MG(yz,2)>0 || time_vary_MG(yz,3)>0) if(time_vary_makefishsel(yf,f)>0 || save_for_report>0) { makefishsel_yr = yf; if (WTage_rd==1) { sel_al_1(s,g,f)=elem_prod(sel_a(yf,f,gg),WTage_emp(tz,GP3(g),f)); // Wt_Age_mid has been set to WTage_emp if necessary already sel_al_3(s,g,f)=sel_a(yf,f,gg); } else if(seltype(f,1)==0) // no size_selectivity { sel_al_1(s,g,f)=elem_prod(sel_a(yf,f,gg),Wt_Age_mid(s,g)); // Wt_Age_mid has been set to WTage_emp if necessary already sel_al_3(s,g,f)=sel_a(yf,f,gg); } else { sel_al_1(s,g,f)=elem_prod(sel_a(yf,f,gg),(ALK_w * elem_prod( sel_l(yf,f,gg),wt_len(s,gg) )) ); sel_al_3(s,g,f)=elem_prod(sel_a(yf,f,gg),(ALK_w * sel_l(yf,f,gg) )); } if(mceval_phase() || save_for_report>0) { if(WTage_rd==0) {fish_body_wt(tz,g,f)=elem_div( ALK_w*elem_prod(sel_l(yf,f,gg),wt_len(s,gg)) , ALK_w*sel_l(yf,f,gg));} else {fish_body_wt(tz,g,f)=WTage_emp(tz,GP3(g),f);} if(save_for_report==2 && ishadow(GP2(g))==0) bodywtout<<-y<<" "<=2) { deadfish(s,g,f)=elem_prod(sel_a(yf,f,gg),(ALK_w * discmort2(yf,f,gg))); // selected dead by numbers if(WTage_rd==0) {deadfish_B(s,g,f)=elem_prod(sel_a(yf,f,gg),(ALK_w * elem_prod(discmort2(yf,f,gg),wt_len(s,gg)) ));} // selected dead by weight else {//deadfish_B(s,g,f)=sel_al_2(s,g,f);} // not quite correct, for now set equal to selected wt of retained fish without adjusting for discmort deadfish_B(s,g,f)=elem_prod(deadfish(s,g,f),WTage_emp(tz,GP3(g),f));} } else { deadfish_B(s,g,f)=sel_al_1(s,g,f); deadfish(s,g,f)=sel_al_3(s,g,f); } } // end need to do it save_sel_fec(t,g,f)= value(sel_al_3(s,g,f)); // save sel_al_3 in save_fecundity array for output } // end fleet loop for mortality, retention } //********************************************************************* /* ProgLabel_FUNCTION 33 get_posteriors (MCMC eval) */ FUNCTION void get_posteriors() { if(rundetail>1) cout<<" mceval counter: "<0) cout<<" did system commands "<0) cout<<" write mcmc headers "<0) post_vecs<0) post_vecs<0) { for(i=1;i<=N_MGparm_dev;i++) for(j=MGparm_dev_minyr(i);j<=MGparm_dev_maxyr(i);j++) { if(active(MGparm_dev)) posts<0) { for(i=1;i<=recdev_cycle;i++) { if(active(recdev_cycle_parm(i))) posts<0) { for(i=recdev_early_start;i<=recdev_early_end;i++) { if( active(recdev_early) ) posts<0) { for(i=recdev_start;i<=recdev_end;i++) { if( active(recdev1)||active(recdev2) ) posts<0) { for(i=recdev_end+1;i<=YrMax;i++) { if(active(Fcast_recruitments)) posts<0) { k=3*N_TG+2*Nfleet; for (j=1;j<=k;j++) { if(active(TG_parm(j))) posts<0) write_rebuilder_output(); // derived vectors quantities t=styr+(endyr+1-styr)*nseas; for(p=1;p<=pop;p++) { for (gg=1;gg<=gender;gg++) { tempvec_a.initialize(); for(g=1;g<=gmorph;g++) if(sx(g)==gg && use_morph(g)>0) { tempvec_a+=natage(t,p,g); } post_vecs<maxpossF) maxpossF=temp; } maxpossF =max_harvest_rate/maxpossF; // applies to any F_method report5<<"Calculated_Max_Allowable_F "<0) { smid=s+nseas; Make_FishSelex(); } if(SR_fxn==6 || SR_fxn==3) { alpha = 4.0 * SR_parm(2)*Recr_virgin / (5.*SR_parm(2)-1.); beta = (SPB_virgin*(1.-SR_parm(2))) / (5.*SR_parm(2)-1.); } // the spawner-recruitment function has Bzero based on virgin biology, not benchmark biology // need to deal with possibility that with time-varying biology, the SPB_virgin calculated from virgin conditions will differ from the SPB_virgin used for benchmark conditions // NEED Replacement code to calc average recr_dist from the natage // get_MGsetup(); // in case recr_dist parameters have changed // get_recr_distribution(); // find Fspr ProgLabel_710 if(show_MSY==1) { report5<<"& & & & & Fspr search"<=1;ii--) { Fmult=mfexp(F1(ii)); for(f=1;f<=Nfleet;f++) for(s=1;s<=nseas;s++) {t=bio_t_base+s; Hrate(f,t)=Fmult*Bmark_RelF_Use(s,f);} Fishon=1; Do_Equil_Calc(); yld1(ii)=SPB_equil/SPR_unf; } SPR_actual=yld1(1); if(jj==3) { Closer*=0.5; dyld=(yld1(2) - yld1(3))/df; // First derivative (to find the root of this) if(dyld!=0.) {last_F1=F1(1); F1(1) += (SPR_target-SPR_actual)/dyld; F1(1)=(1.-Closer)*F1(1)+Closer*last_F1; } // averages with last good value to keep from changing too fast else {F1(1)=(F1(1)+last_F1)*0.5;} // go halfway back towards previous value } else { if((last_calc-SPR_target)*(SPR_actual-SPR_target)<0.0) {Fchange*=-0.5;} // changed sign, so reverse search direction F1(1)+=Fchange; last_calc=SPR_actual; } if(show_MSY==1) { report5<=0.001) {N_warn++; warning<<" warning: poor convergence in Fspr search "<0 && mceval_counter==0) cout<<" got Fspr "<=1;ii--) { if(j==0) {Fmult=0.0;} else {Fmult=mfexp(F1(ii));} for(f=1;f<=Nfleet;f++) for(s=1;s<=nseas;s++) { t=bio_t_base+s; Hrate(f,t)=Fmult*Bmark_RelF_Use(s,f); } Do_Equil_Calc(); SPR_Btgt = SPB_equil/SPR_unf; // here for SPR it uses benchmark's SPB_virgin for consistency SPR_temp=SPB_equil; Get_EquilCalc = Equil_Spawn_Recr_Fxn(); // call function yld1(ii)=Get_EquilCalc(1); } Btgt=Get_EquilCalc(1); // so uses benchmark average years if(jj==3) { Closer *=0.5; dyld=(yld1(2) - yld1(3))/df; // First derivative if(dyld!=0.) {last_F1=F1(1); F1(1) -= (Btgt-Btgttgt)/dyld; F1(1)=(1.-Closer)*F1(1)+(Closer)*last_F1; } // weighted average with last good value to keep from changing too fast else {F1(1)=(F1(1)+last_F1)*0.5;} // go halfway back towards previous value } else { temp=(last_calc-Btgttgt)*(Btgt-Btgttgt)/(sfabs(last_calc-Btgttgt)*sfabs(Btgt-Btgttgt)); // values of -1 or 1 temp1=temp-1.; // values of -2 or 0 Fchange*=exp(temp1/4.)*temp; F1(1)+=Fchange; last_calc=Btgt; } if(show_MSY==1) { report5<=0.001) {N_warn++; warning<<" warning: poor convergence in Btarget search "<0 && mceval_counter==0) cout<<" got_Btgt "<=2) {Fmax=maxpossF/sum(Bmark_RelF_Use);} if(F_Method>=2) {Fmax=3.00*Btgt_Fmult;} switch(Do_MSY) { case 1: // set Fmsy=Fspr {Fmult=SPR_Fmult; if(F_Method==1) {Fmax=SPR_Fmult*1.1;} F1(1)=-log(Fmax/SPR_Fmult-1.); last_calc=0.; Fchange=1.0; Closer=1.; Nloops=0; break;} case 2: // calc Fmsy {last_calc=0.; Fchange=0.51; Closer=1.0; if(SR_fxn==5) {Nloops=40;} else {Nloops=19;} if(F_Method==1) {Fmax=(Btgt_Fmult+SPR_Fmult)*0.5*SR_parm(2)/0.05;} // previously /0.18 F1(1)=-log(Fmax/Btgt_Fmult-1.); // break;} case 3: // set Fmsy=Fbtgt {Fmult=Btgt_Fmult; if(F_Method==1) {Fmax=Btgt_Fmult*1.1;} F1(1)=-log(Fmax/Btgt_Fmult-1.); last_calc=0.; Fchange=1.0; Closer=1.0; Nloops=0; break;} case 4: // set fmult for Fmsy to 1 {Fmult=1; Fmax=1.1; F1(1)=-log(Fmax/Fmult-1.); last_calc=0.; Fchange=1.0; Closer=1.0; Nloops=0; break;} } if(show_MSY==1) { report5<<"+ + + + + + + + + findFmsy"<=1;ii--) { Fmult=Fmax/(1.00+mfexp(-F1(ii))); // so maxes out at Fmax for(f=1;f<=Nfleet;f++) for(s=1;s<=nseas;s++) {t=bio_t_base+s; Hrate(f,t)=Fmult*Bmark_RelF_Use(s,f);} Do_Equil_Calc(); MSY_SPR = SPB_equil/SPR_unf; SPR_temp=SPB_equil; Get_EquilCalc = Equil_Spawn_Recr_Fxn(); // call function Bmsy=Get_EquilCalc(1); Recr_msy=Get_EquilCalc(2); yld1(ii)=YPR_dead*Recr_msy; // *mfexp(-Equ_penalty); Yield=YPR_dead*Recr_msy; bestF1+=F1(ii)*(pow(mfexp(Yield/1.0e08),5)-1.); bestF2+=pow(mfexp(Yield/1.0e08),5)-1.; } // end gradient calc dyld = (yld1(2) - yld1(3))/df; // First derivative (to find the root of this) temp = (yld1(2) + yld1(3) - 2.*yld1(1))/(.25*df*df); // Second derivative (for Newton Raphson) dyldp = -sqrt(temp*temp+1.); // add 1 to keep curvature reasonably large last_F1=F1(1); temp = F1(1)-dyld*(1.-Closer)/(dyldp); if(show_MSY==1) { report5<=0.001 && Do_MSY==2) {N_warn++; warning<<" warning: poor convergence in Fmsy, final dy/dy2= "<0) report5<0) { if(GP4(g)==gp && sx(g)==gg) tempvec_a+= value(Recr_msy*equ_numbers(1,p,g)(0,nages)); } if(nseas>1) { tempvec_a(0)=0.; for(s=1;s<=nseas;s++) for (p=1;p<=pop;p++) for (g=1;g<=gmorph;g++) if(use_morph(g)>0 && Bseas(g)==s) { if(GP4(g)==gp && sx(g)==gg) tempvec_a(0) += value(Recr_msy*equ_numbers(1,p,g,0)); } } report5 <0) report5<0) { if(GP4(g)==gp && sx(g)==gg) tempvec_a+= value(Recr_msy*equ_numbers(1,p,g)(0,nages)); } if(nseas>1) { tempvec_a(0)=0.; for(s=1;s<=nseas;s++) for (p=1;p<=pop;p++) for (g=1;g<=gmorph;g++) if(use_morph(g)>0 && Bseas(g)==s) { if(GP4(g)==gp && sx(g)==gg) tempvec_a(0) += value(Recr_msy*equ_numbers(1,p,g,0)); } } report5 <= SPR_Fmult) {N_warn++; warning<<" Fmsy is >3x of Fspr are you sure? check for convergence "<= Fmax) {N_warn++; warning<<" Fmsy is close to max allowed; check for convergence "<0 && mceval_counter==0) cout<<" got Fmsy "<F_std_because_of_selex)"<0 && mceval_counter==0) cout<<" Do Forecast "<0) { report5<<"-1_:_Input_fixed_catches_or_F_with_fleet/time_specific_values"<F_std_because_of_selex)"<0) // apply implementation error, which is a random variable, so adds variance to forecast // in future, could do this a fleet-specific implementation error { for(s=1;s<=nseas;s++) { t=t_base+s; for(f=1;f<=Nfleet;f++) {Fcast_Catch_Store(t,f)*=mfexp(Fcast_impl_error(y));} // should this be bias adjusted? } } // do biology for this year yz=endyr+1; // biology year for parameters if(time_vary_MG(endyr+1,2)>0 || save_for_report>0) // so uses endyr+1 timevary setting for duration of forecast { get_MGsetup(); get_growth2(); } // ABC_loop: 1=get OFL; 2=get_ABC, use input catches; 3=recalc with caps and allocations for(int ABC_Loop=ABC_Loop_start; ABC_Loop<=ABC_Loop_end;ABC_Loop++) { totcatch=0.; if(ABC_Loop==1) Mgmt_quant(Fcast_catch_start+N_Fcast_Yrs+y-endyr)=0.0; // for OFL Mgmt_quant(Fcast_catch_start+y-endyr)=0.0; // for ABC if(Do_Retain==1) Mgmt_quant(Fcast_catch_start+2*N_Fcast_Yrs+y-endyr)=0.0; // for retained ABC if(STD_Yr_Reverse_F(y)>0) F_std(STD_Yr_Reverse_F(y))=0.0; for(s=1;s<=nseas;s++) { t = t_base+s; smid=s+nseas; bio_t=styr+(endyr-styr)*nseas+s-1; if(ABC_Loop==ABC_Loop_start) // do seasonal ALK and fishery selex { if(time_vary_MG(endyr+1,2)>0 || time_vary_MG(endyr+1,3)>0 || WTage_rd>0) { Make_AgeLength_Key(); // indexed by season and gmorph } else { Ave_Size(t)=Ave_Size(t-nseas); Save_Wt_Age(t)=Wt_Age_beg(s); } for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { Make_FishSelex(); // calcs fishery selex by current season, all fleets, current gmorph } } // end of seasonal biology if(s==nseas) {adv_age=1;} else {adv_age=0;} // advance age or not when doing survivorship if(s==spawn_seas) // get spawnbio in a forecast year { // NEED to adjust for timing within season!!! SPB_pop_gp(y).initialize(); SPB_B_yr(y).initialize(); SPB_N_yr(y).initialize(); for (p=1;p<=pop;p++) { for (g=1;g<=gmorph;g++) if(sx(g)==1 && use_morph(g)>0) // female { SPB_pop_gp(y,p,GP4(g))+=fec(g)*natage(t,p,g); SPB_B_yr(y) += make_mature_bio(GP4(g))*natage(t,p,g); SPB_N_yr(y) += make_mature_numbers(GP4(g))*natage(t,p,g); } } SPB_current=sum(SPB_pop_gp(y)); SPB_yr(y)=SPB_current; if(Hermaphro_Option>0) // get male biomass { temp=0.0; MaleSPB(y).initialize(); for (p=1;p<=pop;p++) { for (g=1;g<=gmorph;g++) if(sx(g)==2 && use_morph(g)>0) // male; all assumed to be mature { MaleSPB(y,p,GP4(g)) += Save_Wt_Age(t,g)*natage(t,p,g); // accumulates SSB by area and by growthpattern temp += sum(natage(t,p,g)); } } if(Hermaphro_maleSPB==1) // add MaleSPB to female SSB { SPB_current+=sum(MaleSPB(y)); SPB_yr(y)=SPB_current; SPB_B_yr(y) += sum(MaleSPB(y)); SPB_N_yr(y) += temp; } } Recruits=Spawn_Recr(SPB_current); // recruitment with deviations if(Fcast_Loop10) { gg=sx(g); // if(s==Bseas(g)) {natage(t,p,g,0) = Recruits*recr_dist_calc(GP(g),s,p)*submorphdist(GP2(g));} //get recruits from total recruits and RecrDist if(s==Bseas(g)) {natage(t,p,g,0) = Recruits*recr_dist_forecast(GP(g),s,p)*submorphdist(GP2(g));} //get recruits from total recruits and RecrDist totbio+=natage(t,p,g)*Wt_Age_beg(s,g); temp=natage(t,p,g)(Smry_Age,nages)*Wt_Age_beg(s,g)(Smry_Age,nages); smrybio+=temp; smrynum+=sum(natage(t,p,g)(Smry_Age,nages)); if(save_for_report==1) { Save_PopLen(t,p,g)=0.0; Save_PopLen(t,p+pop,g)=0.0; // later put midseason here Save_PopWt(t,p,g)=0.0; Save_PopWt(t,p+pop,g)=0.0; // later put midseason here Save_PopAge(t,p,g)=value(natage(t,p,g)); for (a=0;a<=nages;a++) { Save_PopLen(t,p,g)+=value(natage(t,p,g,a))*value(ALK(s,g,a)); Save_PopWt(t,p,g)+= value(natage(t,p,g,a))*value(elem_prod(ALK(s,g,a),wt_len(s,sx(g)))); } // close age loop } } // report5<-1.0) // have an input { if(Fcast_InputCatch(t,f,2)<=3) // input is catch { if(Fcast_InputCatch(t,f,1)==0.0) { Hrate(f,t)=0.0; Do_F_tune(t,f)=0; } else { Tune_F_loops=8; Do_F_tune(t,f)=1; } } else {Hrate(f,t)=Fcast_InputCatch(t,f,1);} // input is as Hrate (F), but do not need tuning } break; } case 3: // always get F to match catch when in ABC_Loop==3 { Tune_F_loops=8; Do_F_tune(t,f)=1; break; } } } if(F_Method==1) // Pope's { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { Nmid(g) = elem_prod(natage(t,p,g),surv1(s,GP3(g))); } for(Tune_F=1;Tune_F<=Tune_F_loops;Tune_F++) { for (f=1;f<=Nfleet;f++) // get calculated catch if (fleet_area(f)==p && Fcast_RelF_Use(s,f)>0.0) { temp=0.0; if(Do_F_tune(t,f)==1) // have an input catch, so get expected catch from F and Z { if(ABC_Loop==2) // tune to input catch { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(catchunits(f)==1) // catch in weight { if(Fcast_InputCatch(t,f,2)==2) {temp+=Nmid(g)*deadfish_B(s,g,f);} // dead catch bio else if(Fcast_InputCatch(t,f,2)==3) {temp+=Nmid(g)*sel_al_2(s,g,f);} // retained catch bio } else // catch in numbers { if(Fcast_InputCatch(t,f,2)==2) {temp+=Nmid(g)*deadfish(s,g,f);} // deadfish catch numbers else if(Fcast_InputCatch(t,f,2)==3) {temp+=Nmid(g)*sel_al_4(s,g,f);} // retained catch numbers } } //close gmorph loop temp=max_harvest_rate-Fcast_InputCatch(t,f,1)/(temp+NilNumbers); Hrate(f,t)=max_harvest_rate-posfun(temp,0.0001,Fcast_Crash); } else // tune to adjusted catch calculated from ABC_Loop=2 (note different basis for catch) { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(Fcast_Catch_Basis==2) {temp+=Nmid(g)*deadfish_B(s,g,f);} // dead catch bio else if(Fcast_Catch_Basis==3) {temp+=Nmid(g)*sel_al_2(s,g,f);} // retained catch bio else if(Fcast_Catch_Basis==5) {temp+=Nmid(g)*deadfish(s,g,f);} // deadfish catch numbers else if(Fcast_Catch_Basis==6) {temp+=Nmid(g)*sel_al_4(s,g,f);} // retained catch numbers } //close gmorph loop temp=max_harvest_rate-Fcast_Catch_Store(t,f)/(temp+NilNumbers); Hrate(f,t)=max_harvest_rate-posfun(temp,0.0001,Fcast_Crash); } } // end have fixed catch to be matched } // end fishery loop } // end finding the Hrates // now get catch details and survivorship Nsurv=Nmid; // initialize the number of survivors for (f=1;f<=Nfleet;f++) //loop over fishing fleets ProgLabel_105 if (fleet_area(f)==p) { catch_fleet(t,f).initialize(); temp=Hrate(f,t); for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { // Nmid(g) = elem_prod(natage(t,p,g),surv1(s,GP3(g))); catch_fleet(t,f,1)+=Nmid(g)*sel_al_1(s,g,f); // encountered catch bio catch_fleet(t,f,2)+=Nmid(g)*deadfish_B(s,g,f); // dead catch bio catch_fleet(t,f,3)+=Nmid(g)*sel_al_2(s,g,f); // retained catch bio catch_fleet(t,f,4)+=Nmid(g)*sel_al_3(s,g,f); // encountered catch numbers catch_fleet(t,f,5)+=Nmid(g)*deadfish(s,g,f); // deadfish catch numbers catch_fleet(t,f,6)+=Nmid(g)*sel_al_4(s,g,f); // retained catch numbers catage_w(g)= temp*elem_prod(Nmid(g),deadfish(s,g,f)); Nsurv(g)-=catage_w(g); } //close gmorph loop catch_fleet(t,f)*=temp; } // close fishery for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(s0) { Z_rate(t,p,g)=natM(s,GP3(g)); for (f=1;f<=Nfleet;f++) //loop over fishing fleets to get Z ProgLabel_105 if (fleet_area(f)==p && Fcast_RelF_Use(s,f)>0.0) { Z_rate(t,p,g)+=deadfish(s,g,f)*Hrate(f,t); } Zrate2(p,g)=elem_div( (1.-mfexp(-seasdur(s)*Z_rate(t,p,g))), Z_rate(t,p,g)); } // end morph for (f=1;f<=Nfleet;f++) // get calculated catch if (fleet_area(f)==p && Fcast_RelF_Use(s,f)>0.0) { temp=0.0; if(Do_F_tune(t,f)==1) // have an input catch, so get expected catch from F and Z { if(ABC_Loop==2) // tune to input catch { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(catchunits(f)==1) // catch in weight { if(Fcast_InputCatch(t,f,2)==2) {temp+=elem_prod(natage(t,p,g),deadfish_B(s,g,f))*Zrate2(p,g);} // dead catch bio else if(Fcast_InputCatch(t,f,2)==3) {temp+=elem_prod(natage(t,p,g),sel_al_2(s,g,f))*Zrate2(p,g);} // retained catch bio } else // catch in numbers { if(Fcast_InputCatch(t,f,2)==2) {temp+=elem_prod(natage(t,p,g),deadfish(s,g,f))*Zrate2(p,g);} // deadfish catch numbers else if(Fcast_InputCatch(t,f,2)==3) {temp+=elem_prod(natage(t,p,g),sel_al_4(s,g,f))*Zrate2(p,g);} // retained catch numbers } } //close gmorph loop temp*=Hrate(f,t); H_temp(f)=Hrate(f,t); C_temp(f)=temp; if(Tune_F<3) { C_old(f)=C_temp(f); H_old(f)=H_temp(f); Hrate(f,t)*=(Fcast_InputCatch(t,f,1)+1.0)/(temp+1.0); // apply adjustment } else { Hrate(f,t)=H_old(f)+(H_temp(f)-H_old(f))/(C_temp(f)-C_old(f)+1.0e-6) * (Fcast_InputCatch(t,f,1)-C_old(f)); C_old(f)=C_temp(f); H_old(f)=H_temp(f); } } else // tune to adjusted catch calculated in ABC_Loop=2 (note different basis for catch) { for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(Fcast_Catch_Basis==2) {temp+=elem_prod(natage(t,p,g),deadfish_B(s,g,f))*Zrate2(p,g);} // dead catch bio else if(Fcast_Catch_Basis==3) {temp+=elem_prod(natage(t,p,g),sel_al_2(s,g,f))*Zrate2(p,g);} // retained catch bio else if(Fcast_Catch_Basis==5) {temp+=elem_prod(natage(t,p,g),deadfish(s,g,f))*Zrate2(p,g);} // deadfish catch numbers else if(Fcast_Catch_Basis==6) {temp+=elem_prod(natage(t,p,g),sel_al_4(s,g,f))*Zrate2(p,g);} // retained catch numbers } //close gmorph loop temp*=Hrate(f,t); // Hrate(f,t)*=(Fcast_Catch_Store(t,f)+1.0)/(temp+1.0); // apply adjustment H_temp(f)=Hrate(f,t); C_temp(f)=temp; if(Tune_F<3) { C_old(f)=C_temp(f); H_old(f)=H_temp(f); Hrate(f,t)*=(Fcast_Catch_Store(t,f)+1.0)/(temp+1.0); // apply adjustment // report5<<" new "<0) { tempvec_a=Hrate(f,t)*Zrate2(p,g); catch_fleet(t,f,1)+=tempvec_a*elem_prod(natage(t,p,g),sel_al_1(s,g,f)); // encountered catch bio catch_fleet(t,f,2)+=tempvec_a*elem_prod(natage(t,p,g),deadfish_B(s,g,f)); // dead catch bio catch_fleet(t,f,3)+=tempvec_a*elem_prod(natage(t,p,g),sel_al_2(s,g,f)); // retained catch bio catch_fleet(t,f,4)+=tempvec_a*elem_prod(natage(t,p,g),sel_al_3(s,g,f)); // encountered catch numbers catch_fleet(t,f,5)+=tempvec_a*elem_prod(natage(t,p,g),deadfish(s,g,f)); // deadfish catch numbers catch_fleet(t,f,6)+=tempvec_a*elem_prod(natage(t,p,g),sel_al_4(s,g,f)); // retained catch numbers } //close gmorph loop } // close fishery for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(s0) //hermaphroditism { if(Hermaphro_seas==-1 || Hermaphro_seas==s) { k=gmorph/2; for (g=1;g<=k;g++) // loop females if(use_morph(g)>0) { for (a=1;a0.) {report5<<" "<0) // movement between areas in forecast { natage_temp=natage(t+1); natage(t+1).initialize(); for (p=1;p<=pop;p++) // source population for (p2=1;p2<=pop;p2++) // destination population for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { k=move_pattern(s,GP4(g),p,p2); if(k>0) natage(t+1,p2,g) += elem_prod(natage_temp(p,g),migrrate(bio_yr,k)); } } if( (save_for_report>0) || ((sd_phase() || mceval_phase()) && (initial_params::mc_phase==0)) ) { if(Fcast_Loop1==2 && ABC_Loop==1) // get variance in OFL { for(f=1;f<=Nfleet;f++) {Mgmt_quant(Fcast_catch_start+N_Fcast_Yrs+y-endyr)+=catch_fleet(t,f,2);} } if(Fcast_Loop1==Fcast_Loop_Control(1) && ABC_Loop==3) // in final loop, so do variance quantities { if(STD_Yr_Reverse_F(y)>0) { if(F_reporting<=1) { for(f=1;f<=Nfleet;f++) F_std(STD_Yr_Reverse_F(y))+=catch_fleet(t,f,2); // add up dead catch biomass if(s==nseas) F_std(STD_Yr_Reverse_F(y))/=Smry_Table(y,2); } else if(F_reporting==2) { for(f=1;f<=Nfleet;f++) F_std(STD_Yr_Reverse_F(y))+=catch_fleet(t,f,5); // add up dead catch numbers if(s==nseas) F_std(STD_Yr_Reverse_F(y))/=Smry_Table(y,3); } else if(F_reporting==3) { if(F_Method==1) { for(f=1;f<=Nfleet;f++) { F_std(STD_Yr_Reverse_F(y))+=Hrate(f,t); } } else { for(f=1;f<=Nfleet;f++) { F_std(STD_Yr_Reverse_F(y))+=Hrate(f,t)*seasdur(s); } } } else if(F_reporting==4 && s==nseas) { // sum across p and g the number of survivors to end of the year // also project from the initial numbers and M, the number of survivors without F // then F = ln(n+1/n)(M+F) - ln(n+1/n)(M only), but ln(n) cancels out, so only need the ln of the ratio of the two ending quantities temp1=0.0; temp2=0.0; for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { for(p=1;p<=pop;p++) { for(a=F_reporting_ages(1);a<=F_reporting_ages(2);a++) // should not let a go higher than nages-2 because of accumulator { if(nseas==1) { temp1+=natage(t+1,p,g,a+1); temp2+=natage(t,p,g,a)*mfexp(-seasdur(s)*natM(s,GP3(g),a)); } else { temp1+=natage(t+1,p,g,a+1); temp3=natage(t-nseas+1,p,g,a); // numbers at begin of year for(j=1;j<=nseas;j++) {temp3*=mfexp(-seasdur(j)*natM(j,GP3(g),a));} temp2+=temp3; } } } } F_std(STD_Yr_Reverse_F(y)) = log(temp2)-log(temp1); } } for(f=1;f<=Nfleet;f++) { Mgmt_quant(Fcast_catch_start+y-endyr)+=catch_fleet(t,f,2); if(Do_Retain==1) Mgmt_quant(Fcast_catch_start+2*N_Fcast_Yrs+y-endyr)+=catch_fleet(t,f,3); } } } // store catches to allow calc of adjusted F to match this catch when doing ABC_loop=3, and then when doing Fcast_loop1=3 for(f=1;f<=Nfleet;f++) { Fcast_Catch_Store(t,f)=catch_fleet(t,f,Fcast_Catch_Basis); totcatch+=Fcast_Catch_Store(t,f); } // report5<0) {report5<0 && y>=Fcast_Cap_FirstYear) { for(f=1;f<=Nfleet;f++) // adjust ABC catch to fleet caps { if(Fcast_MaxFleetCatch(f)>0.) { temp = Fcast_Catch_Current_Alloc(f)/Fcast_MaxFleetCatch(f); join1=1./(1.+mfexp(1000.*(temp-1.0))); // steep logistic joiner at adjustment of 1.0 temp1=join1*1.0 + (1.-join1)*temp; Fcast_Catch_Current_Alloc(f)/=temp1; for(s=1;s<=nseas;s++) {Fcast_Catch_Store(t_base+s,f)/=temp1;} } } // report5<0 && y>=Fcast_Cap_FirstYear) // scale down if Totcatch exceeds Max_Fcast_Catch (in this area) { if(pop==1) // one area { Fcast_Catch_ByArea(1)=sum(Fcast_Catch_Current_Alloc(1,Nfleet)); } else { Fcast_Catch_ByArea=0.0; for(f=1;f<=Nfleet;f++) { Fcast_Catch_ByArea(fleet_area(f))+=Fcast_Catch_Current_Alloc(f); } } for(p=1;p<=pop;p++) if(Max_Fcast_Catch(p)>0.0) { temp = Fcast_Catch_ByArea(p)/Max_Fcast_Catch(p); join1=1./(1.+mfexp(1000.*(temp-1.0))); // steep logistic joiner at adjustment of 1.0 temp1=join1*1.0 + (1.-join1)*temp; for(f=1;f<=Nfleet;f++) if (fleet_area(f)==p) { Fcast_Catch_Current_Alloc(f)/=temp1; // adjusts total for the year for(s=1;s<=nseas;s++) {Fcast_Catch_Store(t_base+s,f)/=temp1;} } } // report5<0 && y>=Fcast_Cap_FirstYear) // adjust to get a specific fleet allocation { Fcast_Catch_Current_Allocation=0.0; for(g=1;g<=Fcast_Catch_Allocation_Groups;g++) for(f=1;f<=Nfleet;f++) if (Allocation_Fleet_Assignments(f)==g) { Fcast_Catch_Current_Allocation(g)+=Fcast_Catch_Current_Alloc(f); } temp=sum(Fcast_Catch_Current_Allocation); // total catch for all fleets that are part of the allocation scheme temp1=sum(Fcast_Catch_Allocation(y-endyr)); // total of all allocation fractions for all fleets that are part of the allocation scheme for(g=1;g<=Fcast_Catch_Allocation_Groups;g++) { temp2=(Fcast_Catch_Allocation(y-endyr,g)/temp1) / (Fcast_Catch_Current_Allocation(g)/temp); for(f=1;f<=Nfleet;f++) if (Allocation_Fleet_Assignments(f)==g) { Fcast_Catch_Current_Alloc(f)*=temp2; for(s=1;s<=nseas;s++) { Fcast_Catch_Store(t_base+s,f)*=temp2; } } } // report5<0)) || ((sd_phase() || mceval_phase()) && (initial_params::mc_phase==0)) ) { eq_yr=y; equ_Recr=Recr_virgin; bio_yr=endyr; Fishon=0; Do_Equil_Calc(); // call function to do equilibrium calculation SPR_unf=SPB_equil; Smry_Table(y,11)=SPR_unf; Smry_Table(y,13)=GenTime; Fishon=1; Do_Equil_Calc(); // call function to do equilibrium calculation SPR_trial=SPB_equil; if(STD_Yr_Reverse_Ofish(y)>0) SPR_std(STD_Yr_Reverse_Ofish(y))=SPR_trial/SPR_unf; Smry_Table(y,9)=totbio; Smry_Table(y,10)=smrybio; Smry_Table(y,12)=SPR_trial; Smry_Table(y,14)=YPR_dead; for(g=1;g<=gmorph;g++) { Smry_Table(y,20+g)=(cumF(g)); Smry_Table(y,20+gmorph+g)=(maxF(g)); } } } // end year loop } // end Fcast_Loop1 for the different stages of the forecast } // end forecast function //********************************************************************* /* ProgLabel_FUNCTION 36 write_summaryoutput */ FUNCTION void write_summaryoutput() { random_number_generator radm(long(time(&finish))); time(&finish); elapsed_time = difftime(finish,start); report2<=1) report2<<" Start_from_SS3.PAR"; report2<0) { for(j=1;j<=N_SC;j++) report2<0) { for(j=1;j<=N_DC;j++) report2<0) { for(j=1;j<=N_CC;j++) report2<0) { for(j=1;j<=N_FC;j++) report2<max_lambda_phase) k=max_lambda_phase; report2<0) report2<0) report2<0) report2<0) report2<0) report2<0) report2<1) report2<0) report2<0) report2<0) report2<0) report2<0) report2<0) report2<0) report2<0) report2<0) report2<0) report2<0) report2<0) report2<0) { report2<0) report2<0) { report2<0) { report2<0) { report2<0) { report2<0) { report2<0) { report2<0) { report2<0) for(f=1;f<=Ntypes;f++) if(nyr_cr(f)>0) { report2 <=0) // lognormal or lognormal T_dist {report2 <0) { report2 <0) { report2 <0 && mceval_counter==0) cout<<" produce output for rebuilding package"<0.0) // active fishery in this area in endyr { j=1; for(g=1;g<=gmorph;g++) if(sx(g)==gg) { tempvec_a+=elem_prod(fish_body_wt(t,g,f),natage(t+s-1,p,g)*Fcast_RelF_Use(s,f)); // body wt tempvec2+=elem_prod(sel_al_3(s,g,f),natage(t+s-1,p,g)*Fcast_RelF_Use(s,f)); //no wt tempvec3+=natage(t+s-1,p,g)*Fcast_RelF_Use(s,f); } } if(j==1) { tempvec_a= elem_div(tempvec_a,tempvec3); tempvec2 = elem_div(tempvec2,tempvec3); rebuilder <0) { tempvec_a+=elem_prod(natM(1,GP3(g)),natage(t,p,g)); tempvec2+=natage(t,p,g); // note, uses season 1 only } } tempvec_a=elem_div(tempvec_a,tempvec2); rebuilder<k) k=Rebuild_Yinit; //f. "blank line" used for header for following lines rebuilder <<"#R0 "<endyr) rebuild_dat<<" "<=Rebuild_Ydecl+1) { for(y=Rebuild_Ydecl+1;y<=Rebuild_Yinit;y++) rebuild_dat<9)"<9); Approach (-1=Read in else 1-9)"<0=T"<0) for (i=1;i<=nobs_cr_rd;i++) { f=abs(indexdata(i,3)); report1 << indexdata(i)<<" # "<0) { report1<<"#_discard_units (1=same_as_catchunits(bio/num); 2=fraction; 3=numbers)"<< endl; report1<<"#_discard_errtype: >0 for DF of T-dist(read CV below); 0 for normal with CV; -1 for normal with se; -2 for lognormal"<0) report1<0 for DF of T-dist(read CV below); 0 for normal with CV; -1 for normal with se; -2 for lognormal"<0) { report1 << "#_year seas index part obs cv"<0) report1<0) report1<0) report1 << age_err_rd << endl; report1 <0) report1<0) report1<0) report1<0) { report1< "<0) { // info on dimensions of tagging data report1< area yr season gender age Nrelease (note that the TG and tfill values are placeholders and are replaced by program generated values)"<0.0) { report1<<" 0.1 "; // for bycatch only fleet } else if(catchunits(f)==1) {report1<0=T"<0) for(f=1;f<=Ntypes;f++) for (i=1;i<=nyr_cr(f);i++) { report1 << yr_cr_y(f,i)<<" "<0) { if(cr_errtype(f)>=0) // lognormal { report1 << mfexp(exp_cr(f,i)+log_q_cr(f,i)); } else if(cr_errtype(f)==-1) // normal { report1<0) { report1<<"#_discard_units (1=same_as_catchunits(bio/num); 2=fraction; 3=numbers)"<< endl; report1<<"#_discard_errtype: >0 for DF of T-dist(read CV below); 0 for normal with CV; -1 for normal with se; -2 for lognormal"<0) report1<0) for (i=1;i<=nyr_disc(f);i++) { s=abs(yr_disc_s(f,i)); report1 << yr_disc_y(f,i)<<" "<= 0.0 ) {report1 << exp_disc(f,i);} else {report1 << obs_disc(f,i);} report1 << " "<< cv_disc(f,i)<<" #_orig_obs: "<0 for DF of T-dist(read CV below); 0 for normal with CV; -1 for normal with se; -2 for lognormal"<0) {report1 << "#_year seas index part obs cv"<0) { for(i=1;i<=Nobs_l(f);i++) { if(nsamp_l(f,i)>0 && header_l(f,i,3)) // do only if this was a real observation { k=1000; if(nsamp_l(f,i)0) report1<0) report1 << age_err_rd << endl; report1 <0) for(f=1;f<=Ntypes;f++) { if(Nobs_a(f)>=1) { for(i=1;i<=Nobs_a(f);i++) { if(nsamp_a(f,i)>0 && header_a(f,i,3)>0) // if real observation { k=1000; if(nsamp_a(f,i)0) for(f=1;f<=Ntypes;f++) { if(Nobs_ms(f)>0) { for(i=1;i<=Nobs_ms(f);i++) { report1 << header_ms(f,i)(1,7); for(a=1;a<=n_abins2;a++) { report1 << " " ; if(obs_ms_n(f,i,a)>0) {temp=exp_ms(f,i,a); if(temp<=0.) {temp=0.0001;} report1 << temp;} else {report1 << obs_ms(f,i,a) ;} } report1 << endl<< elem_prod(obs_ms_n(f,i),obs_ms_n(f,i)) << endl; } } } report1 << endl << N_envvar<<" #_N_environ_variables"<0) report1<0) { report1< "<0) // flag for date range in bounds { report1<0) { // info on dimensions of tagging data report1< area yr season gender age Nrelease (note that the TG and tfill values are placeholders and are replaced by program generated values)"<TG_maxperiods) t=TG_maxperiods; report1<0.0) { report1<<" 0.1 "; // for bycatch only fleet } else if(catchunits(f)==1) {report1<0=T"<0) for(f=1;f<=Ntypes;f++) for (i=1;i<=nyr_cr(f);i++) { report1 << yr_cr_y(f,i)<<" "< 0) { if(cr_errtype(f)==-1) // normal error { report1<0) // lognormal T_dist { temp = sqrt( (cr_errtype(f)+1.)/cr_errtype(f)); // where df=cr_errtype(f) report1 << mfexp(exp_cr(f,i)+log_q_cr(f,i)+ randn(radm)*se_cr_use(f,i)*temp ); // adjusts the sd by the df sample size } } else { report1 << obs_cr(f,i); } report1 <<" "<0) { report1<<"#_discard_units (1=same_as_catchunits(bio/num); 2=fraction; 3=numbers)"<< endl; report1<<"#_discard_errtype: >0 for DF of T-dist(read CV below); 0 for normal with CV; -1 for normal with se; -2 for lognormal"<0) report1<0) for (i=1;i<=nyr_disc(f);i++) { s=abs(yr_disc_s(f,i)); report1 << yr_disc_y(f,i)<<" "<= 0.0 ) { if(disc_errtype(f)>=1) {temp=exp_disc(f,i) + randn(radm)*sd_disc(f,i)*sqrt((disc_errtype(f)+1.)/disc_errtype(f)) * exp_disc(f,i); if(temp<0.001) temp=0.001;} else if(disc_errtype(f)==0) {temp=exp_disc(f,i) + randn(radm)*sd_disc(f,i); if(temp<0.001) temp=0.001; } else if(disc_errtype(f)==-1) {temp=exp_disc(f,i) + randn(radm)*sd_disc(f,i); if(temp<0.001) temp=0.001; } else if(disc_errtype(f)==-2) {temp=exp_disc(f,i) * mfexp(randn(radm)*sd_disc(f,i));} } else {temp=obs_disc(f,i);} report1 <<" "<0 for DF of T-dist(read CV below); 0 for normal with CV; -1 for normal with se; -2 for lognormal"<0) { report1 << "#_year seas index part obs cv"<0 && mnwtdata(5,i)>0.) { temp=exp_mnwt(i)+randn(radm)*mnwtdata(6,i)*sqrt((DF_bodywt+1.)/DF_bodywt) *exp_mnwt(i); if(temp<=0.0) {temp=0.0001;} } else { temp=mnwtdata(5,i); } report1 << mnwtdata(1,i)<<" "<0) { for(i=1;i<=Nobs_l(f);i++) { if(nsamp_l(f,i)>0 && header_l(f,i,3)>0) // do only if this was a real observation { k=1000; if(nsamp_l(f,i)0) report1<0) report1 << age_err_rd << endl; report1 <0) for(f=1;f<=Ntypes;f++) { if(Nobs_a(f)>=1) { for(i=1;i<=Nobs_a(f);i++) { if(nsamp_a(f,i)>0 && header_a(f,i,3)>0) // if real observation { k=1000; if(nsamp_a(f,i)0) for(f=1;f<=Ntypes;f++) { if(Nobs_ms(f)>0) { for(i=1;i<=Nobs_ms(f);i++) { report1 << header_ms(f,i)(1,7); for(a=1;a<=n_abins2;a++) { report1 << " " ; if(obs_ms_n(f,i,a)>0) {temp=exp_ms(f,i,a)+randn(radm)*exp_ms_sq(f,i,a)/obs_ms_n(f,i,a); if(temp<=0.) {temp=0.0001;} report1 << temp;} else {report1 << exp_ms(f,i,a) ;} } report1 << endl<< elem_prod(obs_ms_n(f,i),obs_ms_n(f,i)) << endl; } } } report1 << endl << N_envvar<<" #_N_environ_variables"<0) report1<0) { report1< "<0) // flag for date range in bounds and used { j=1000; if(SzFreq_obs1(iobs,7)0) { dvector temp_negbin(1,1); // info on dimensions of tagging data report1< area yr season gender age Nrelease (note that the TG and tfill values are placeholders and are replaced by program generated values)"<TG_maxperiods) t=TG_maxperiods; // some robustification of expected recaps might be needed // for cases where the TG_recap_exp = 0 temp_negbin.fill_randnegbinomial(value(TG_recap_exp(TG,t,0)), value(overdisp), radm); report1<0) NuStart<0) NuFore< the no F level below) "<0.0 to cause active impl_error)"<1 allocation group"<0) {NuFore<0) { for(j=1;j<=N_Fcast_Input_Catches;j++) { y=Fcast_InputCatch_rd(j,1); s=Fcast_InputCatch_rd(j,2); f=Fcast_InputCatch_rd(j,3); t=styr+(y-styr)*nseas +s-1; NuFore<0) report4<1"< 1"<0"<0) { report4<0"<0) {report4<=3) {report4<<" #_Age_natmort_by gender x growthpattern"<0) report4<0) { report4<<1<<" #_custom_MG-env_setup (0/1)"<0) { report4<<1<<" #_custom_MG-block_setup (0/1)"<0) { report4<<"#_MGtrend_&_cycle_parms "<0) { for(f=1;f<=N_MGparm_seas;f++) { NP++; j++; MGparm_seas_1(f,3)=value(MGparm(j)); report4<0) { for(i=1;i<=N_MGparm_dev;i++) for(j=MGparm_dev_minyr(i);j<=MGparm_dev_maxyr(i);j++) { NP++; report4<<"#DisplayOnly "<0) { for(y=1;y<=recdev_cycle;y++) { NP++; recdev_cycle_parm_RD(y,3)=value(recdev_cycle_parm(y)); report4<0) { report4<<"# Specified recr devs to read"<=recdev_first) {report4<0) { for(y=recdev_early_start;y<=recdev_early_end;y++) { NP++; report4<<"#DisplayOnly "<0) { for(y=recdev_start;y<=recdev_end;y++) { NP++; report4<<"#DisplayOnly "<0) { for(y=recdev_end+1;y<=YrMax;y++) { NP++; report4<<"#DisplayOnly "<0) // report q_parm_detail { report4<<1<<" #_0=read one parm for each fleet with random q; 1=read a parm for each year of index"<0) { report4<<"# LO HI INIT PRIOR PR_type SD PHASE"<0) { report4<<1<<" #_custom_sel-env_setup (0/1) "<0) { report4<<1<<" #_custom_sel-blk_setup (0/1) "<0) { report4<<"#_seltrend_parms "<0) { for(i=1;i<=N_selparm_dev;i++) for(j=selparm_dev_minyr(i);j<=selparm_dev_maxyr(i);j++) { NP++; report4<<"# "<0) { report4<<1<<" # TG_custom: 0=no read; 1=read"<0) report4<0) {for(f=1;f<=Ntypes;f++) report4<<"# "<0) {for(f=1;f<=Ntypes;f++) report4<<"# "<< disc_lambda(f)<<" #_discard:_"<0) {for(f=1;f<=Ntypes;f++) report4<<"# "<< mnwt_lambda(f)<<" #_meanbodywt:"<0) {for(f=1;f<=Ntypes;f++) report4<<"# "<< length_lambda(f)<<" #_lencomp:_"<0) {for(f=1;f<=Ntypes;f++) report4<<"# "<< age_lambda(f)<<" #_agecomp:_"<0) for(f=1;f<=SzFreq_N_Like;f++) report4<<"# "<0) {for(f=1;f<=Ntypes;f++) report4<<"# "<< sizeage_lambda(f)<<" #_size-age:_"<0) report4<<"# "<< Morphcomp_lambda<<" #_Morphcomplambda"<0) { for(TG=1;TG<=N_TG;TG++) report4<<"# "<0) { report4<0) report4<0) report4<0) report4<max_lambda_phase) k=max_lambda_phase; SS2out<=1) SS2out<<"Start_parm_values_from_SS3.PAR"<gmax<<" is_final_gradient"<0) { SS2out<<"#"<0) { SS2out<<"#"<0) { SS2out<<"#"<0) { SS2out<<"#"<0=df_T): "<1) SS2out <<"Catch "<0) SS2out <<"Survey "<0) SS2out <<"Discard "<0) SS2out <<"Mean_body_wt "<0) SS2out <<"Length_comp "<0) SS2out <<"Age_comp "<0) SS2out <<"Size_at_age "<0) SS2out <<"SizeFreq "<0) SS2out <<"Morphcomp "<0) SS2out <<"Tag_comp "<0) SS2out <<"Tag_negbin "<0) SS2out <<"Parm_softbounds "<0) SS2out <<"F_Ballpark "<1) SS2out<<"Catch_lambda: _ "<0) SS2out<<"Surv_lambda: _ "<0) SS2out<<"Disc_lambda: _ "<0) SS2out<<"mnwt_lambda: _ "<0) SS2out<<"Length_lambda: _ "<0) SS2out<<"Age_lambda: _ "<0) SS2out<<"Sizeatage_lambda: _ "<0) { for(j=1;j<=SzFreq_Nmeth;j++) { SS2out<<"SizeFreq_lambda:_"<0) {SS2out<0) {SS2out<0) { SS2out<0) { for(i=1;i<=N_MGparm_dev;i++) for(j=MGparm_dev_minyr(i);j<=MGparm_dev_maxyr(i);j++) { NP++; SS2out<0) { for(j=1;j<=recdev_cycle;j++) { NP++; Activ=0; if(active(recdev_cycle_parm(j))) { active_count++; Activ=1; } Report_Parm(NP, active_count, Activ, recdev_cycle_parm(j), recdev_cycle_parm_RD(j,1), recdev_cycle_parm_RD(j,2), recdev_cycle_parm_RD(j,3), recdev_cycle_parm_RD(j,4), recdev_cycle_parm_RD(j,5), recdev_cycle_parm_RD(j,6), recdev_cycle_parm_RD(j,7), recdev_cycle_Like(j)); } } if(recdev_do_early>0) { for(i=recdev_early_start;i<=recdev_early_end;i++) {NP++; SS2out<0) { for(i=recdev_start;i<=recdev_end;i++) {NP++; SS2out<0) { for(i=recdev_end+1;i<=YrMax;i++) { NP++; SS2out<0) { for(i=endyr+1;i<=YrMax;i++) { NP++; SS2out<0) { k=3*N_TG+2*Nfleet; for(j=1;j<=k;j++) { NP++; Activ=0; if(active(TG_parm(j))) { active_count++; Activ=1; } Report_Parm(NP, active_count, Activ, TG_parm(j), TG_parm_LO(j), TG_parm_HI(j), TG_parm2(j,3), TG_parm2(j,4), TG_parm2(j,5), TG_parm2(j,6), TG_parm_PH(j), TG_parm_Like(j)); } } SS2out<0.0) { temp=value((SPR_std(j)-1.0)/CoVar(active_count,1)); SS2out<<" "<0.0) { temp=value((F_std(j)-1.0)/CoVar(active_count,1)); SS2out<<" "<0.0) { temp=value((depletion(j)-1.0)/CoVar(active_count,1)); SS2out<<" "<0) { SS2out<<"Base_parm# "; for(y=styr;y<=endyr;y++) {SS2out<<" "<0) SS2out<0) { SS2out<<"Base_parm# "; for(y=styr;y<=endyr;y++) {SS2out<<" "<0) SS2out<0) {k1=endyr;} else {k1=styr;} SS2out<0) SS2out<0) SS2out<0) { SS2out<=styr && STD_Yr_Reverse_F(y)>0 ) {SS2out<0.0) {SS2out<<0.5*square( (log(1.1*catch_ret_obs(f,t)) -log(catch_fleet(t,f,gg)+0.1*catch_ret_obs(f,t))) / catch_se(t,f));} else {SS2out<<"BYCATCH";} SS2out<0) { for(gp=1;gp<=N_GP;gp++) SS2out<<" MaleSpbio_GP:"<0) { if(s==Bseas(g)) Recr(p,y)+=natage(t,p,g,0); gg=sx(g); temp=natage(t,p,g)(Smry_Age,nages)*Save_Wt_Age(bio_t,g)(Smry_Age,nages); Bio_Comp(GP(g))+=value(temp); //sums to accumulate across submorphs and birthseasons Num_Comp(GP(g))+=value(sum(natage(t,p,g)(Smry_Age,nages))); //sums to accumulate across submorphs and birthseasons totbio+= natage(t,p,g)*Save_Wt_Age(bio_t,g); smrybio+= temp; smrynum+=sum(natage(t,p,g)(Smry_Age,nages)); smryage+=natage(t,p,g)(Smry_Age,nages)*r_ages(Smry_Age,nages); SPB_vir_LH += natage(t,p,g)*virg_fec(g); if(y<=endyr) { for (f=1;f<=Nfleet;f++) { if(fleet_area(f)==p&&y>=styr-1) { Smry_Table(y,16)+=sum(catage(t,f,g)); Smry_Table(y,17)+=catage(t,f,g)*r_ages; } } } } //close gmorph loop SS2out<0) SS2out<=styr-1) { SS2out<<" "<0) {SS2out<0) {SS2out<=styr && STD_Yr_Reverse_F(y)>0 ) {SS2out<<" "<0) {SIS_table<0) {SIS_table<0) {SIS_table<=styr && STD_Yr_Reverse_F(y)>0 ) {SS2out<<" "<0. && rmse(1)>0.) rmse(1) = sqrt(rmse(1)/n_rmse(1)); // rmse during main period if(n_rmse(1)>0.) rmse(2) = rmse(2)/n_rmse(1); // mean biasadj during main period if(n_rmse(3)>0. && rmse(3)>0.) rmse(3) = sqrt(rmse(3)/n_rmse(3)); //rmse during early period if(n_rmse(3)>0.) rmse(4) = rmse(4)/n_rmse(3); // mean biasadj during early period dvariable Shepard_c; dvariable Shepard_c2; dvariable Hupper; if(SR_fxn==8) { Shepard_c=SR_parm(3); Shepard_c2=pow(0.2,Shepard_c); Hupper=1.0/(5.0*Shepard_c2); temp=0.2+(SR_parm(2)-0.2)/(0.8)*(Hupper-0.2); } SS2out<0) { SS2out<<"to_envvar:_"<(0.01+2.0*square(rmse(1))/temp)) {N_warn++; warning<<" Main recdev biasadj is >2 times ratio of rmse to sigmaR"<2_times_ratio_of_rmse_to_sigmaR"<(0.01+2.0*square(rmse(3))/temp)) {N_warn++; warning<<" Early recdev biasadj is >2 times ratio of rmse to sigmaR"<2_times_ratio_of_rmse_to_sigmaR"<0 && y>=recdev_early_start && y<=recdev_early_end) {SS2out<=recdev_start && y<=recdev_end) {SS2out<0 && y>recdev_end) { SS2out<0) { for(f=1;f<=Ntypes;f++) { in_superperiod=0; for (i=1;i<=nyr_cr(f);i++) { y=abs(yr_cr_y(f,i)); s=abs(yr_cr_s(f,i)); temp = float(y)+0.01*int(100.*(azero_seas(s)+seasdur_half(s))); SS2out<=0) // lognormal { temp = exp_cr(f,i)+log_q_cr(f,i); SS2out< 0) { SS2out<<" "<0) // student's T { SS2out<<((cr_errtype(f)+1.)/2.)*log((1.+square((Ln_obs_cr(f,i)-temp ))/(cr_errtype(f)*square(se_cr_use(f,i))) ))<<" " <<((cr_errtype(f)+1.)/2.)*log((1.+square((Ln_obs_cr(f,i)-temp ))/(cr_errtype(f)*square(se_cr_use(f,i))) ))+log(se_cr_use(f,i)); } rmse(f)+=value(square(Ln_obs_cr(f,i)-temp)); n_rmse(f)+=1.; mean_CV(f)+=se_cr_obs(f,i); mean_CV2(f)+=value(se_cr_use(f,i)); } else { SS2out<<" _ _ _ "; } } else // normal { temp = exp_cr(f,i)*q_cr(f,i); SS2out<0) { SS2out<<" "<0) {rmse(f) = sqrt((rmse(f)+1.0e-9)/n_rmse(f)); mean_CV(f) /= n_rmse(f); mean_CV2(f) /= n_rmse(f);} } } SS2out <0) {SS2out<0) {SS2out<0) {SS2out<1: log(L)_based_on_T_distribution_with_specified_DF"<< endl; SS2out << "0: log(L)_based_on_normal_with_Std_in_as_CV"<< endl; SS2out << "-1: log(L)_based_on_normal_with_Std_in_as_stddev"<< endl; SS2out << "-2: log(L)_based_on_lognormal_with_Std_in_as_stddev_in_logspace"<< endl; SS2out<<"#_Fleet units errtype"<0) { for(f=1;f<=Ntypes;f++) if(disc_units(f)>0) SS2out<0) for(f=1;f<=Nfleet;f++) for (y=styr;y<=endyr;y++) for (s=1;s<=nseas;s++) { t = styr+(y-styr)*nseas+s-1; if(catchunits(f)==1) {gg=3;} // biomass else {gg=6;} // numbers if(yr_disc2(f,t)>0) { i=yr_disc2(f,t); temp = float(y)+0.01*int(100.*(azero_seas(s)+seasdur_half(s))); SS2out<=0.0) { if(disc_errtype(f)>=1) // T -distribution { temp=0.5*(disc_errtype(f)+1.)*log((1.+square(obs_disc(f,i)-exp_disc(f,i))/(disc_errtype(f)*square(sd_disc(f,i))) )); SS2out<<" "<0) SS2out<<"log(L)_based_on_T_distribution_with_DF=_"<0) for(i=1;i<=nobs_mnwt;i++) { y=abs(mnwtdata(1,i)); s=abs(mnwtdata(2,i)); f=abs(mnwtdata(3,i)); temp = float(y)+0.01*int(100.*(azero_seas(s)+seasdur_half(s))); SS2out << mnwtdata(3,i)<<" "<0.) { SS2out<<" "<=2 && gender==2) { temp -= obs_l(f,i)(tails_l(f,i,3),tails_l(f,i,4)) * log(exp_l(f,i)(tails_l(f,i,3),tails_l(f,i,4))); temp += obs_l(f,i)(tails_l(f,i,3),tails_l(f,i,4)) * log(obs_l(f,i)(tails_l(f,i,3),tails_l(f,i,4))); } if(nsamp_l(f,i)>0 && header_l(f,i,3)>0) { n_rmse(f)+=1.; rmse(f)+=value(neff_l(f,i)); mean_CV(f)+=nsamp_l(f,i); Hrmse(f)+=value(1./neff_l(f,i)); Rrmse(f)+=value(neff_l(f,i)/nsamp_l(f,i)); } SS2out<0) {rmse(f)/=n_rmse(f); mean_CV(f)/=n_rmse(f); Hrmse(f)=n_rmse(f)/Hrmse(f); Rrmse(f)/=n_rmse(f); } SS2out<0) {SS2out<<" "<0) for(f=1;f<=Ntypes;f++) for(i=1;i<=Nobs_a(f);i++) { neff_a(f,i) = exp_a(f,i)*(1-exp_a(f,i))+1.0e-06; // constant added for stability neff_a(f,i) /= (obs_a(f,i)-exp_a(f,i))*(obs_a(f,i)-exp_a(f,i))+1.0e-06; temp=0.00; if(gen_a(f,i) !=2) {temp -= obs_a(f,i)(tails_a(f,i,1),tails_a(f,i,2)) * log(exp_a(f,i)(tails_a(f,i,1),tails_a(f,i,2))); temp += obs_a(f,i)(tails_a(f,i,1),tails_a(f,i,2)) * log(obs_a(f,i)(tails_a(f,i,1),tails_a(f,i,2))); } if(gen_a(f,i) >=2 && gender==2) {temp -= obs_a(f,i)(tails_a(f,i,3),tails_a(f,i,4)) * log(exp_a(f,i)(tails_a(f,i,3),tails_a(f,i,4))); temp += obs_a(f,i)(tails_a(f,i,3),tails_a(f,i,4)) * log(obs_a(f,i)(tails_a(f,i,3),tails_a(f,i,4))); } if(nsamp_a(f,i)>0 && header_a(f,i,3)>0) { n_rmse(f)+=1.; rmse(f)+=value(neff_a(f,i)); mean_CV(f)+=nsamp_a(f,i); Hrmse(f)+=value(1./neff_a(f,i)); Rrmse(f)+=value(neff_a(f,i)/nsamp_a(f,i)); } SS2out<0) {rmse(f)/=n_rmse(f); mean_CV(f)/=n_rmse(f); Hrmse(f)=n_rmse(f)/Hrmse(f); Rrmse(f)/=n_rmse(f); } SS2out<0) {SS2out<<" "<0) // have some sizefreq data { SzFreq_effN.initialize(); SzFreq_eachlike.initialize(); SS2out<<"Fleet Yr Seas Method Gender Mkt Nsamp effN Like"<0) // flag for date range in bounds { p=SzFreq_obs_hdr(iobs,5); // partition z1=SzFreq_obs_hdr(iobs,7); z2=SzFreq_obs_hdr(iobs,8); temp=0.0; temp1=0.0; for(z=z1;z<=z2;z++) { SzFreq_effN(iobs)+= value(SzFreq_exp(iobs,z)*(1.0-SzFreq_exp(iobs,z))); temp += square(SzFreq_obs(iobs,z)-SzFreq_exp(iobs,z)); temp1 += SzFreq_obs(iobs,z)*log(SzFreq_obs(iobs,z))-SzFreq_obs(iobs,z)*log(SzFreq_exp(iobs,z)); } SzFreq_effN(iobs) =(SzFreq_effN(iobs)+1.0e-06)/value((temp+1.0e-06)); temp1*=SzFreq_sampleN(iobs); SzFreq_eachlike(iobs)=value(temp1); if(SzFreq_obs_hdr(iobs,3)>0) { n_rmse(f)+=1.; rmse(f)+=SzFreq_effN(iobs); mean_CV(f)+=SzFreq_sampleN(iobs); Hrmse(f)+=1./SzFreq_effN(iobs); Rrmse(f)+=SzFreq_effN(iobs)/SzFreq_sampleN(iobs); } SS2out<0) { rmse(f)/=n_rmse(f); mean_CV(f)/=n_rmse(f); Hrmse(f)=n_rmse(f)/Hrmse(f); Rrmse(f)/=n_rmse(f); SS2out<0) { SS2out<1) { SS2out<0) { SS2out<=styr && (time_vary_sel(y,f)>0 || time_vary_sel(y+1,f)>0))) { SS2out<<"Lsel "<=styr && (time_vary_sel(y,f)>0 || time_vary_sel(y+1,f)>0))) { if(y>=styr && y<=endyr) { SS2out<<"Ret "<=styr && (time_vary_sel(y,f+Ntypes)>0 || time_vary_sel(y+1,f+Ntypes)>0))) { SS2out<<"Asel "<0) { if(Do_Forecast>0) {k=endyr+1;} else {k=endyr;} for (y=styr-3;y<=k;y++) for (s=1;s<=nseas;s++) { t=styr+(y-styr)*nseas+s-1; for(g=1;g<=gmorph;g++) if(use_morph(g)>0 && (y==styr-3 || y>=styr)) { if(s==spawn_seas && (sx(g)==1 || Hermaphro_Option>0) ) SS2out<<"Fecund "<<" NA "<<" "<0) for(s=1;s<=nseas;s++) { SS2out<<"sel*wt "<=1) { SS2out<<"Year "; for(i=-2;i<=N_envvar;i++) SS2out<<" "<0) { SS2out<<" Tag_release_info"<0) { SS2out << endl << "NUMBERS_AT_AGE" << endl; // ProgLabel_410 SS2out << "Area Bio_Pattern Gender BirthSeas SubMorph Morph Yr Seas Time Beg/Mid Era"<0) { for (y=styr-2;y<=YrMax;y++) for (s=1;s<=nseas;s++) { t = styr+(y-styr)*nseas+s-1; temp=double(y)+double(s-1.)/nseas; SS2out <0) { for (y=styr;y<=endyr;y++) for (s=1;s<=nseas;s++) { t = styr+(y-styr)*nseas+s-1; temp=double(y)+double(s-1.)/nseas; SS2out <0) { for (y=styr;y<=endyr;y++) for (s=1;s<=nseas;s++) { t = styr+(y-styr)*nseas+s-1; temp=double(y)+double(s-1.)/nseas; SS2out <0) { for (y=styr-1;y<=endyr;y++) for (s=1;s<=nseas;s++) { t = styr+(y-styr)*nseas+s-1; SS2out <0) {for(s=1;s<=nseas;s++) SS2out<0) { SS2out<0 || time_vary_MG(endyr,3)>0 || WTage_rd>0) { y=endyr; t_base=styr+(y-styr)*nseas-1; for (s=1;s<=nseas;s++) { t = t_base+s; smid=s+nseas; bio_t=styr+(endyr-styr)*nseas+s-1; { Make_AgeLength_Key(); // indexed by season and gmorph } } } SS2out<0) SS2out<<" Herma_Trans Herma_Cum "; for(f=1;f<=Ntypes;f++) SS2out<<" Len:_"<0) { Herma_Cum=fracfemale; for(a=0;a<=nages;a++) { SS2out<0) { if(a>1) Herma_Cum*=(1.0-Hermaphro_val(GP4(g),a-1)); SS2out<<" "<0) SS2out<<" as read from wtatage.ss"; SS2out<<" #NOTE_yr=_"<0) { for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { for(y=styr-3;y<=YrMax;y++) { yz=y; if(yz>endyr+2) yz=endyr+2; if(y==styr-3 || y==styr || time_vary_MG(yz,2)>0 || time_vary_MG(yz,3)>0 || WTage_rd>0) // if growth or wtlen parms have changed for(s=1;s<=nseas;s++) { t = styr+(y-styr)*nseas+s-1; // SS2out<0) { for(g=1;g<=gmorph;g++) if(use_morph(g)>0) { for(y=styr-3;y<=YrMax;y++) { yz=y; if(yz>endyr+2) yz=endyr+2; if(y==styr-3 || y==styr || time_vary_MG(yz,2)>0) { for(s=1;s<=nseas;s++) { t = styr+(y-styr)*nseas+s-1; for(i=0;i<=1;i++) { SS2out<endyr+2) yz=endyr+2; if(y<=styr || time_vary_MG(yz,2)>0 || N_platoon>1) { t = styr+(y-styr)*nseas+s-1; SS2out<0) { for(p=1;p<=pop;p++) { temp+=natage(t,p,g,a); temp1+=Ave_Size(t,0,g,a)*natage(t,p,g,a); } // end loop of areas } // end need to use this gender/platoon } // end loop of all platoons if(temp>0.0) {SS2out <<" "<< temp1/temp;} else {SS2out<<" __";} } // end loop of ages SS2out<0) { SS2out <0) { t = styr+(endyr-styr)*nseas+s-1; smid=s+nseas; SS2out <=1;z--) { SS2out << len_bins2(z) << " "; if(subseas==1) { for (a=0;a<=nages;a++) SS2out << ALK(s,g,a,z) << " " ; } else { for (a=0;a<=nages;a++) SS2out << ALK(smid,g,a,z) << " " ; } SS2out<0) { SS2out <0) { for (k=1;k<=N_ageerr;k++) { SS2out << "KEY: "<=1;b--) { SS2out << age_bins(b) << " "; for (a=0;a<=nages;a++) SS2out << age_age(k,b,a) << " " ; SS2out<=1;b--) { SS2out << age_bins(b) << " "; for (a=0;a<=nages;a++) SS2out << age_age(k,b+L2,a+A2) << " " ; SS2out<0) SS_compout<<" Size: "<0) SS_compout<<" Age: "<0) { for(z=1;z<=nlen_bin;z++) { SS_compout<<"all all all "<0) {anystring="Sup"; in_superperiod=0;} else if (in_superperiod>0) {in_superperiod++; anystring="Sup";} else {anystring="_";} if(header_l(f,i,3)<0 || nsamp_l(f,i)<0) {anystring+=" skip";} else {anystring+=" _";} if(gen_l(f,i)!=2) { s_off=1; for(z=tails_l(f,i,1);z<=tails_l(f,i,2);z++) { SS_compout<0 && header_l(f,i,3)>0) { if(exp_l(f,i,z)!=0.0 && exp_l(f,i,z)!=1.0) {SS_compout<=2 && gender==2) // do males { s_off=2; for(z=tails_l(f,i,3);z<=tails_l(f,i,4);z++) { SS_compout<0 && header_l(f,i,3)>0) { if(exp_l(f,i,z)!=0.0 && exp_l(f,i,z)!=1.0) {SS_compout<0) {anystring="Sup"; in_superperiod=0;} else if (in_superperiod>0) {in_superperiod++; anystring="Sup";} else {anystring="_";} if(header_a(f,i,3)<0) {anystring+=" skip";} else {anystring+=" _";} if(gen_a(f,i)!=2) {s_off=1; for(z=tails_a(f,i,1);z<=tails_a(f,i,2);z++) {SS_compout<0) { if(exp_a(f,i,z)!=0.0 && exp_a(f,i,z)!=1.0) {SS_compout<=2 && gender==2) // do males {s_off=2; for(z=tails_a(f,i,3);z<=tails_a(f,i,4);z++) {SS_compout<0) { if(exp_a(f,i,z)!=0.0 && exp_a(f,i,z)!=1.0) {SS_compout<0) {anystring="Sup"; in_superperiod=0;} else if (in_superperiod>0) {in_superperiod++; anystring="Sup";} else {anystring="_";} if(use_ms(f,i)<0) {anystring+=" skip";} else {anystring+=" _";} for(z=1;z<=n_abins2;z++) { if(z<=n_abins) s_off=1; else s_off=2; t1=obs_ms_n(f,i,z); // whre: obs_ms_n(f,i,z)=sqrt(var_adjust(6,f)*obs_ms_n(f,i,z)); if(ageerr_type_ms(f,i)>0) {anystring2=" L@A ";} else {anystring2=" W@A ";} if(t1>0.) t1=square(t1); SS_compout<0. && t1>0. && use_ms(f,i)>0) { SS_compout<<(obs_ms(f,i,z) -exp_ms(f,i,z)) / (exp_ms_sq(f,i,z)/obs_ms_n(f,i,z))<<" "; // Pearson SS_compout<0) // have some sizefreq data { in_superperiod=0; for(iobs=1;iobs<=SzFreq_totobs;iobs++) { y=SzFreq_obs_hdr(iobs,1); if(y>=styr && y<=retro_yr) // flag for obs that are used { N_out++; temp2=0.0; temp1=0.0; s=abs(SzFreq_obs_hdr(iobs,2)); // temp=float(y)+float(abs(s)-1.)/float(nseas); temp = float(y)+0.01*int(100.*(azero_seas(s)+seasdur_half(s))); f=abs(SzFreq_obs_hdr(iobs,3)); gg=SzFreq_obs_hdr(iobs,4); // gender k=SzFreq_obs_hdr(iobs,6); if(SzFreq_obs_hdr(iobs,2)<0 && in_superperiod==0) {in_superperiod=1; anystring="Sup";} else if (SzFreq_obs_hdr(iobs,2)<0 && in_superperiod>0) {anystring="Sup"; in_superperiod=0;} else if (in_superperiod>0) {in_superperiod++; anystring="Sup";} else {anystring="_";} if(SzFreq_obs_hdr(iobs,3)<0) {anystring+=" skip";} else {anystring+=" _";} p=SzFreq_obs_hdr(iobs,5); // partition z1=SzFreq_obs_hdr(iobs,7); z2=SzFreq_obs_hdr(iobs,8); temp2=0.0; temp1=0.0; for(z=z1;z<=z2;z++) { s_off=1; SS_compout<SzFreq_Nbins(k)) s_off=2; SS_compout<<" "<0) { if(SzFreq_exp(iobs,z)!=0.0 && SzFreq_exp(iobs,z)!=1.0) {SS_compout<<(SzFreq_obs(iobs,z)-SzFreq_exp(iobs,z))/sqrt( SzFreq_exp(iobs,z) * (1.-SzFreq_exp(iobs,z)) / SzFreq_sampleN(iobs));} else {SS_compout<<" NA ";} SS_compout<<" "<0) { for(iobs=1;iobs<=Morphcomp_nobs;iobs++) { N_out++; y=Morphcomp_obs(iobs,1); s=Morphcomp_obs(iobs,2); temp1=s-1.; temp2=y; temp = float(y)+0.01*int(100.*(azero_seas(s)+seasdur_half(s))); // temp=temp2+temp1/nseas; f=Morphcomp_obs(iobs,3); k=5+Morphcomp_nmorph; for(z=6;z<=k;z++) { SS_compout<0) { for(TG=1;TG<=N_TG;TG++) { y=TG_release(TG,3); s=TG_release(TG,4); for(TG_t=0;TG_t<=TG_endtime(TG);TG_t++) { N_out++; t = styr+(y-styr)*nseas+s-1; temp1=s-1.; // temp=float(y)+temp1/float(nseas); temp = float(y)+0.01*int(100.*(azero_seas(s)+seasdur_half(s))); SS_compout<=TG_mixperiod) {SS_compout<<"_"<1) for(f=1;f<=Nfleet;f++) { SS_compout<=TG_mixperiod) {SS_compout<<"_"<nseas) {s=1; y++;} } } } if(N_out==0) SS_compout<0 || time_vary_sel(y+1,f)>0)) { for (gg=1;gg<=gender;gg++) { for(z=1;z<=nlength;z++) {SS2out<0) { for (gg=1;gg<=gender;gg++) for(a=0;a<=nages;a++) {SS2out<0) { SS2out<0) { smid=s+nseas; Make_FishSelex(); } equ_Recr=1.0; Fishon=0; Do_Equil_Calc(); SPR_unf=SPB_equil; for(int SPRloop1=0; SPRloop1<=2; SPRloop1++) { Fmultchanger1=value(pow(0.0001/Fcrash,0.025)); Fmultchanger2=value(Fcrash/39.); if(SPRloop1==1) Fmult2=Fcrash; for(SPRloop=1; SPRloop<=40; SPRloop++) { for(f=1;f<=Nfleet;f++) for(s=1;s<=nseas;s++) { t=bio_t_base+s; Hrate(f,t)=Fmult2*Bmark_RelF_Use(s,f); } Fishon=1; Do_Equil_Calc(); SPR_temp=SPB_equil; Get_EquilCalc = Equil_Spawn_Recr_Fxn(); // call function Btgt_prof=Get_EquilCalc(1); Btgt_prof_rec=Get_EquilCalc(2); if(SPRloop1==0) { if(Btgt_prof<0.001 && Btgt_prof_rec<0.001) {Fcrash=Fmult2;} } SS2out<0.001 && SPR_last>1.00001*SPR_trial && YPR_last1) {Fmult2*=1.05;} else {Fmult2=Fmult2+(1.0-Fmult2)*0.05;} SPR_last=SPR_trial; YPR_last=YPR_dead; for(f=1;f<=Nfleet;f++) for(s=1;s<=nseas;s++) { t=bio_t_base+s; Hrate(f,t)=Fmult2*Bmark_RelF_Use(s,f); } SPRloop+=1; Fishon=1; Do_Equil_Calc(); SPR_temp=SPB_equil; Get_EquilCalc = Equil_Spawn_Recr_Fxn(); // call function Btgt_prof=Get_EquilCalc(1); Btgt_prof_rec=Get_EquilCalc(2); SPR_trial=value(SPB_equil/SPR_unf); SS2out<=0;fishery_on_off--) { SS2out<0) { show_MSY=0; Get_Forecast(); } } for(y=styr-2;y<=YrMax;y++) { SS2out<0) { if(GP4(g)==gp && sx(g)==gg) tempvec_a+= value(natage(t,p,g)); } if(nseas>1) { tempvec_a(0)=0.; for(s=1;s<=nseas;s++) for (p=1;p<=pop;p++) for (g=1;g<=gmorph;g++) if(use_morph(g)>0 && Bseas(g)==s) { if(GP4(g)==gp && sx(g)==gg) tempvec_a(0) += value(natage(t,p,g,0)); } } SS2out <0) SS2out<<"_hermaphrodites_combined_gender_output"; SS2out << endl; SS2out << "Bio_Pattern Gender Year "<0) {k=1;} else {k=gender;} for(gg=1;gg<=k;gg++) for(gp=1;gp<=N_GP;gp++) for(y=styr;y<=YrMax;y++) { tempvec_a.initialize(); t = styr+(y-styr)*nseas; // first season only for (p=1;p<=pop;p++) for (g=1;g<=gmorph;g++) if(use_morph(g)>0) { if(GP4(g)==gp && (sx(g)==gg || Hermaphro_Option>0)) tempvec_a+= value(natage(t,p,g)); } if(nseas>1) { tempvec_a(0)=0.; for(s=1;s<=nseas;s++) for (p=1;p<=pop;p++) for (g=1;g<=gmorph;g++) if(use_morph(g)>0 && Bseas(g)==s) { if(GP4(g)==gp && (sx(g)==gg || Hermaphro_Option>0)) tempvec_a(0) += value(natage(t,p,g,0)); } } if(y>styr) { SS2out <1) SS2out<<" Age zero fish summed across birthseasons, but Z calc is as if all born in season 1"<SPB_virgin_adj) {SPB_BH1=SPB_virgin_adj;} else {SPB_BH1=SPB_curr_adj;} NewRecruits=(4.*steepness*Recr_virgin_adj*SPB_BH1) / (SPB_virgin_adj*(1.-steepness)+(5.*steepness-1.)*SPB_BH1); break; } // ProgLabel_43.3.7 survival based case 7: // survival based, so constrained such that recruits cannot exceed fecundity { // PPR_0=SPB_virgin_adj/Recr_virgin_adj; // pups per recruit at virgin // Surv_0=1./PPR_0; // recruits per pup at virgin // Pups_0=SPB_virgin_adj; // total population fecundity is the number of pups produced // Sfrac=SR_parm(2); SRZ_0=log(1.0/(SPB_virgin_adj/Recr_virgin_adj)); SRZ_max=SRZ_0+SR_parm(2)*(0.0-SRZ_0); SRZ_surv=mfexp((1.-pow((SPB_curr_adj/SPB_virgin_adj),SR_parm(3)) )*(SRZ_max-SRZ_0)+SRZ_0); // survival // warning<<"survivalcalcs "<0) { gg=y - (styr+(int((y-styr)/recdev_cycle))*recdev_cycle)+1; SRZ_surv*=mfexp(recdev_cycle_parm(gg)); } exp_rec(y,2)=SPB_curr_adj*SRZ_surv; SRZ_surv*=mfexp(-biasadj(y)*half_sigmaRsq); // bias adjustment exp_rec(y,3)=SPB_curr_adj*SRZ_surv; if(y <=recdev_end) { if(recdev_doit(y)>0) SRZ_surv*=mfexp(recdev(y)); // recruitment deviation } else if(Do_Forecast>0) { SRZ_surv *= mfexp(Fcast_recruitments(y)); } join=1./(1.+mfexp(100*(SRZ_surv-1.))); SRZ_surv=SRZ_surv*join + (1.-join)*1.0; // warning<<" adjust "<0) { gg=y - (styr+(int((y-styr)/recdev_cycle))*recdev_cycle)+1; NewRecruits*=mfexp(recdev_cycle_parm(gg)); } exp_rec(y,2)=NewRecruits; if(SR_fxn!=4) NewRecruits*=mfexp(-biasadj(y)*half_sigmaRsq); // bias adjustment exp_rec(y,3)=NewRecruits; if(y <=recdev_end) { if(recdev_doit(y)>0) NewRecruits*=mfexp(recdev(y)); // recruitment deviation } else if(Do_Forecast>0) { NewRecruits *= mfexp(Fcast_recruitments(y)); } exp_rec(y,4) = NewRecruits; } return NewRecruits; } //********************************************************************* /* ProgLabel_FUNCTION 44 Equil_Spawn_Recr_Fxn */ FUNCTION dvar_vector Equil_Spawn_Recr_Fxn() { dvar_vector EquilCalc(1,2); dvariable B_equil; dvariable R_equil; dvariable temp; dvariable join; dvariable steepness; dvariable SRZ_0; dvariable SRZ_max; dvariable SRZ_surv; steepness=SR_parm(2); // ProgLabel_44.1 calc equilibrium SpawnBio and Recruitment from input SPR_temp, which is spawning biomass per recruit at some given F level switch(SR_fxn) { case 1: // previous placement for B-H constrained { N_warn++; cout<<"Critical error: see warning"<