From b992fd7b7a0dcce0f99fb899258c671b8fb4c2dd Mon Sep 17 00:00:00 2001 From: Ian Taylor <4992918+iantaylor-NOAA@users.noreply.github.com> Date: Tue, 6 Aug 2024 11:34:32 -0700 Subject: [PATCH] Revise text in tuning the 2DAR selectivity (#242) * update Xu et al. 2020 to published year and info * revise 2DAR tuning text & use "2DAR" everywhere instead of mixed with "2DAR1" * remove TMB from ss3_glossaries.tex --------- Co-authored-by: Elizabeth Perl --- 15special.tex | 13 +++++++------ SS3.bib | 18 ++++++++---------- ss3_glossaries.tex | 3 +-- 3 files changed, 16 insertions(+), 18 deletions(-) diff --git a/15special.tex b/15special.tex index 6a226af0..4553184b 100644 --- a/15special.tex +++ b/15special.tex @@ -76,13 +76,13 @@ \hat{S}_{a,t} = S_aexp^{\epsilon_{a,t}} \end{equation} -where $S_a$ is specified in the corresponding age/length selectivity types section, and it can be either parametric (recommended) or non-parametric (including any of the existing selectivity options in SS3); $\epsilon_{a,t}$ is simulated as a two-dimensional first-order autoregressive (2DAR1) process: +where $S_a$ is specified in the corresponding age/length selectivity types section, and it can be either parametric (recommended) or non-parametric (including any of the existing selectivity options in SS3); $\epsilon_{a,t}$ is simulated as a two-dimensional first-order autoregressive (2DAR) process: \begin{equation} vec(\epsilon) \sim MVN(\mathbf{0},\sigma_s^2\mathbf{R_{total}}) \end{equation} -where $\epsilon$ is the two-dimensional deviation matrix and $\sigma_s^2\mathbf{R_{total}}$ is the covariance matrix for the 2DAR1 process. More specifically, $\sigma_s^2$ quantifies the variance in selectivity deviations and $\mathbf{R_{total}}$ is equal to the kronecker product ($\otimes$) of the two correlation matrices for the among-age and among-year AR1 processes: +where $\epsilon$ is the two-dimensional deviation matrix and $\sigma_s^2\mathbf{R_{total}}$ is the covariance matrix for the 2DAR process. More specifically, $\sigma_s^2$ quantifies the variance in selectivity deviations and $\mathbf{R_{total}}$ is equal to the kronecker product ($\otimes$) of the two correlation matrices for the among-age and among-year AR processes: \begin{equation} \mathbf{R_{total}}=\mathbf{R}\otimes\mathbf{\tilde{R}} @@ -96,20 +96,22 @@ \mathbf{\tilde{R}}_{t,\tilde{t}}=\rho_t^{|t-\tilde{t}|} \end{equation} -where $\rho_a$ and $\rho_t$ are the among age and among year AR1 coefficients, respectively. When both of them are zero, $\mathbf{R}$ and $\mathbf{\tilde{R}}$ are two identity matrices and their Kronecker product, $\mathbf{R_{total}}$, is also an identity matrix. In this case selectivity deviations are essentially identical and mutually independent: +where $\rho_a$ and $\rho_t$ are the among age and among year AR coefficients, respectively. When both of them are zero, $\mathbf{R}$ and $\mathbf{\tilde{R}}$ are two identity matrices and their Kronecker product, $\mathbf{R_{total}}$, is also an identity matrix. In this case selectivity deviations are essentially identical and mutually independent: \begin{equation} \epsilon_{a,t}\sim N(0,\sigma_s^2) \end{equation} \myparagraph{Using the Two-Dimensional Autoregressive Selectivity} -Note, \citet{xu-new-2019} has additional information on tuning the 2DAR1 selectivity parameters. First, fix the two AR1 coefficients ($\rho_a$ and $\rho_t$) at 0 and tune $\sigma_s$ iteratively to match the relationship: +See \citet{xu-new-2019} and \citet{xu-comparing-2020} for information on tuning the 2DAR selectivity parameters. There is not yet a generalized method to automate the tuning, so the information below provides a general framework. + +First, fix the two AR coefficients ($\rho_a$ and $\rho_t$) at 0 and tune $\sigma_s$ iteratively to match the relationship: \begin{equation} \sigma_s^2=SD(\epsilon)^2+\frac{1}{(a_{max}-a_{min}+1)(t_{max}-t_{min}+1)}\sum_{a=a_{min}}^{a_{max}}\sum_{t=t_{min}}^{t_{max}}SE(\epsilon_{a,t})^2 \end{equation} -The minimal and maximal ages/lengths and years for the 2DAR1 process can be freely specified by users in the control file. However, we recommend specifying the minimal and maximal ages and years to cover the relatively ``data-rich'' age/length and year ranges only. Particularly we introduce: +The minimal and maximal ages/lengths and years for the 2DAR process can be freely specified by users in the control file. However, we recommend specifying the minimal and maximal ages and years to cover the relatively ``data-rich'' age/length and year ranges only. Particularly we introduce: \begin{equation} b=1-\frac{\frac{1}{(a_{max}-a_{min}+1)(t_{max}-t{min}+1)}\sum_{a=a_{min}}^{a_{max}}\sum_{t=t_{min}}^{t_{max}}SE(\epsilon_{a,t})^2}{\sigma_s^2} @@ -119,7 +121,6 @@ Second, fix $\sigma_s$ at the value iteratively tuned in the previous step and estimate $\epsilon_{a,t}$. Plot both Pearson residuals and $\epsilon_{a,t}$ out on the age-year surface to check their 2D dimensions. If their distributions seems to be not random but rather be autocorrelated (deviation estimates have the same sign several ages and/or years in a row), users should consider estimating and then including the autocorrelations in $\epsilon_{a,t}$. -Third, extract the estimated selectivity deviation samples from the previous step for estimating $\rho_a$ and $\rho_t$ externally by fitting the samples to a stand-alone model written in \gls{tmb}. In this model, both $\rho_a$ and $\rho_t$ are bounded between 0 and 1 via applying a logic transformation. If at least one of the two AR1 coefficients are notably different from 0, the model should be run one more time by fixing the two AR1 coefficients at their values externally estimated from deviation samples. The Pearson residuals and $\epsilon_{a,t}$ from this run are expected to distribute more randomly as the autocorrelations in selectivity deviations can be at least partially included in the 2DAR1 process. \hypertarget{continuous-seasonal-recruitment-sec}{} \subsection[Continuous seasonal recruitment]{\protect\hyperlink{continuous-seasonal-recruitment-sec}{Continuous seasonal recruitment}} diff --git a/SS3.bib b/SS3.bib index 333b7789..d8b92e4e 100644 --- a/SS3.bib +++ b/SS3.bib @@ -262,19 +262,17 @@ @article{xu-new-2019 file = {Xu et al. - 2019 - A new semi-parametric method for autocorrelated ag.pdf:C\:\\Users\\Chantel.Wetzel\\Zotero\\storage\\ZJ64IPKT\\Xu et al. - 2019 - A new semi-parametric method for autocorrelated ag.pdf:application/pdf} } -@article{xu-comparing-2019, - title = {Comparing the performance of three data weighting methods when allowing for time-varying selectivity}, - issn = {0706-652X, 1205-7533}, - url = {http://www.nrcresearchpress.com/doi/10.1139/cjfas-2019-0107}, +@article{xu-comparing-2020, + title = {Comparing the performance of three data-weighting methods when allowing for time-varying selectivity}, + url = {https://doi.org/10.1139/cjfas-2019-0107}, doi = {10.1139/cjfas-2019-0107}, - language = {en}, - urldate = {2019-09-26}, journal = {Canadian Journal of Fisheries and Aquatic Sciences}, author = {Xu, Haikun and Thorson, James T and Methot, Richard D}, - month = jun, - year = {2019}, - pages = {cjfas--2019--0107}, - file = {Xu et al. - 2019 - Comparing the performance of three data weighting .pdf:C\:\\Users\\Chantel.Wetzel\\Zotero\\storage\\GITXVVB9\\Xu et al. - 2019 - Comparing the performance of three data weighting .pdf:application/pdf} + volume = {77}, + number = {2}, + pages = {247-263}, + year = {2020}, + doi = {10.1139/cjfas-2019-0107}, } @techreport{grandin-status-2020, diff --git a/ss3_glossaries.tex b/ss3_glossaries.tex index 701833d2..331b0227 100644 --- a/ss3_glossaries.tex +++ b/ss3_glossaries.tex @@ -26,6 +26,5 @@ \newacronym{srr}{SRR}{spawner-recruitment relationship} \newacronym{ss3}{SS3}{Stock Synthesis} \newacronym{ssi}{SSI}{Stock Synthesis Interface} -\newacronym{tmb}{TMB}{Template Model Builder} \newacronym{vlab}{VLab}{NOAA Virtual Lab} -\newacronym{ypr}{YPR}{yield per recruit} \ No newline at end of file +\newacronym{ypr}{YPR}{yield per recruit}