-
Notifications
You must be signed in to change notification settings - Fork 92
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add running mean functions #724
Conversation
…mory (ie simple moving average) in a window in favor of the exponential moving window, 2) added fixed window capabilities.
After discussions with @billsacks @dlawrenncar @ekluzek @ckoven , I've dropped support for a simple moving averages. The SMA requires that all independent points of memory over a window of time are maintained, we all agreed this would be too memory intensive. Now, moving windows only use the exponential moving average (EMA), which maintains 1 point of memory. This essentially updates a single point of memory with a weighting function where mean = (1-alpha)mean + alphaupdate_value. The alpha is the fraction of the window in which an update occurs (ie the frequency). |
… running mean functions
Code has been updated with the following:
Testing this now, will report back |
Ran a 20 year test at BCI using the default pft set. Simulations were initialized with inventory. Here are some plots for just the new branch with the running mean functions, which have a new 24hr veg temperature history variable: |
plots looks reasonable, we'd expect there to be some small differences if we're calculating the respiration temperature slightly differently. thanks @rgknox! |
well, respiration uses the instantaneous temperatures right now, so in theory, it should not be affected by these changes. I did however notice that the number of chill days (phenology) had a non-zero (strange) starting value for the base run, and was set to zero (expected) in the new run. But it still seemed strange to me that this would potentially have the effect that we are seeing. Maybe there is a small amount of fire happening? |
ran a special test where I held the temperature controlling frost mortality to a constant 20 degrees, then compared this branch to its base, the results were then indistinguishable. https://github.com/NGEET/fates/blob/master/biogeochem/EDMortalityFunctionsMod.F90#L177 I also printed out the temperature on the first call to calculate frost mortality (in the base) and the value was -273 C. A little frosty. On the new branch the temperature is 23 C on the first timestep (at BCI). |
thanks @rgknox. so then it sounds like there was a bug in the old code then, which you've now fixed. great! |
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.
Hi @rgknox, this looks great. A thing whose significance has only just occurred to me though, upon staring hard at the code just now, is whether we should be using the fixed window rather than the exponential window for the special case of the 24-hour smoothing?
My thinking on this is the following: because FATES's daily timestep is happening synchronized around the planet all at once, it will fall at a different time of day (locally) around the world. And because the exponential moving average still has some amplitude over any given cycle (~10% I think, based on playing around in jupyter), which we'd then be sampling at different phases of the diurnal cycle at different sites around the world, it means that the 24-hour mean temperature will have a longitudinally-dependent high or low bias relative to what we'd get with the fixed moving window. And maybe its not a big deal, but also a longitudinally-dependent bias strikes me as something we'd want to avoid?
So I guess I'm ok with pulling this in as-is for now, since we've had this bias all along and (I at least) just hadn't perceived it, but maybe we should put switching the tveg24 to the fixed window method on the to-do list as well? Unless it'd be a simple swap in this PR to change the method (which maybe it is, as the machinery that you've built to do so is really very nice)?
main/FatesRunningMeanMod.F90
Outdated
implicit none | ||
private | ||
|
||
integer, parameter :: maxlen_varname = 8 |
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 can't see where this is used. is it?
main/FatesRunningMeanMod.F90
Outdated
! over their construction period. | ||
|
||
|
||
integer, public, parameter :: moving_ema_window = 0 |
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.
could you write in the comments here that 'EMA' refers to exponential moving average? It doesn't say so anywhere in the code right now (or at least I didn't see it).
main/FatesRunningMeanMod.F90
Outdated
|
||
! Define the time methods that we want to have available to us | ||
|
||
class(rmean_def_type), public, pointer :: ema_24hr |
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.
define ema again here in comments?
@ckoven , your point about the longitudinal bias sounds real to me. We don't want some sites with more memory of yesterday's mid-day, and some sites with more memory of yesterday's night. Changing the current 24 veg temp to a fixed window will be a good way to double check the coding on the fixed window. Will do. |
Co-authored-by: Charlie Koven <ckoven@users.noreply.github.com>
Co-authored-by: Charlie Koven <ckoven@users.noreply.github.com>
Co-authored-by: Charlie Koven <ckoven@users.noreply.github.com>
I re-worked the code to test out using the fixed-window average. One thing I noticed, that kind of caught me off guard: When I set a model run-time that starts on the 0 hour, there are 2-half hour model steps in clm/elm before our first dynamics step. This was strange to me, as there should had been either 48 or 0 steps. This would effect how our windows are applied because by the time that fixed window average is completed, we will have to wait 1 hour until the new value is used, so it will be slightly out of date. I suppose 1 hour is not the worst lag, but still, did not expect this and this should be addressed. |
We use the Note that it checks if the time of day |
…ean as using fixed window
@ckoven and I discussed the issue that 24-hour fixed window running means will represent a window that is lagged 1 hour from the time of the dynamics call and feel this is acceptable for the time being. Modifying the call sequence in the hlm driver could have significant unforseen consequences and make a mess, and would be better left to its own PR and investigation. |
I merged up to dev061 on the ctsm side and started testing with the fates suites on izumi and cheyenne. The cheyenne tests are still running, but I'm seeing the
I haven't had a chance to look into it much yet, but from the checking out the branch diffs against master in FatesRestartInterfaceMod, I don't see anything jumping out at me right away. |
@glemieux , I can't see anything yet either... I don't think its anything specific to rio_recrate_sift, as that is just the first restart variable encountered. My guess is that the new variables have somehow messed with the indexing system used to assign the restart variables, and not their spatial coordinates, or the cohort ordering coordinates, because we really don't make any changes to that in the code... Still looking, still stumped. |
@rgknox @glemieux Could the problem be that this moves the call to |
yes, that is the problem, thanks @ckoven |
…ndant with patch-level given how the HLMs handle temperature physics
The following report compares the branch in this PR (as merged) against master (ctsm: dev61, fates:sci.1.48.0_api.17.0.0). It compares the annual mean biomass, annual maximum LAI, and annual mean biomass partitioned by PFT, for the 60th year of simulation (from a cold-start). rmeans_v0-f10_f10_mapplots.pdf The expectation is that the new averaging functions should change results. |
After reviewing the code and printing diagnostics, I verified that we are getting 24-hour means generated at the right time and they are in-phase with the dynamics step. I'm going to start regression testing. |
Tests for the fates test suite are as expected, on cheyenne: /glade/scratch/rgknox/tests_1201-124452ch Will now run aux_clm |
This set of changes synchronizes CTSM with API 20 of FATES. API 20 of FATES requires a modification to timing boundary conditions so that FATES can maintain its own internal running means. FATES also no-longer asks CTSM for the 24hour vegetation temperature, since this is a patch(pft) level variable, and FATES has more suitable averaging mechanisms. These changes are synchronized with FATES Pull Request: NGEET/fates#724, which subsequently created tag: https://github.com/NGEET/fates/releases/tag/sci.1.52.0_api.20.0.0
This set of changes synchronizes CTSM with API 20 of FATES. API 20 of FATES requires a modification to timing boundary conditions so that FATES can maintain its own internal running means. FATES also no-longer asks CTSM for the 24hour vegetation temperature, since this is a patch(pft) level variable, and FATES has more suitable averaging mechanisms. These changes are synchronized with FATES Pull Request: NGEET/fates#724, which subsequently created tag: https://github.com/NGEET/fates/releases/tag/sci.1.52.0_api.20.0.0
This set of changes synchronizes CTSM with API 20 of FATES. API 20 of FATES requires a modification to timing boundary conditions so that FATES can maintain its own internal running means. FATES also no-longer asks CTSM for the 24hour vegetation temperature, since this is a patch(pft) level variable, and FATES has more suitable averaging mechanisms. These changes are synchronized with FATES Pull Request: NGEET/fates#724, which subsequently created tag: https://github.com/NGEET/fates/releases/tag/sci.1.52.0_api.20.0.0
Description:
Add capacity to track running means in FATES. This adds the code to perform running means, and allows these variables to be attached at any FATES scale, including site, patch and cohort. Only the 24-hour vegetation temperature was converted over as of yet.
Fixes #722
Should be synchronized with: ESCOMP/CTSM#1304
Integrate after: #703
Collaborators:
@ckoven @Qianyuxuan Claire Zarakas @billsacks @dlawrenncar @ekluzek
Expectation of Answer Changes:
This should change answers, but my expectation is that it should change them subtly. The 24hour vegetation temperature that was previously calculated in CLM/ELM should now have similar, but different values now that we are allowing patch-persistence to influence the calculation. This value is used in mortality, fire and phenology.
Checklist:
Test Results:
CTSM (or) E3SM (specify which) test hash-tag:
CTSM (or) E3SM (specify which) baseline hash-tag:
FATES baseline hash-tag:
Test Output: