Skip to main content

Agent-based wildfire evacuation simulator using SUMO and LLM-driven agents

Project description

Agentic Simulator for Wildfire Evacuations

banner

CI Docker PyPI Python 3.11+ Docs License

📖 Full API documentation

An agentic simulator for wildfire evacuations that couples SUMO traffic simulation with LLM-driven agents. Agents follow the Protective Action Decision Model (PADM), maintaining probabilistic beliefs about hazard states and making real-time departure, routing, and destination decisions under uncertainty.

TL;DR

pip install agentevac

Background

Wildfire evacuations in the wildland-urban interface (WUI) are high-risk and time-critical. Existing simulations rely on behaviorally naive models that fail to capture dynamic human cognition — fear, trust in authorities, social influence, and evolving risk perception. This project uses LLM agents to encode psychologically grounded, communicative, and adaptive evacuation behavior, enabling rigorous testing of warning strategies and route policies before crises occur.

Objectives

  • Model how information uncertainty ($\sigma_{info}$), communication delays, and social trust ($\theta_{trust}$) affect evacuation decisions
  • Compare three information regimes: no-notice, alert-guided, and advice-guided evacuation
  • Measure behavioral outcomes (departure timing, route entropy, decision instability) and safety/efficiency trade-offs (hazard exposure vs. travel time)
  • Support calibration against historical wildfire after-action reports

Quickstart

Requirements: Python 3.11+, SUMO, OpenAI API key.

# Install from PyPI
pip install agentevac

# Or install in development mode from source
git clone https://github.com/denoslab/AgentEvac.git
cd AgentEvac
pip install -e .

# Set required environment variables
export SUMO_HOME=/path/to/sumo
export OPENAI_API_KEY=your_key_here

# Run a simulation (interactive, with SUMO GUI)
python -m agentevac.simulation.main --sumo-binary sumo-gui --scenario advice_guided --messaging on

# Run headless with metrics collection
python -m agentevac.simulation.main --sumo-binary sumo --scenario no_notice --metrics on

# Record LLM decisions for deterministic replay
python -m agentevac.simulation.main --run-mode record --scenario alert_guided

# Replay a previous run (no API calls)
python -m agentevac.simulation.main --run-mode replay --run-id 20260209_012156

Scenarios: no_notice | alert_guided | advice_guided

Key flags: --messaging on/off, --events on/off, --web-dashboard on/off, --overlays on/off, --metrics on/off

Docker

# Build the image
docker compose build

# Place scenario files in ./scenario/ (Repaired.sumocfg, *.net.xml, *.rou.xml)
mkdir -p scenario outputs

# Run (OPENAI_API_KEY is read from your shell environment)
docker compose run simulation --scenario advice_guided --metrics on

# Override scenario or flags
docker compose run simulation --scenario no_notice --messaging off --metrics on

Run artifacts are written to ./outputs/ on the host.

Parameter Sweep & Calibration

agentevac-study \
  --reference reference_metrics.json \
  --sigma-values "20,40,60" \
  --delay-values "0,5" \
  --trust-values "0.3,0.5,0.7" \
  --scenario-values "advice_guided" \
  --sumo-binary sumo

This runs a grid search over information noise, delay, and trust parameters and fits results against a reference metrics file.

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

agentevac-0.2.1.tar.gz (99.8 kB view details)

Uploaded Source

Built Distribution

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

agentevac-0.2.1-py3-none-any.whl (91.9 kB view details)

Uploaded Python 3

File details

Details for the file agentevac-0.2.1.tar.gz.

File metadata

  • Download URL: agentevac-0.2.1.tar.gz
  • Upload date:
  • Size: 99.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for agentevac-0.2.1.tar.gz
Algorithm Hash digest
SHA256 5878e4bf85be4d1b1f6389392d03161dccb7af62a033591d07d4c3bb329f05a4
MD5 b29b6acf79670b3f2c55de6f1a1d3dda
BLAKE2b-256 76aee7c1c6b7abe854ef453b7ebd87923ae2ff88ffcf778addc8569f6679d3f5

See more details on using hashes here.

Provenance

The following attestation bundles were made for agentevac-0.2.1.tar.gz:

Publisher: release.yml on denoslab/AgentEvac

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file agentevac-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: agentevac-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 91.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for agentevac-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 029df1c4a0e13f9938bacb8bbc66685779ee012d73fd043ecbbf4df76389d377
MD5 1b8c4e3d476624fbd88b7cd9f8a249c1
BLAKE2b-256 c8492292081f7e095437ceecf826d78c1e94ae86afb4a51d5f18a6ba820d01b1

See more details on using hashes here.

Provenance

The following attestation bundles were made for agentevac-0.2.1-py3-none-any.whl:

Publisher: release.yml on denoslab/AgentEvac

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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