-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
91fefa8
commit 2614278
Showing
3 changed files
with
10 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm late to this party so maybe misunderstanding something here, but the last year has information from the hyperdistribution and we want that uncertainty to be in the model and eventually projections. So setting to the mean seems not right to me.
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the input - it's not the last year, it's
nyears + 1
. Does that still apply? I need to follow up with the group that worked on PR #514 because they removed the first year of the model comparison recdev vector - it's possible everything should have shifted over one rather than removing the first year?2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Conceptually any dev should have the hyperdistribution without any data informing it. That can be the initial years, terminal ones, or projection ones. I'm sure there are special cases where you'd want to maybe use a different sigmaR for projections, or fix certain devs, but the latter is best done through mapping IMO, and will accomplish the same.
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Andrea-Havron-NOAA may be able to describe it better, but my vague memory of the issue in #514 was that age-0 in the initial age structure and the first recdev were applying to the same year and age so one needed to be removed.
Our feeling was that all this would change in M2 when we moved to more flexible range of years for data, estimated recdevs, etc., so at this point the goal was to just get the model to work.
@Cole-Monnahan-NOAA, I totally agree that we can have uninformed devs in the future. If there's further discussion on this, we could make it easier to find by adding to the "Investigate constrain deviations in recruitment" issue #364.
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I dropped off the first year of recdevs as no data were informing it and leaving it in the model as estimated was resulting in gradients that weren't passing tests (higher than 0.0001) in test-fims-estimation.R. After dropping the first observation, gradients became orders of magnitude smaller. I was hoping this was a temporary fix until we explored more correct ways to implement the recruitment devs under constraints or as random effects in M2. I wasn't running into the same issues happening in this branch. Should we revert the changes I made to the log_recruit_dev vector given the problems happening in the fims_vector branch?
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That interesting. I'm surprised they don't go to zero after a step or two given that they're independent, and normal so quadratic where is when Newton's method works the best. Usually there's data later on when the fish are still alive so maybe it was just really poorly informed? In that case there can be a lot of correlation too so maybe that's why the optimizer had a hard time? We could get around these gradient issues by taking a step or two using this algorithm: MLE=MLE-(inverse Hessian)*(gradient).
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Cole-Monnahan-NOAA right now recdevs are annual fixed effects, so there is no hyper distribution. We definitely need to re-do this in M2 when we turn on random effects anyway. This fix is now passing all checks, so I'd prefer that we keep it this way rather than revert log_recruit_dev and have to troubleshoot more gradient issues, unless the gradient issues are pointing towards a different problem.
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fine to leave as is to keep things moving. Just to highlight the point that the hyperdistribution N(0,sigmaR) affects all devs, regardless if they have data informing them, regardless of if using penalized ML or random effect integration.
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
But if there's no data informing the final element of the vector because it's for an unobserved final year, wouldn't that value just be drawn from the hyperdistribution rather than informing what sigmaR + other devs are?
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What if we add the first element of the recdevs vector back, but remove initial NAA at age of recruitment as a parameter instead?
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@ChristineStawitz-NOAA Yes correct it will just take the hyperdistribution N(0,sigmaR). But that's what we want, because that uncertainty will be propagated into the NAA and throughout the model. Early devs will affect initial NAA and the last ones will affect the projections (if that's desired). This is pretty common practice, at least in my region, and with SS3. For instance take the following example from Pacific hake 2021 assessment Figure 27. You can see the hyperdistribution at the start and end of the vector.
@msupernaw Also correct that you'd get an estimate of 0 if estimated, and have a gradient of zero if you left off rec_devs[0] from the likelihood calculation. But you'd also have a zero second derivative and hence a non positive definite Hessian for that component and thus the whole model. It also would have no uncertainty and thus underestimate uncertain in early NAA.
I think conceptually we should do ~N(0,sigmaR) for all devs as a baseline, and let the user make adjustments from there through e.g. mapping.
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we'll want some flexibility in the initial NAA configurations. In this case if initial_numbers[0] is a freely estimated fixed effect then recruitment_deviations[0] will just take the hyperdistrubtion but be negatively correlated with the fixed effect. I may be lost in the indexing here. Is recruitment[0] in the first year of the model? If so then I don't see the logic of having initial_numbers[0] in that statement, since that is the age structure at the beginning of the first year, and recruitment happens later in the year given those fish.
My main point is that we should think statistically about our recdevs. The N(0,sigmaR) formulation also implicitly assumes that they're exchangeable random effects, and IMO we should strive to meet those assumptions.
I'm done with my busy assessment season so can be more involved and happy to chat about this stuff in person if it's helpful.
2614278
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Cole-Monnahan-NOAA, we will be restructuring recruitment as part of M2. I think we will want to follow a similar structure to WHAM/SAM with a random effect on logN opposed to a recruitment dev structure as the former is sparse and the latter is not. We also need to think if we want to include an option to turn off the random effect and use a constraint instead and what this might look like. I would love your input in the next development cycle.