HydroCompute

Table of Contents

Link to documentation

Introduction

This work introduces HydroCompute, a computational library for hydrology and environmental sciences that runs on the client side. It employes 4 different engines, 3 main computations and 1 for peer-to-peer connection. The library has been developed using ES6 standards and the most recent available APIs for WebAssembly, WebGPU, WebRTC, and the Web Workers specifications.

How to Use

Please download the library and run index.html. If a new html file should be created, the library must be onloaded onto the file as a script

<script
 type = "module"
 src= "src/hydrocompute.js"
></script>

The library is loaded into an HTML web app by declaring either it as a window object when loading, or as a single instance run as follows:

const compute = new hydrocompute('engineName');

When instantiated if no specific engines are passed into the constructor, the library will default to run using the functions within the JavaScript engine. The available engines along with existing code and how to develop more functions for usage in the library can be found in the following links:

  • WebAssembly: Available C and AssemblyScript bindings.
  • JavaScript: Available as native JavaScript object.
  • WebGPU: GLSL code onloaded as strings in a JavaScript object.

Running a simulation

By default, the hydrocompute library runs need 3 specific instructions settings: data, steps, and functions. The data submitted to the library is saved using the following instruction:

compute.data({ id: 'itemName', data: some2Dor1Darray })

If no id is passed, the library will save a random name generated for the data. To revise the available data, then pass the command

compute.availableData()

Steps are inferred from the configuration for each

If there is only 1 data souce available inside the available data namespace, then just calling run would suffice.

compute.run()

To run a batch work, do:

compute.run({
    linked: Boolean stating linkeage between steps
    functions: [Array of functions per step],
    dataId: [Array of names of saved data],
    dependencies: [Array of dependencies as numbers, if applicable],
    funcArgs: [Array of additional configurations per function, if applicable]
})

The console of the browser will show the number of executions done by the engine once the results are finished. To retrieve the results, prompt the following command.

compute.availableResults()

The results per simulation will be saved with nametag Simulation_N.

A list of case studies and examples can be found here.

A self-guided tutorial can be found in the following link.

Expansions and Test Cases

Expansions

Currently the library works fully with Chromium based browsers. Mozilla implementations will be added in future releases.

New modules for dealing with Web Assembly compiled code will be implemented as well as new working examples for a more comprehensive view of what the library can do.

Community

It is possible for the library to expand by becoming a community-based framework with collaborations from research institutes or knowledgeable individuals thanks to the flexibility of employing a modular architecture, open-source libraries, and not requiring installation. Interested parties can adapt and expand HydroLang to fit their unique use cases, development environments, project requirements, and data resources. Everyone is encouraged to contribute to the growth of HydroCompute by:

  • filing an issue to request certain features, functionality, and data,
  • implementing the desired capability on a fork, and submitting a pull request.

Feedback

Please feel free to send feedback to us on any issues found by filing an issue.

Scalability and To-Do's

The HydroCompute library is a work in progress that aims in providing a scalable set of tools so that the hydrologic community can benefit from. To this extent, we have the following open developments that will be included in future deployments:

  • New engines and functions for the existing engines will be added into the library for easier implementation and usage.
  • A webpack implementation of the library that provides an easier interaction directly from a CDN.
  • Create a better integration with technologies such as Docker containers to streamline the deployment of new functions using WebAssembly into the library.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgements

This project was funded by the National Oceanic & Atmospheric Administration (NOAA) via a cooperative agreement with The University of Alabama (NA22NWS4320003) awarded to the Cooperative Institute for Research to Operations in Hydrology (CIROH).

References

  • Erazo Ramirez, C., Sermet, Y., & Demir, I. (2023). Hydrocompute: An Open-Source Web-Based Computational Library for Hydrology and Environmental Sciences. EarthArxiv. https://doi.org/10.31223/X5FM2D