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

[5pt] PR: Post-processing tool for inundation: interpolate water surface #1048

Merged
merged 19 commits into from
Jan 3, 2025

Conversation

CarsonPruitt-NOAA
Copy link
Collaborator

@CarsonPruitt-NOAA CarsonPruitt-NOAA commented Dec 8, 2023

This script produces inundation depths and attempts to overcome the catchment boundary issue by interpolating water surface elevations between catchments. Water surface calculations require the hydroconditioned DEM (dem_thalwegCond_{}.tif) for computation, however, this file is not in the standard outputs from fim_pipeline.sh. Therefore, users may have to re-run fim_pipeline.sh with dem_thalwegCond_{}.tif removed from all deny lists.

Additions

  • tools/interpolate_water_surface.py: New post-inundation processing tool for extending depths beyond catchment limits. The interpolate_wse() contains the logic for computing the updated depth raster, but users can also call this module directly to perform inundation, similar to how inundate_mosaic_wrapper.py works, but with the new post-processing enhancement.

Testing

This method has not been widely tested for improved FIM skill. Here is the example usage:

python interpolate_water_surface.py -y /outputs/fim_pipline_outputs -u 17110009 17110010 \
    -f /home/user/interpolated_fim/custom_flow_file.csv -d /home/user/interpolated_fim/depth_raster.tif

Screenshots

This plot shows a transect of water surface elevation and the DEM in between 2 catchments where a catchment boundary is limiting inundation extent. The interpolate_water_surface.py tool interpolates the water surface to fill the gap in between. If the DEM surface is below the interpolated water surface, the area should be classified as inundated.
profile_plot

These maps show the results. Blue is the original depth output from HAND and the yellow/orange shows the additional interpolated depth using this method. The catchment boundaries are the red polygons.
image
image
image

Issuer Checklist (For developer use)

You may update this checklist before and/or after creating the PR. If you're unsure about any of them, please ask, we're here to help! These items are what we are going to look for before merging your code.

  • Informative and human-readable title, using the format: [_pt] PR: <description>
  • Links are provided if this PR resolves an issue, or depends on another other PR
  • If submitting a PR to the dev branch (the default branch), you have a descriptive Feature Branch name using the format: dev-<description-of-change> (e.g. dev-revise-levee-masking)
  • Changes are limited to a single goal (no scope creep)
  • The feature branch you're submitting as a PR is up to date (merged) with the latest dev branch
  • pre-commit hooks were run locally
  • Any change in functionality is tested
  • Passes all unit tests locally (inside interactive Docker container, at /foss_fim/, run: pytest unit_tests/)
  • New functions are documented (with a description, list of inputs, and expected output)
  • Placeholder code is flagged / future todos are captured in comments
  • CHANGELOG updated with template version number, e.g. 4.x.x.x
  • Reviewers requested
  • Add yourself as an assignee in the PR as well as the FIM Technical Lead

Merge Checklist (For Technical Lead use only)

  • Update CHANGELOG with latest version number and merge date
  • Update the Citation.cff file to reflect the latest version number in the CHANGELOG
  • If applicable, update README with major alterations

@CarsonPruitt-NOAA CarsonPruitt-NOAA added the enhancement New feature or request label Dec 8, 2023
@CarsonPruitt-NOAA CarsonPruitt-NOAA self-assigned this Dec 8, 2023
@CarsonPruitt-NOAA CarsonPruitt-NOAA changed the title PR: [5pt] Post-processing tool for inundation: interpolate water surface [5pt] PR: Post-processing tool for inundation: interpolate water surface Dec 8, 2023
@jameshalgren
Copy link

jameshalgren commented Jan 2, 2024

Hi @CarsonPruitt-NOAA, at some point, it might make sense to see if this code could be transformed to python to permit spillover in the library generation step.

@ku22dw

@CarsonPruitt-NOAA
Copy link
Collaborator Author

@RyanSpies-NOAA Hey, just wanted to put this one back on your radar so we can merge this PR. Since we're unlikely to use this tool much, just a quick test is okay.

RyanSpies-NOAA
RyanSpies-NOAA previously approved these changes Dec 31, 2024
Copy link
Collaborator

@RyanSpies-NOAA RyanSpies-NOAA left a comment

Choose a reason for hiding this comment

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

Tested and reviewed

RobHanna-NOAA
RobHanna-NOAA previously approved these changes Dec 31, 2024
@CarsonPruitt-NOAA CarsonPruitt-NOAA merged commit d6ae01d into dev Jan 3, 2025
1 check passed
@CarsonPruitt-NOAA CarsonPruitt-NOAA deleted the dev-catchment-spillover branch January 3, 2025 21:13
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request Ready_to_Merge
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants