Skip to content
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

Update nonlinear channel flow benchmark #6164

Conversation

gassmoeller
Copy link
Member

This is a follow-up PR that is based on #6159. I here also rework the nonlinear channel flow benchmark. I still need to check some tests, but one thing I already noticed is: If I change the boundary traction value or the boundary velocity value the solver converge much better than with the values they are set to know. I kept the values the same to reproduce the figure like they are in the original paper, but I wanted to record this somewhere. It is curious how the traction benchmark stagnates at a constant nonlinear solver tolerance, even for models that use the standard Picard solver (therefore it is not related to the Newton solver or the defect correction solver).

@gassmoeller gassmoeller force-pushed the update_nonlinear_channel_flow_benchmark branch from a4411f3 to e09c782 Compare November 28, 2024 14:59
@gassmoeller gassmoeller force-pushed the update_nonlinear_channel_flow_benchmark branch from e09c782 to 0e3a60b Compare November 28, 2024 15:56
@gassmoeller gassmoeller changed the title [WIP] Update nonlinear channel flow benchmark Update nonlinear channel flow benchmark Nov 28, 2024
@gassmoeller
Copy link
Member Author

Ok, @MFraters I think this is also ready for a review. This PR does the following things:

  • Simplify running the nonlinear_channel_flow benchmark.
  • Expand the documentation of the benchmark, in particular mentioning the difference between the figures in the original Newton solver paper and what the current default solver parameters do.
  • Add 2 tests that use exactly the benchmark input files. This will ensure the benchmark files stay usable, and will also alert us if the results change. Although we already have many tests for the nonlinear channel flow benchmark they use their own copy of the input file and are therefore way out of date. I thought about changing the tests to use the existing benchmark file, but they are all based on one main test file, and because of Support recursively including parameter files in a better way #6165 I cannot simply base the main test file on the benchmark files.

Copy link
Member

@MFraters MFraters left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for writing this all up in detail. I think this will be helpful since it gives some insight into some of the choices which are made.

Adding exact tests from the benchmark without changes makes some sense to me, although the default state of the benchmark has no special meaning, it is just one of the cases. Nonetheless, I think it is a good idea to add, like you said, to be aware if we break it. The recursive parameter files sound really cool btw!

@MFraters MFraters merged commit e14c1ad into geodynamics:main Dec 2, 2024
7 of 8 checks passed
@gassmoeller gassmoeller deleted the update_nonlinear_channel_flow_benchmark branch December 10, 2024 14:55
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants