Skip to main content

A simple toolkit for baseflow separation and Baseflow Index (BFI) estimation from daily streamflow.

Project description

🌊 BFI-Toolkit

TestPyPI PyPI License: MIT DOI

A lightweight and flexible Python package for estimating Baseflow and Baseflow Index (BFI) from streamflow time series.

This toolkit provides a simple, efficient way to:

  • Separate baseflow using forward/backward recession analysis
  • Compute optimized decay parameters (k)
  • Calculate BFI — a key hydrologic metric for understanding watershed storage and runoff behavior.

📄 Associated Research

This toolkit was developed as part of the work presented in:

Farmani, M. A., Tavakoly, A., Behrangi, A., Qiu, Y., Gupta, A., Jawad, M., Yousefi Sohi, H., Zhang, X., Geheran, M., Niu, G.-Y. (2025).
Improving Streamflow Predictions in the Arid Southwestern United States Through Understanding of Baseflow Generation Mechanisms.
Water Resources Research. https://doi.org/10.1029/2024WR039479

© Author(s) 2025. This work is distributed under the Creative Commons Attribution 4.0 License.


🧠 Scientific Background

This toolkit builds on established methods for baseflow estimation using recession analysis and BFI calculation.
The underlying baseflow recession concept is based on:

van Dijk, A. I. J. M. (2010). Climate and terrain factors explaining streamflow response and recession in Australian catchments.
Hydrology and Earth System Sciences, 14(1), 159–169.
https://doi.org/10.5194/hess-14-159-2010


📦 Installation

From PyPI (when released)

pip install bfi-toolkit

From source (development version)

git clone https://github.com/mfarmani95/BFI-Toolkit.git
cd BFI-Toolkit
pip install -e .

This installs the package in editable mode, so any code edits are reflected immediately without reinstalling.


⚡️ Quick Start

import numpy as np
from bfi_toolkit import compute_bfi

# Example: simple synthetic streamflow data
streamflow = np.array([5, 5, 5, 6, 7, 6, 5.8, 5.6, 5.4, 5.2, 5, 4.9, 4.8])

result = compute_bfi(streamflow, day_after_peak=2,min_events=1,min_pairs=3, start_date="2020-01-01")

# day_after_peak : Number of days to exclude after each detected runoff peak.
# min_events : Minimum number of runoff events required.
# min_pairs :  Minimum number of Q–Q* pairs required.

print("Optimized k:", result["k"])
print("BFI:", result["bfi"])
print("Baseflow head:\n", result["baseflow"].head())

Supported input types:

  • Python list
  • numpy.ndarray
  • pandas.DataFrame (must contain column QQ)
  • torch.Tensor (optional, if PyTorch installed)

🧪 Development Setup

Option 1: with pip

git clone https://github.com/mfarmani95/BFI-Toolkit.git 
cd BFI-Toolkit
python -m venv .venv
source .venv/bin/activate   # (Windows: .venv\Scripts\activate)
pip install -r requirements-dev.txt

Option 2: with Conda (recommended)

git clone https://github.com/mfarmani95/BFI-Toolkit.git 
cd BFI-Toolkit
conda env create -f environment.yml
conda activate bfi-toolkit

Then:

make dev     # install dev dependencies
make test    # run tests

🧰 Useful Makefile Commands

Command Description
make install Install package in editable mode
make dev Install dev dependencies
make test Run test suite with pytest
make format Auto-format code with Black
make lint Run static checks with Ruff
make build Build distribution package
make upload-test Upload to TestPyPI
make upload Upload to PyPI

🧠 Contributing

We welcome contributions from the community 🙌

  1. Fork the repository
  2. Create a feature branch
  3. Commit your changes with clear messages
  4. Add or update tests if needed
  5. Submit a Pull Request

Before submitting:

make format
make lint
make test

🧭 Features

  • ✅ Supports multiple input formats (NumPy, Pandas, PyTorch, lists)
  • 📉 Flexible dry period filtering with day_after_peak
  • ⚙️ Optimized decay constant estimation (k)
  • 💧 Baseflow separation using forward/backward recession
  • 📊 Automatic BFI calculation
  • 🧰 Clean modular structure (core, utils, optimization, baseflow)
  • 🧪 Fully testable with pytest

📝 Citation

If you use this toolkit in your research or operational projects, please cite:

Farmani, M. A. (2025). BFI-Toolkit: A lightweight Python package for estimating baseflow and Baseflow Index (BFI).
GitHub: https://github.com//BFI-Toolkit


📜 License

This project is licensed under the MIT License.
You’re free to use, modify, and distribute it — just give credit where it’s due.


🚀 Roadmap

  • Add uncertainty quantification for k estimates
  • Add multi-resolution time series support (weekly, monthly)
  • Add visualization module (hydrograph plotting)
  • Add unit conversion utilities for different discharge formats
  • Publish as official PyPI package

💧 Acknowledgements

Developed as part of ongoing hydrologic research by
Mohammad Ali Farmani — University of Arizona.

Inspired by the need for transparent, flexible, and efficient baseflow separation tools for hydrologic modeling and water resources applications.

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

bfi_toolkit-0.1.3.tar.gz (12.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bfi_toolkit-0.1.3-py3-none-any.whl (10.4 kB view details)

Uploaded Python 3

File details

Details for the file bfi_toolkit-0.1.3.tar.gz.

File metadata

  • Download URL: bfi_toolkit-0.1.3.tar.gz
  • Upload date:
  • Size: 12.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.18

File hashes

Hashes for bfi_toolkit-0.1.3.tar.gz
Algorithm Hash digest
SHA256 3cdafd5a16851071e22919563ec8ab48e27e79e1a3614045d7f38566730324f0
MD5 cada4106524b84050e365cf318808c10
BLAKE2b-256 bd994153d7ca013db0bffe12e6e948637f0bf3eb447f514512b9769713ce0a78

See more details on using hashes here.

File details

Details for the file bfi_toolkit-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: bfi_toolkit-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 10.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.18

File hashes

Hashes for bfi_toolkit-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 9f4226e11a23f2261ffab38a22f738958c4c0203aa0fa176c5c43a05d45f9732
MD5 e35afd4b54a37635939ea0be04ff4c40
BLAKE2b-256 1a1b83fec5189db9a059ce999d45fd3f06508231f090627979bc9c6792a3508c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page