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

Refactor TabulatedRatingCurve / time updating #1976

Closed
visr opened this issue Dec 16, 2024 · 0 comments · Fixed by #2003
Closed

Refactor TabulatedRatingCurve / time updating #1976

visr opened this issue Dec 16, 2024 · 0 comments · Fixed by #2003
Labels
tech-debt Improvements related to technical debt

Comments

@visr
Copy link
Member

visr commented Dec 16, 2024

TabulatedRatingCurve and Subgrid are the two LinearInterpolations that can be updated over time. For both we currently only support instantaneous updates.

TabulatedRatingCurve was done first in #165, and the unprocessed time table is read during initialization, after which the callback (update_tabulated_rating_curve!) searches the sorted table for the right data. From this a LinearInterpolation is created which is put into the model struct. This callback runs each time new data appears, which is precomputed.

The Subgrid update from #1975 was done differently, which is more in line with the way we update the other dynamic data. We process the tables into interpolation objects at initialization time, then use these to lookup the right data at runtime. Note that there is a double lookup. First we use the subgrid ID and time to look up what the h(h) is, and then use that to look up the h.

We should probably refactor TabulatedRatingCurve / time handling to be more like Basin / subgrid_time. One thing to consider is that this setup only supports instantaneous updating of relations. For now there is no need yet to support gradually changing relations over time, though there were reports of convergence issues is Q(h) relations get changed a lot over time, so eventually we may need time-smoothing in addition to #1919. It would need to work with a different number of data points in the LinearInterpolation over time, and DataInterpolations.jl is currently restricted to 1D.

With this we should also change the sorting like done for other tables in #601, in the fix for that I purposely let sort_by_time_id_level alone. Possibly we should directly do this action for Basin as well: use interpolation objects instead of update_basin, which still relies on time being sorted first. Which was also mentioned in #601.

@visr visr added the tech-debt Improvements related to technical debt label Dec 16, 2024
@github-project-automation github-project-automation bot moved this to To do in Ribasim Dec 16, 2024
visr added a commit that referenced this issue Dec 20, 2024
Fixes #1010

This adds `Basin / subgrid_time`. So far the only relation we could
update over time was `Q(h)` (`TabulatedRatingCurve / time`), and that is
implemented differently. I wrote #1976 to get those more in line. It's
good to read that since it explains the implementation here.

Things I dislike:
- Need a special case to allow an underscore in `Basin / subgrid_time`,
just like `Basin / concentration_`.
- Other dynamic tables are just named time and have a static counterpart
like `Basin / static`, `Basin / time`. Since we already have `Basin /
subgrid` we cannot do that.

---------

Co-authored-by: Maarten Pronk <[email protected]>
visr added a commit that referenced this issue Jan 13, 2025
Fixes #1976.
Fixes most of #601.
@github-project-automation github-project-automation bot moved this from To do to ✅ Done in Ribasim Jan 13, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
tech-debt Improvements related to technical debt
Projects
Status: Done
Development

Successfully merging a pull request may close this issue.

1 participant