Forest Harvesting Operations Planning System
Project description
FHOPS — Forest Harvesting Operations Planning System
FHOPS is a Python package and CLI for building, solving, and evaluating forest harvesting operations plans. It provides:
- A data contract (Pydantic models) for blocks, machines, landings, calendars.
- A deterministic MIP builder using Pyomo, with HiGHS as the default solver (optional Gurobi support when installed/licensed).
- A metaheuristic engine (Simulated Annealing v0.1) with pluggable operators.
- A CLI (
fhops) to validate data, solve with MIP or heuristics, and evaluate results.
Installation
pip install fhops # once the release candidate lands on PyPI
For local development or when cutting a release candidate, use Hatch to mirror the CI suite:
pip install hatch
hatch run dev:suite
Quick start (development install)
# inside a fresh virtual environment (Python 3.12+ recommended)
pip install -e .[dev]
# optional extras for spatial IO
pip install .[geo]
# optional extras for commercial MIP backends
# (requires a Gurobi install + license)
pip install .[gurobi]
### Optional: Gurobi setup (Linux)
HiGHS remains the default open-source MIP solver. If you have an academic or commercial Gurobi
licence and want to use it with FHOPS:
```bash
# install gurobipy alongside FHOPS
pip install fhops[gurobi]
# download the licence tools bundle (version shown as example)
wget https://packages.gurobi.com/lictools/licensetools13.0.0_linux64.tar.gz
tar xvfz licensetools13.0.0_linux64.tar.gz
# request your licence key (replace XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX)
./grbgetkey XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
# accept the default install path (typically $HOME/gurobi.lic) or specify a custom location.
# if stored elsewhere, point gurobipy at it:
export GRB_LICENSE_FILE=/path/to/gurobi.lic
# quick sanity check
python -c "import gurobipy as gp; m = gp.Model(); m.setParam('OutputFlag', 0); m.optimize()"
After the licence is active you can run FHOPS MIP commands with --driver gurobi (or
gurobi-appsi / gurobi-direct). Without an available licence FHOPS falls back to HiGHS.
Validate & Evaluate
fhops validate examples/minitoy/scenario.yaml
fhops solve-mip examples/minitoy/scenario.yaml --out examples/minitoy/out/mip_solution.csv
fhops solve-heur examples/minitoy/scenario.yaml --out examples/minitoy/out/sa_solution.csv
fhops evaluate examples/minitoy/scenario.yaml examples/minitoy/out/mip_solution.csv
fhops solve-mip tests/fixtures/regression/regression.yaml --out /tmp/regression_mip.csv
fhops solve-heur tests/fixtures/regression/regression.yaml --out /tmp/regression_sa.csv
fhops evaluate tests/fixtures/regression/regression.yaml /tmp/regression_sa.csv
Expected evaluation output includes sequencing_violation_count=0. Mobilisation costs are
exercised in tests/test_regression_integration.py, which injects machine parameters before
running the CLI.
Analytics notebooks & dashboards
Executed analytics notebooks live under docs/examples/analytics/ and are published to the
documentation site. They showcase deterministic playback, stochastic robustness, telemetry
diagnostics, and benchmarking workflows. Regenerate them locally with:
python scripts/run_analytics_notebooks.py --light
The --light flag mirrors CI: it sets FHOPS_ANALYTICS_LIGHT=1, trimming stochastic sample counts so
the suite finishes quickly. Drop the flag (or unset the environment variable) when you want the full
ensemble versions.
Live dashboards (auto-published after every main build and the weekly full notebook run) live at
https://ubc-fresh.github.io/fhops/reference/dashboards.html. Highlights:
- Telemetry history trends and per-scenario leaderboards.
- Latest tuner reports, comparison tables, and win-rate leaderboards.
- Difficulty indices per bundle/tier and weekly notebook metadata archives.
Each dashboard entry includes regeneration commands so you can reproduce the artefacts locally.
Tuned heuristic presets
Release candidate tuning runs are recorded in notes/release_tuning_results.md; the best operator
weights and configurations per scenario/algorithm are serialized in notes/release_tuned_presets.json.
Use these records when reproducing benchmarks or seeding custom presets, e.g.
python -c "import json; cfg=json.load(open('notes/release_tuned_presets.json')); print(cfg[0])"
# feed operator weights into fhops tune-random --operator-weight swap=... --operator-weight move=...
Quick demos
Show off the tuning harness or heuristics in one command:
python scripts/run_tuning_benchmarks.py \
--bundle synthetic-small \
--out-dir tmp/demo-synth \
--random-runs 1 --random-iters 400 \
--grid-iters 400 --grid-preset explore \
--bayes-trials 2 --bayes-iters 400 \
--max-workers 8 \
&& column -t -s'|' tmp/demo-synth/tuner_report.md | sed 's/^/ /'
or run eight random restarts per heuristic on the baseline bundle:
python scripts/run_tuning_benchmarks.py \
--bundle baseline \
--out-dir tmp/demo-restarts \
--tuner random --tuner ils --tuner tabu \
--random-runs 8 --random-iters 400 \
--ils-runs 8 --ils-iters 400 \
--tabu-runs 8 --tabu-iters 2000 \
--max-workers 8 \
&& column -t -s'|' tmp/demo-restarts/tuner_summary.md | sed 's/^/ /'
Project details
Release history Release notifications | RSS feed
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 fhops-1.0.0a2.tar.gz.
File metadata
- Download URL: fhops-1.0.0a2.tar.gz
- Upload date:
- Size: 3.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b1cd4c6ad69559f4070defb09137ae750dd29090f8072dbc7bb59d2bea7587b1
|
|
| MD5 |
672cd9ffe5e29cde0e03fff4a586a094
|
|
| BLAKE2b-256 |
1dae555ca8d701f248f74c5e4a463407771840fb9c6d71e4ac40867bc50e02b9
|
File details
Details for the file fhops-1.0.0a2-py3-none-any.whl.
File metadata
- Download URL: fhops-1.0.0a2-py3-none-any.whl
- Upload date:
- Size: 318.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
428d19d93a3e06dadc09a135a75a676ad2da29659dc24d255f0a07c1eddaf65b
|
|
| MD5 |
c916aa5d50361db8f367a4009509f9a9
|
|
| BLAKE2b-256 |
79fbbb7487d1319aaf2f1864b52f507cbee32f3c1fa8de451b7a7a0e225c2228
|