Visualization, reporting, statistics, and mapping for the VIEWS conflict forecasting platform.
Project description
VIEWS Reporting: Visualization, Statistics & Mapping
Part of the VIEWS Platform ecosystem for large-scale conflict forecasting.
Table of Contents
- Overview
- Role in the VIEWS Pipeline
- Architecture
- Features
- Installation
- Running Tests
- Project Structure
- Governance
- Contributing
- Acknowledgements
Overview
VIEWS Reporting provides the visualization, statistical analysis, reconciliation, and report generation layer for the VIEWS conflict forecasting pipeline. It produces HTML evaluation reports, interactive choropleth maps, posterior distribution analyses, and hierarchical forecast reconciliation.
All incoming data is expected on its original measurement scale -- this library does not infer or reverse mathematical transformations from column names (ADR-011, Architecture Decision Record).
Key Capabilities:
- Bayesian posterior analysis -- MAP (Maximum A Posteriori) estimation, HDI (Highest Density Interval) computation, and credible interval reporting
- Hierarchical forecast reconciliation -- proportional scaling to ensure country-grid consistency
- HTML report generation -- Tailwind CSS-styled evaluation and forecast reports with XSS-safe content
- Interactive mapping -- choropleth maps at country and PRIO-GRID (Peace Research Institute Oslo grid) resolution via GeoPandas and Mapclassify
Role in the VIEWS Pipeline
VIEWS Reporting sits at the output end of the forecasting pipeline, consuming model predictions and producing human-readable reports, maps, and statistical summaries.
Integration with Other Repositories
- views-pipeline-core: Pipeline infrastructure -- provides orchestration, configuration, and the queryset/partition framework that reporting consumes.
- views-models: Model outputs -- predictions and posterior samples evaluated and visualized by this library.
- views-evaluation: Evaluation metrics -- scoring and calibration results displayed in evaluation reports.
- views-stepshifter: Stepshift model predictions consumed for reconciliation and visualization.
- docs: Organization/pipeline level documentation.
Integration Workflow
- Data Input: Receives evaluated predictions and posterior samples from the pipeline.
- Analysis: Computes MAP estimates, HDI intervals, and reconciles hierarchical forecasts.
- Output: Generates HTML reports, distribution plots, historical line graphs, and choropleth maps.
Architecture
The repository follows a five-layer dependency model (ADR-002):
| Layer | Package | Purpose |
|---|---|---|
| Ingestion | loaders |
Declared-format prediction loaders (parquet / numpy PredictionFrame) → datasets (ADR-012) |
| Compute | statistics |
Bayesian posterior analysis (MAP, HDI), forecast reconciliation |
| Compute | transformations |
Log transform lifecycle (legacy per ADR-011) |
| Compute | reconciliation |
Hierarchical country-grid forecast reconciliation |
| Compute | metadata |
Entity metadata accessors via viewser (30 functions) |
| Render | visualizations |
Distribution plots, historical line graphs |
| Render | mapping |
Interactive/static choropleth maps |
| Compose | reports |
HTML report builder with Tailwind CSS |
| Compose | templates |
EvaluationReportTemplate, ForecastReportTemplate |
| Assets | assets |
Shapefiles (country, priogrid), header images |
Data flows upward: ingestion -> compute -> render -> compose. No downward dependencies (ADR-002).
Features
- Posterior Distribution Analysis: MAP via histogram density peak, HDI via shortest-interval on sorted samples, configurable credible masses and zero-mass thresholds.
- Forecast Reconciliation: Proportional scaling that preserves zeros, clamps non-negative, and ensures country totals match grid sums. Parallel execution via ProcessPoolExecutor.
- HTML Reports: Content accumulation API (headings, paragraphs, tables, images, footers) with
html.escape()on all user-facing text. Tailwind CSS styling. Export to standalone HTML files. - Choropleth Mapping: Country and PRIO-GRID level maps with bundled shapefiles, configurable classification schemes, and interactive Folium output.
- Historical Line Graphs: Plotly-based time series with HDI bands, forecast cutoff markers, and entity dropdown navigation.
- Distribution Plots: HDI and MAP overlays on posterior sample histograms.
Installation
Prerequisites
- Python 3.11 — 3.12+ is not yet supported: an upstream transitive dependency
(
views-pipeline-core → ingester3 → levenshtein) has no 3.12/3.13 build. See ADR-014 and risk register C-36. The package is resolved for Linux and macOS. - uv for development (hatchling + uv per ADR-014).
Steps
For development (recommended):
git clone https://github.com/views-platform/views-reporting
cd views-reporting
uv sync # creates .venv from uv.lock
Or install the published package into an existing environment:
pip install views-reporting
See the organization/pipeline level docs for full environment setup.
Running Tests
uv run pytest tests/ -q # full suite
uv run pytest tests/ -q -m "not slow" # skip slow integration tests
Fixture-dependent tests skip automatically when their data is absent.
Project Structure
views-reporting/
├── README.md # Documentation
├── tests/ # 85–161 tests depending on environment
├── views_reporting/ # Main source code
│ ├── assets/ # Shapefiles and header images
│ ├── mapping/ # Choropleth map generation
│ ├── metadata/ # Entity metadata accessors
│ ├── reconciliation/ # Hierarchical forecast reconciliation
│ ├── reports/ # HTML report builder + Tailwind CSS
│ ├── statistics/ # Posterior analysis (MAP, HDI)
│ ├── templates/ # Report templates (evaluation, forecast)
│ ├── transformations/ # Log transform lifecycle (legacy)
│ ├── visualizations/ # Distribution and historical plots
│ └── __init__.py # Package initialization
├── documentation/
│ ├── ADRs/ # 13 Architecture Decision Records
│ └── CICs/ # 13 Class Intent Contracts
├── reports/ # Technical risk register
├── .github/workflows/ # CI configuration
└── pyproject.toml # Poetry project file
Governance
This repository uses structured governance documented in documentation/:
- 13 ADRs (000-012) -- architectural decisions, from foundational principles to data ingestion contracts
- 13 CICs -- intent contracts covering every non-trivial class plus the full Ingestion-layer loader surface (ADR-006)
- Risk register --
reports/technical_risk_register.md(ADR-010) - Testing doctrine -- red/green/beige team taxonomy (ADR-005)
Start with documentation/ADRs/README.md for the governance map.
| ADR | Title | Impact |
|---|---|---|
| ADR-002 | Topology and dependency rules | Four-layer architecture, no downward deps |
| ADR-003 | Authority of declarations over inference | Fail-loud, no semantic inference |
| ADR-005 | Testing as mandatory critical infrastructure | Red/green/beige test categories |
| ADR-011 | Data arrives on original measurement scale | No transform detection from column names |
Contributing
We welcome contributions! Please follow the contribution guidelines outlined in the VIEWS Documentation. See also documentation/contributor_protocols/ for repo-specific protocols.
All contributions must comply with the constitutional ADRs in documentation/ADRs/, including:
- ADR-003 -- Explicit declarations over inference; fail loud on semantic ambiguity
- ADR-005 -- Testing is mandatory (red / beige / green taxonomy)
- ADR-006 -- Non-trivial classes require intent contracts
- ADR-007 -- Silicon-based agents are untrusted contributors
Acknowledgements
Special thanks to the VIEWS MD&D Team for their collaboration and support.
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 views_reporting-0.1.0.tar.gz.
File metadata
- Download URL: views_reporting-0.1.0.tar.gz
- Upload date:
- Size: 7.4 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
065774671478785a09da8589a766317458607ac7c5696f5d686c0d6e2ce628b1
|
|
| MD5 |
25bd6b3a8893d5459e93769beb707cd9
|
|
| BLAKE2b-256 |
d003d51571ba363c2785e778229c5bc5ab2c2adf2f09dedaf7461248e7c2336e
|
File details
Details for the file views_reporting-0.1.0-py3-none-any.whl.
File metadata
- Download URL: views_reporting-0.1.0-py3-none-any.whl
- Upload date:
- Size: 7.0 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
85925aeed75552944b73389e700328aa26c6e5c4b210d49ded2465b358aae259
|
|
| MD5 |
3a32ec8c2705c3bace23c182bb27e0ce
|
|
| BLAKE2b-256 |
3f555e5f3638ef412532f13155bbef920c46ab312d9629e96ae9cb78d3ebf5a5
|