Tip
Need help? Please let us know in the UMEP Community.
Please report issues with the manual on GitHub Issues (or use Report Issue for This Page for page-specific feedback).
Please cite SUEWS with proper information from our Zenodo page.
1. Installation#
1.1. Formal releases#
Since 2023, SUEWS is available as a command line tool via its Python wrapper package SuPy (SUEWS in Python) on PyPI.
Note
The Fortran-based binaries build prior to 2023 are still available at the SUEWS download page. However, they are not maintained anymore so users are encouraged to use the Python-based packages instead.
1.1.1. Installing Python#
These instructions will set you up with mamba, which makes it easy to install and manage Python packages.
To install the mamba Python distribution follow the mamba installation instructions.
This makes installing supy and many other packages in the scientific Python ecosystem much easier and quicker.
It also provides many pre-compiled binaries that are not available on PyPI.
Tip
mamba is a drop-in replacement for conda (another widely used Python package manager):
mamba is faster and solves some common problems with conda.
More details about mamba can be found at mamba.
1.1.2. Installing SuPy#
One can install supy using pip:
python3 -m pip install supy --upgrade
1.2. Testing Development Versions#
Warning
⚠️ CAUTION: Development versions are unstable!
Development versions are pre-release and may contain bugs
Features may change or break without notice
Not recommended for production use or research publications
Only use if you need to test new features or help with development
Development versions are published to test.pypi.org for testing new features before official release.
Installation Steps:
Install uv (one-time setup):
# macOS/Linux curl -LsSf https://astral.sh/uv/install.sh | sh # Windows (PowerShell) powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
Note
uv is a fast Python package and environment manager written in Rust. It replaces pip, venv, and other tools with a single, faster solution.
Create an isolated environment:
uv venv .venv-dev source .venv-dev/bin/activate # Linux/macOS # or: .venv-dev\Scripts\activate # Windows # You'll see (.venv-dev) in your terminal prompt when activated
Tip
uv venv is 80x faster than python -m venv and automatically manages Python versions.
Check latest version at https://test.pypi.org/project/supy/ (format:
YYYY.M.D.dev0)Install development version:
# Replace 2025.9.16.dev0 with latest version from step 3 uv pip install --extra-index-url https://test.pypi.org/simple/ \ --index-strategy unsafe-best-match \ supy==2025.9.16.dev0
Verify installation:
python -c "import supy; print(f'SUEWS version: {supy.__version__}')" # Should show: 2025.9.16.dev0
For future use:
Always activate the virtual environment before working with the development version:
source .venv-dev/bin/activate # Linux/macOS
# or: .venv-dev\Scripts\activate # Windows
To deactivate when finished:
deactivate
Why uv?
Creates virtual environments 80x faster than standard tools
Handles test.pypi.org dependencies correctly with
--index-strategy unsafe-best-matchSingle tool for both environment and package management
Can automatically download and manage Python versions
1.3. Development build#
Warning
The development build can be highly unstable and is not recommended for production use. However, it is automatically constructed every week for testing purposes and we are happy to receive feedback on the development build.
To install the development build of SUEWS, you need to install supy in the development mode:
git clone the repository:
git clone https://github.com/UMEP-dev/SUEWS.git
navigate to the directory of the cloned repository:
cd SUEWS
install the package in the development mode:
make dev