Skip to main content

SYnergistic Modelling Framework for Linking and Unifying Earth-system Nexii for Computational Exploration

Project description

SYMFLUENCE

SYnergistic Modelling Framework for Linking and Unifying Earth-system Nexii for Computational Exploration

PyPI version Python 3.11+ License: GPL v3 Documentation Build Status Tests


Overview

SYMFLUENCE is a computational environmental modeling platform that streamlines the hydrological modeling workflow—from domain setup to evaluation. It provides an integrated framework for multi-model comparison, parameter optimization, and automated workflow management across spatial scales.


Quick Links


Installation

pip install symfluence

After installation, install external model binaries:

symfluence binary install

For development setup (editable install / bootstrap) and all other install methods — Docker, conda, npm, uv, HPC modules — see the installation guide.


Quick Start

Basic CLI Usage

# Show options
symfluence --help

# Run full workflow
symfluence workflow run --config my_config.yaml

# Run specific steps
symfluence workflow steps setup_project calibrate_model

# Define domain from pour point
symfluence project pour-point 51.1722/-115.5717 --domain-name MyDomain --definition semidistributed

# Check workflow status
symfluence workflow status

# Validate configuration
symfluence config validate --config my_config.yaml

First Project

# Initialize project from template
symfluence project init

# Or copy template manually
cp src/symfluence/resources/config_templates/config_template.yaml my_project.yaml

# Run setup
symfluence workflow step setup_project --config my_project.yaml

# Run full workflow
symfluence workflow run --config my_project.yaml

Python API

For programmatic control or integration:

from pathlib import Path
from symfluence import SYMFLUENCE

cfg = Path('my_config.yaml')
symfluence = SYMFLUENCE(cfg)
symfluence.run_individual_steps(['setup_project', 'calibrate_model'])

Configuration

YAML configuration files define:

  • Domain boundaries and discretization
  • Model selection and parameters
  • Optimization targets
  • Output and visualization options

See src/symfluence/resources/config_templates/config_template.yaml for a full example.


Project Structure

SYMFLUENCE/
├── src/symfluence/           # Main Python package
│   ├── core/                 # Core system, configuration, mixins
│   ├── cli/                  # Command-line interface
│   ├── project/              # Project and workflow management
│   ├── data/                 # Data acquisition and preprocessing
│   ├── geospatial/           # Domain discretization and geofabric
│   ├── models/               # Model integrations (SUMMA, FUSE, GR4J, etc.)
│   ├── optimization/         # Calibration algorithms (DDS, DE, PSO, NSGA-II)
│   ├── evaluation/           # Performance metrics and evaluation
│   ├── reporting/            # Visualization and plotting
│   └── resources/            # Configuration templates and base settings
├── examples/                 # Progressive tutorial examples
├── docs/                     # Sphinx documentation source
├── scripts/                  # Build and release scripts
├── tools/                    # NPM packaging and utilities
└── tests/                    # Unit, integration, and E2E tests

Branching Strategy

  • main: Stable releases only — every commit is a published version.
  • develop: Ongoing integration — merges from feature branches and then tested before release.
  • Feature branches: feature/<description>, PR to develop.

Contributing

See CONTRIBUTING.md for:

  • Code standards and testing
  • Branching and pull request process
  • Issue reporting

License

Licensed under the GPL-3.0 License. See LICENSE for details.

Commercial Licensing

SYMFLUENCE is free and open-source software under GPL-3.0-or-later. For organizations that require alternative licensing terms — including proprietary integration, redistribution without copyleft obligations, or operational deployment support — commercial licenses are available.

For commercial licensing, derivative-platform inquiries, and the Foundation's dual-licensing policy, see LICENSING.md.

Contact: licensing@symfluence.org (licensing) · dev@symfluence.org (general)


Happy modelling! The SYMFLUENCE Team

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

symfluence-0.9.0.tar.gz (3.4 MB view details)

Uploaded Source

Built Distribution

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

symfluence-0.9.0-py3-none-any.whl (3.9 MB view details)

Uploaded Python 3

File details

Details for the file symfluence-0.9.0.tar.gz.

File metadata

  • Download URL: symfluence-0.9.0.tar.gz
  • Upload date:
  • Size: 3.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for symfluence-0.9.0.tar.gz
Algorithm Hash digest
SHA256 c0528f53e23d4a61af6aefe0f2924dda150f258c1ccda0c6d010a2a468aef540
MD5 9dcd78307ec04a4a4452c2e4961c665a
BLAKE2b-256 36a8f0fc07db0636d23cef17a80e46c4a2d391e4a4db0723f0ca05164d5e6ba5

See more details on using hashes here.

File details

Details for the file symfluence-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: symfluence-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 3.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for symfluence-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c52e11767da164ecfb2c92d07a639561aa4d50784200d9e87cea6598bdac8ba6
MD5 30ebee5bddeca368473e92e0eff19826
BLAKE2b-256 60e90ce83cfe643e1a5f53222cefc8df76692d0997874473d4eca29d22e09ae3

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