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

End-to-end Auto Mesh Gen #165

Open
15 of 27 tasks
felicio93 opened this issue Jul 11, 2024 · 5 comments
Open
15 of 27 tasks

End-to-end Auto Mesh Gen #165

felicio93 opened this issue Jul 11, 2024 · 5 comments
Assignees

Comments

@felicio93
Copy link
Collaborator

felicio93 commented Jul 11, 2024

General Plan:

The plan is to create an fully automated mesh generation tool for the land-ocean continuum that takes advantage of SCHISM's flexibility. That encompasses the ability of creating individual meshes for the floodplain, river, and ocean domains, following their specific mesh generation requirements, as well as emerging them accordingly.

Development Team: @felicio93, @SorooshMani-NOAA, @feiye-vims, @hyungjuyoo, @saeed-moghimi-noaa, @josephzhang8,

Software Development

Testing

Documentation


Development Iterations

We organize the development in 2 months iterations for which we define a Minimum Viable Product. Each iterations is a separate ticket. Feel free to add your suggestions/priorities. The Iteration 00 was completed with the successful validation of our first complete 2D mesh: https://github.com/SorooshMani-NOAA/river-in-mesh/issues/3

@felicio93 felicio93 self-assigned this Jul 11, 2024
@josephzhang8
Copy link

Thx @felicio93. I'd highly encourage you to write this up for Ocean Modelling Special Issue. It's highly relevant. Thx

@SorooshMani-NOAA
Copy link
Collaborator

@felicio93 the generic OCSMesh focused tasks I had in mind are:

  • Parallelization of size function calculation (collector type). The issue is that hfun object is not picklable due to reference to files object
  • Optimizing operations (e.g. contour calculation that we discussed)
  • Subsetting an existing mesh with remeshing the boundaries to match the subsetting shape
  • Parallelizing using Dask; right now the parallelization is limited to a single node.

@hyungjuyoo
Copy link

Hi, I am Hyung Ju, Yoo (post-doc) from Joseph's group.

Thank you for inviting me.

@felicio93
Copy link
Collaborator Author

tagging @janahaddad for reference

@pbranson
Copy link

Chiming in here, I work at CSIRO in Australia and have been testing out OCS mesh these past few weeks, with mostly positive results - thanks for your work on this!

@felicio93 the generic OCSMesh focused tasks I had in mind are:

  • Parallelization of size function calculation (collector type). The issue is that hfun object is not picklable due to reference to files object
  • Parallelizing using Dask; right now the parallelization is limited to a single node.

Can I suggest that you take a look at using FSSpec for file handling, it allows for a uniform interface between POSIX and cloud storage, are generally lazy locking, which allows for pickling of python file-like objects that are also supported by rasterio: see rasterio/rasterio#2905 These aspects also help with dask

On the dask front, you could consider using https://corteva.github.io/rioxarray/html/rioxarray.html to interface with rasterio which provides an xarray container overlay on rasterio that can leverage all of xarray+dask computational graph generation. It would likely be some effort to transition away from the current "windows" approach, so you could perhaps maintain that for multi-threaded processing within larger dask-chunks - this kind of approach can actually be beneficial as it reduces the overall size of the dask graph which can become an overhead for very large datasets.

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

No branches or pull requests

5 participants