-
Notifications
You must be signed in to change notification settings - Fork 132
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
Test nghost #855
Comments
I ran some tests manually with nghost>1 and it runs fine and is bit-for-bit for standard gx3 configurations. We could
Right now, there is a large amount of code implemented using nghost, but we don't test any of it for ghost > 1. On the other hand, I realize we only use nghost=1 (currently hardwired in code) and have no plans to have a larger stencil. So, we could also leave things as they are and defer any testing until it's needed, which might be never. Thoughts? |
If it actually works (which surprises me!), then it would be nice to maintain it. I don't think we need to make nghost a namelist input until someone actually needs to change it. That said, maintaining it means testing that it doesn't get broken in some PR, which might require a namelist input. I'm also fine just leaving things as they are. |
I too was surprised the it even ran including with debug flags on. Then it produce bit-for-bit was even more shocking. It could be eap or vp or some other configurations don't work with nghost>1, so another step might be to extend the testing. I'm undecided as well whether to test and maintain the nghost capability or just punt for now. If we do want to test, we need to make nghost a namelist so the testing software can run those tests. If the likelihood that nghost is >1 anytime in the next decade or so is low, maybe we should just leave it alone. |
But from a software engineering perspective, it would be cool to add the necessary test cases and make it part of our test suite. I guess the question is whether it's a requirement for the code to run with nghost>1. If so, we should test and maintain it. If not, then we shouldn't. One way to view nghost is that it's a parameter set to 1 and it's not expected/allowed to change without further testing/development. The fact that a bunch of code supports nghost>1 doesn't mean it's a requirement to do so. |
I doubt that it will be needed, perhaps ever. It's only in there because CICE was built on POP's framework. We could just note in the documentation that it exists and if it needs to be used, then the developer needing it should take care to test it very thoroughly, and at that point add a namelist option for it. |
I agree, I'll try to add something to the documentation then will close this issue. Thanks. |
Test nghost > 1, should be identical to nghost=1 for a given problem.
Alternatively, check value of nghost at initialization, abort if it's not 1.
The text was updated successfully, but these errors were encountered: