Reservoir Estimation of Capacity Loss using AI based Methods
Project description
First-of-its-kind globally scalable tool to predict reservoir sedimentation, screen vulnerable reservoirs, and pinpoint those struggling the most.
RECLAIM (Reservoir Estimation of Capacity Loss using AI-based Methods) is a globally scalable machine learning framework to predict absolute sedimentation rates in reservoirs using observed records and multi-decadal satellite-based Earth observations.
It is the first-of-its-kind tool to:
- Rapidly assess sedimentation risk
- Provide scalable predictions across diverse climates and geographies
- Enable cost-effective screening to prioritize reservoirs for detailed surveys
- Support decision-making for mitigation interventions where they are most needed
Note: RECLAIM is designed as a screening tool, not a replacement for field surveys. It helps guide where and when to act first.
Installation
Install the package via pip:
pip install pyreclaim
Documentation
The documentation is available here.
Quick Start / Example Workflow
This example shows generating features, loading the pretrained model, predicting sedimentation rates, and evaluating results.
from reclaim.generate_features import create_features_per_row
from reclaim.reclaim import Reclaim
# Step 1: Generate features for a reservoir
reservoir_static = {
"obc": 150.0,
"hgt": 45.0,
"mrb": "Ganges",
"lat": 25.6,
"lon": 81.9,
"reservoir_polygon": reservoir_polygon,
"aec_df": aec_df
}
catchment_static = {
"ca": 1200,
"dca": 50,
"catchment_geometry": catchment_geom,
"glc_share_path": "data/glc.nc",
"hwsd2_path": "data/soil.nc",
"hilda_veg_freq_path": "data/veg.nc",
"terrain_path": "data/terrain.nc"
}
features = create_features_per_row(
reservoir_static_params=reservoir_static,
catchment_static_params=catchment_static,
observation_period=[2000, 2020]
)
# Step 2: Load pretrained RECLAIM model
model = Reclaim()
model.load_model() # loads XGBoost, LightGBM, CatBoost, and metadata
# Step 3: Predict sedimentation rates using ensemble
pred_sr, weights = model.predict(features, return_weights=True)
# Step 4: Inspect predictions
print(pred_sr)
print(weights)
# Step 5: Evaluate (if ground truth available)
y_true = [...] # replace with true sedimentation rates
metrics = model.evaluate(features, y_true)
print(metrics) # {'RMSE': ..., 'MAE': ..., 'R2': ...}
Citation
If you use RECLAIM in your work, please cite:
Minocha, S., Hossain, F., Zhao, J., & Istanbulluoglu, E.
RECLAIM: A Globally Scalable Machine Learning Framework to Predict Reservoir Sedimentation and Capacity Loss from Satellite-based Earth Observations (Submitted to Environmental Modelling and Software (EMS)).
License
RECLAIM 3.0 is distributed under the GPL v3 license. You may copy, distribute, and modify the software as long as you track changes/dates in source files. Any modifications or software including GPL-licensed code must also be made available under GPL along with build & install instructions.
For more information, see LICENSE.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyreclaim-0.2.0.tar.gz.
File metadata
- Download URL: pyreclaim-0.2.0.tar.gz
- Upload date:
- Size: 63.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
62420c715d6651c3bd0c5a9c8df7a0ccb23d2489737ef6cc7f990ba5ebe5d6e7
|
|
| MD5 |
f5574430a10d65977815cc0b526add36
|
|
| BLAKE2b-256 |
cd79b10fbbe7410fcc38a2cfc1b514bea78cb601670ac8e98ca891cbf4a79cdb
|
File details
Details for the file pyreclaim-0.2.0-py3-none-any.whl.
File metadata
- Download URL: pyreclaim-0.2.0-py3-none-any.whl
- Upload date:
- Size: 56.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4ad40addc087b383da4e493223473b045fc8a9d116f749b809123a9843b6c70b
|
|
| MD5 |
9f830e1c9870c3d09462650356786d90
|
|
| BLAKE2b-256 |
e3ec9346aaad41185134b68267e227a360ebc97c76bddd5f156619c2e6245e7a
|