-
Notifications
You must be signed in to change notification settings - Fork 318
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
Have the FATES parameter file created at runtime in the buildnml #2126
Comments
There's several considerations for this that we need to think about:
|
I think the main script for this is here: https://github.com/NGEET/fates/blob/main/tools/UpdateParamAPI.py Any scripts used would be in that directory. Looking at dependencies, I see that scipy and numpy are being used, so that's pretty basic, but beyond the current barebones requirements that cime currently has. |
@ekluzek and all: When I'm running FATES and making perturbations to parameters in the FATES parameter file, there are two things I typically do, depending on the scenario. Scenario 1: I'm running a simulation where I've already calibrated a set of parameters, and this set of parameters is not encapsulated in the default file. This set of parameters could be associated with the default PFT set, or a subset, or a completely new set of PFTs.
Scenario 2: I want to do a "one-off" perturbation to a parameter, or multiple parameters. The basis of my parameter set may be the default, or a different file perhaps generated from Scenario 1:
I could picture both of these methods being used in a testing workflow, or normal build and run workflow. The combination of them would certainly give us better testing coverage of FATES. The BatchPatchParams.py could potentially over-complicate a testing workflow, but might come in handy. The most direct method to modifying fates parameter for testing, might be calling modify_fates_paramfile.py in some type of shell or existing execution script. Either way, both could be worked into a system where we build the file at run-time. |
@rgknox that's very helpful. Yes, we should incorporate both scenarios into our testing workflow and make sure they are options that can be done from buildnml. As I think about this I think there should be some XML variables that control this operation. I'd like to talk about this more at tomorrow's software meeting. I have one more idea I'm going to put in another comment... |
Since, there are python module dependencies that are beyond what cime normally requires (which right now is only the python version) we should add some error checking for those modules and python version dependencies. This should also eventually go into the tool in FATES, but to start with we should have a graceful fail in the CTSM side. Here's the issue to put it into FATES... As a name for an XML field I'm thinking of something like:
The BATCH_PATH option will also have to assume a name for the input file it'll use we suggest: user_nl_FATES_param_changes.xml below. |
We had some discussion on this today. I modified the above proposal a bit based on that. It does seem clear that transitioning to always building the parameter file would be the best way to separate the HLM's from needing to update whenever new parameters are added to the FATES parameter file. But, I think we should do this as a transition, so start allowing it, and then transition to one of the parameter file creation options is the only choice. I tried to see if there might be a way to have the HLM still work with an updated version of FATES that has new parameters on the FATES parameter file. But, that doesn't seem workable. So working towards always creating the FATES parameter file at buildnml time is a better long term solution. I also realized that an option to use straight up ncgen should be one of the options. The nice thing about that is that's part of NetCDF so will be loaded in the modules to run the model. So it's not an new requirement. |
Copied from google meet chat:
|
From today's meeting on parameter files we discussed how a future PR could utilize this infrastructure to provide a testmod for the fates seed dispersal code, since it needs reasonable values based on the resolution type. As requested, I've attached a potential xml file (adding a txt suffix since github doesn't like xml). Seed dispersal PR for future reference: NGEET/fates#1005 and #2077 |
I looked up in cime, and we need to have a "user_nl_" prefix for it to be handled correctly. So we should have the name... user_nl_FATES_param_changes.xml |
Some details that came out in our discussion. The ncgen part needs to always be done. And then the batch_path or modify script can be run on top. The nice thing about ncgen is that its guaranteed to be loaded as NetCDF is loaded in the cime case environment. The modify script only does one thing at a time, so typically you have to run it many multiple of times to get the changes needed. Since, the batch_patch option just bundles those changes into one xml file, it seems best to just enable the batch_patch option as the general tool to take a user XML file and apply a list of desired changes to the default file. |
In our discussion we also thought this should be broken up into small steps. Here's my thinking of that. Feel free to suggest changes.
Separate from this HLM work, will be work inside of FATES to improve the FATES parameter file manipulation tools. None of the above is dependent on that, but we may have to modify the interface here in response to changes there. I think the two hardest steps are 1 and 3 and especially 3 which is the real proof of concept test for this. @adrifoster @slevis-lmwg @glemieux @samsrabin any thoughts on this schedule above? Missing steps? Or things that could be broken up? Some of the steps could be done together depending on who does them, but it's nice to break it up into as small of steps as possible. |
I guess I am confused. The |
Yes, valid point. At the first step everything is contained in shell_commands and includes, so that all works until we get to step 3 above. At that point for clones to work, the filename either needs to be an assumed name that cime will automatically copy over (which right now is user_nl_*) -- or it needs to be explicitly named with another XML variable. But, if it's named with an XML variable, cime won't automatically copy it for create_clone, unless we figure out how to explicitly add that in somehow. You are right that "nl" stands for namelist, but I really think of it as user lists of control file changes. The user_nl_* files mostly deal with namelists, but they also operate on config files (for driver), XML files (for CDEPS), and mizuRoute control files. So for datm you have user_nl_datm_streams and mizuRoute user_nl_mizuroute_control. This is perhaps why the "user_nl_" should become something more general, but because that would require a lot of coordinated changes we've left it alone. Does that help? Or should we do more discussion? |
The changes in steps 2 and 3 above could be implemented in either the buildnml or the build-namelist scripts. Because we want to deprecate and replace the build-namelist, as in #585 we should implement this at that point in the buildnml. This could be an incremental step in moving towards having the build-namelist functionality fully inside the buildnml script. |
Work I did in ctsm5.3.014 helps with this. I'm taking the above task list and turning it into checkboxes that I'll put at the top. ctsm5.3.014 enables the ctsm_pylib environment if it can, or adds graceful error checking for some FATES tests, and this can be extended for more. This would get us further down the road into this at least for testing. It could also be moved to user-mods for FATES so would be active in more compsets. We've had some discussion on this in CSEG, and there is concern about the requirement of having a conda environment needed for a CESM case. So we'll have a subgroup discuss this once we have a document that outlines ideas and options. Here's a link to the discussion there: I just added some action items there and additional notes. I've got a start at that document that we'll present to CSEG about different options here. This is only an overview right now. |
Note an alternative that @glemieux talked about was changing the FATES modify parameter file tool, to NOT use anything beyond base python modules required by CIME. This is actually the desired long term solution for FATES for the parameter file to be stored in XML. @mvdebolskiy for NorESMF is also planning on having the python module environment needed for this as part of the machine setup for the machines they support. |
I realized we didn't have an explicit issue or thread on the FATES-side so I'm referencing this here: NGEET/fates#1296 |
@ekluzek my setup won't work, since for the tests |
@mvdebolskiy thanks for confirming the order for shell_commands. That's good to know for sure. That might be a hard requirement for CIME to do it that way because shell_commands can also be in user-mods and create_newcase needs to execute them and it doesn't normally do case.setup as part of what it does. We could maybe modifty the behavior for create_test, but we wouldn't want it to do something that different than how create_newcase functions. Another way to do this would be to require the user to rerun shell_commands after case.setup is done. So it would die with an error and then tell the user to run case.setup and then shell_commands again. How does that sound? |
I'd like to see this for usability in the CESM3 release, so marked it that way. But, I also added next on this to discuss as it's not that strictly required. |
@ekluzek It's not a huge problem. I can just add machine specific things to the Reruning shell commands does not sound good to me since it's adding confusion. |
This was an idea talked about here:
NGEET/fates#1073
We think a better way to handle FATES parameter files is to have the buildnml use the FATES tools to create them from the CDL files in FATES. A shorter way to do this would be for that to happen in a testmod in the shell_commands file. But, longer term we probably want it as part of the configure process for a CESM case. This also gets people in the habit of using the tools to make FATES parameter files themselves which sets them up to configure their files for their situation from the get go. That's a more FATES like way to run, and sets people up for doing things like PPE work, or site specific changes.
Definition of done: FATES parameter files are created from the CDL file stored in FATES
NOTE: The longer term solution that is desired is to store the default parameter file in FATES as XML. With this python tools that modify the file will just have standard python packages and NOT also require an extended Python environment using conda and activating ctsm_pylib as we require now.
Steps to get there:
The text was updated successfully, but these errors were encountered: