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 implicit solver interface #542

Merged
merged 1 commit into from
May 23, 2024
Merged

update implicit solver interface #542

merged 1 commit into from
May 23, 2024

Conversation

juliasloan25
Copy link
Member

@juliasloan25 juliasloan25 commented Mar 7, 2024

Purpose

Update implicit solver interface for RichardsModel to use ClimaCore.MatrixFields.

Comparing the buildkite timing to the most recent main build, the RichardsModels runs see a ~25% speedup from this PR.

closes #528
#602 has to be merged first for update to ClimaCore v0.14

To Do

Content

  • delete thomas_algorithm
    handling multiple vars
  • the full soil case will contain a variable that isn't stepped implicitly (theta_i), so we can't just loop over everything in the state
    • when extending, will add if statement, so that we use tridiagonal for theta_l and heat, and identity for theta_i
  • boundary conditions
  • allocate space in cache for dtopBCdY (extend boundary_vars, boundary_var_domain_names, boundary_var_types, etc for MoistureStateBC)
  • update cache var with expression currently in dtendencyBCdY (except multiply by dz factor)
  • update dtendencyBCdY: update in place, rename to set_dfluxBCdY!, multiply by dz factor
  • update dtheta_resdtheta setting: add if/else branch where if default use expression currently in code; if p.soil.dtopBCdtheta exists, add dtopBCdtheta term before div applied (use Operators.SetBoundaryOperators, then construct Bidiagonal(?)Matrix of zeros with this BC)

Status 4/17/24

The implicit solver has been updated and works on CPU. It doesn't work on GPU because of a couple of problems. First, one of the operators produces a non-isbits object. This is because the space is not being stripped out of the input object, which should happen via a call to strip_space. We need to extend adapt_structure for the SetBoundaryOperator type (and perhaps other operator types too), but even with that the solver fails on GPU.

It seems like the second bug may be from FT not being inferred correctly when it crosses the function boundary from make_update_jacobian to update_jacobian!


  • I have read and checked the items on the review checklist.

@juliasloan25 juliasloan25 force-pushed the js/imp-interface branch 4 times, most recently from dfab428 to d60e2b2 Compare March 15, 2024 22:41
src/standalone/Soil/rre.jl Outdated Show resolved Hide resolved
src/standalone/Soil/rre.jl Outdated Show resolved Hide resolved
src/standalone/Soil/rre.jl Outdated Show resolved Hide resolved
@juliasloan25 juliasloan25 force-pushed the js/imp-interface branch 3 times, most recently from 8536daf to 6248969 Compare April 4, 2024 21:17
@juliasloan25 juliasloan25 force-pushed the js/imp-interface branch 3 times, most recently from 627e577 to 8f897bd Compare April 13, 2024 00:09
@juliasloan25 juliasloan25 force-pushed the js/imp-interface branch 2 times, most recently from 41defca to ec37455 Compare April 19, 2024 22:52
@juliasloan25 juliasloan25 mentioned this pull request Apr 22, 2024
@juliasloan25 juliasloan25 requested a review from kmdeck April 24, 2024 21:25
test/runtests.jl Outdated Show resolved Hide resolved
src/standalone/Soil/rre.jl Outdated Show resolved Hide resolved
@@ -1,5 +1,4 @@
export make_tendency_jacobian,
make_update_jacobian, AbstractTridiagonalW, ∂tendencyBC∂Y
export make_tendency_jacobian, make_update_jacobian, set_dfluxBCdY!
Copy link
Member

Choose a reason for hiding this comment

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

I wonder if this should have a clearer name, or if we need this function at all. We can get rid of this function if we move the update_aux! and update_boundary_fluxes! function calls that make_tendency_jacobian does before it calls update jacobian into update_jacobian.

Copy link
Member Author

Choose a reason for hiding this comment

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

Good point! I think it makes more sense to get rid of make_tendency_jacobian, and just have make_update_jacobian

Copy link
Member Author

@juliasloan25 juliasloan25 May 9, 2024

Choose a reason for hiding this comment

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

I realized that now we're updating the aux and boundary fluxes in exp_tendency!, imp_tendency!, and update_jacobian!. I think this is fine for now, but we might want to avoid recomputing these multiple times per timestep. Dennis mentioned that ClimaTimeSteppers has the capability to take in an update cache function, which will be called once per timestep (Atmos leverages this to call set_precomputed_quantities! as few times as possible)., so we could later on switch to using that as a performance improvement

Copy link
Member Author

Choose a reason for hiding this comment

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

After removing tendency_jacobian!, we can't directly compare the jacobian entries in test/shared_utilities/implicit_timestepping/richards_model.jl, since update_jacobian! also calls update_aux and boundary_fluxes. I wonder if it's still worth keeping separate functions for cleaner structure and more granular testing

Copy link
Member

@kmdeck kmdeck left a comment

Choose a reason for hiding this comment

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

This looks good! I left a couple of minor comments. nice job @juliasloan25 @dennisYatunin !!

@juliasloan25 juliasloan25 force-pushed the js/imp-interface branch 4 times, most recently from 1d27737 to 26f468a Compare May 15, 2024 19:29
@juliasloan25
Copy link
Member Author

juliasloan25 commented May 18, 2024

failing because of a change introduced in CliMA/ClimaCore.jl#1653 - need to debug this

@juliasloan25
Copy link
Member Author

juliasloan25 commented May 22, 2024

failing because of a change introduced in CliMA/ClimaCore.jl#1653 - need to debug this

fixed in CliMA/ClimaCore.jl#1750

@juliasloan25 juliasloan25 requested a review from kmdeck May 22, 2024 20:51
Copy link
Member

@kmdeck kmdeck left a comment

Choose a reason for hiding this comment

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

looks great! thank you!!

@juliasloan25 juliasloan25 force-pushed the js/imp-interface branch 3 times, most recently from e4bc924 to 032fa3d Compare May 23, 2024 18:18
@juliasloan25 juliasloan25 enabled auto-merge May 23, 2024 18:58
@juliasloan25 juliasloan25 merged commit 9d41b66 into main May 23, 2024
9 checks passed
@juliasloan25 juliasloan25 deleted the js/imp-interface branch May 23, 2024 20:19
@juliasloan25 juliasloan25 mentioned this pull request Oct 30, 2024
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.

use new interface for implicit RRE
3 participants