-
Notifications
You must be signed in to change notification settings - Fork 134
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
Deprecate zsalinity #439
Comments
Is the code that still needs to be removed in the zsalinity module, or elsewhere? |
There is stuff other places. The zsalinity module will be deleted. But for instance, see below. The icepack parameters is fine, I guess we want to leave the setting there, but abort if it's turned on for backwards compatibility. I'm happy to start stripping out the solve_zsal blocks of code. Is solve_zsal just for zsalinity or are there other uses of that flag? Are there some other variables we can key off of to verify the zsalinity is completely removed?
|
Wow, I missed a lot. I think it's fine to remove all of it, and run the various test suites to make sure it doesn't mess up something else. Removing all of it might affect the hbrine tracer - that's the only thing I can think of to keep an eye on. zsalinity was originally developed for zBGC, which we will update and thoroughly test as part of the Icepack-E3SM merge; now the BGC uses the mushy thermo salinity rather than this zsalinity parameterization. |
OK, let me take a crack at removing the code and see what happens. Will keep you posted. I'm pretty sure you intentionally just turned off the zsalinity code during the initial deprecation without removing all the code because it was a bit invasive. That was a reasonable first step that would be easier to do and undo if we decided not to deprecate the feature. But now it does need to happen. |
When we deprecate zsalinity in Icepack, I assume we also want to deprecate zsalinity in the Icepack driver and CICE? In Icepack, I kept the option to set solve_zsal to true, but there is no more solve_zsal code and setting solve_zsal to true will lead to an Icepack abort. I would take the same approach in the Icepack driver and CICE, keep solve_zsal as a namelist, abort if it's set to true, and otherwise remove code we no longer need. Does that sound like the way we want to go? An alternative is just to keep all the solve_zsal code in the Icepack driver and CICE, Icepack will abort if we try to use it. I don't think we want the solve_zsal code laying around in the drivers though. Thoughts? |
I agree, it's better to remove as much of the zsal code as possible but keep the namelist options so the abort will be clean and provide useful diagnostic information. |
Looks like nt_bgc_S and bgc_S in general is only used with zsalinity. Does that sound right? Is there any reason to keep this tracer index for some future need? Otherwise, I'll remove it, right? |
Yes, I think that's right. |
I'm in the process of deprecating zsalinity. It looks like the "UNDEPRECATE" implementation done earlier just made it impossible to run with zsalinity, but there is lots of code that actually has to still be removed. Is this correct? Should I try to do that or is this better done by someone with a better understanding of zsalinity?
The text was updated successfully, but these errors were encountered: