You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
5 days ago | |
|---|---|---|
| .compound-engineering | 2 months ago | |
| .github/workflows | 2 months ago | |
| .opencode/skills/score-extremity | 2 weeks ago | |
| .streamlit | 2 months ago | |
| agent_tools | 2 months ago | |
| analysis | 5 days ago | |
| ansible | 2 months ago | |
| data | 3 months ago | |
| docs | 2 weeks ago | |
| health | 2 months ago | |
| migrations | 3 months ago | |
| pages | 2 months ago | |
| pipeline | 2 months ago | |
| reports | 5 days ago | |
| scripts | 2 months ago | |
| similarity | 3 months ago | |
| src/validators | 2 months ago | |
| tests | 3 weeks ago | |
| thoughts | 2 months ago | |
| tools | 3 months ago | |
| .gitignore | 4 weeks ago | |
| .pre-commit-config.yaml | 2 months ago | |
| .python-version | 3 months ago | |
| AGENTS.md | 3 weeks ago | |
| ARCHITECTURE.md | 3 months ago | |
| CODE_STYLE.md | 3 months ago | |
| Home.py | 2 months ago | |
| README.md | 2 weeks ago | |
| STRATEGY.md | 2 months ago | |
| ai_provider.py | 2 weeks ago | |
| api_client.py | 2 months ago | |
| app.py | 2 months ago | |
| config.py | 2 months ago | |
| database.py | 2 months ago | |
| explorer.py | 2 weeks ago | |
| explorer_helpers.py | 3 months ago | |
| logging_config.py | 2 months ago | |
| pyproject.toml | 2 months ago | |
| requirements-dev.txt | 3 months ago | |
| scheduler.py | 2 months ago | |
| streamlit_index.html | 3 months ago | |
| summarizer.py | 3 months ago | |
| uv.lock | 2 months ago | |
README.md
Stemwijzer
A Dutch parliamentary voting compass that lets you vote on real Tweede Kamer motions and see which parties match your positions.
What is Stemwijzer?
Stemwijzer ingests motions and voting records from the Dutch House of Representatives (Tweede Kamer), stores them in DuckDB, generates AI-powered explanations with an LLM, and presents a Streamlit UI where users can vote on real motions and explore party positions through SVD visualizations, trajectory analysis, and embedding-based similarity search.
Features
- Voting Compass — Vote on real parliamentary motions and see which parties align with your choices
- Explorer — Interactive SVD visualizations, party trajectories over time, motion browser, and semantic search
- Analytics — SVD decomposition of voting patterns, UMAP projections, clustering, and drift analysis
- LLM Enrichment — Automatic generation of layman-friendly motion explanations using QWEN via OpenRouter
- Overton Window Analysis — Quantitative analysis of whether the Dutch parliamentary center has shifted rightward, using centrist voting support, SVD spatial drift, 2D extremity scoring, and mechanism classification
Prerequisites
- Python >= 3.13
- uv for dependency management
- (Optional)
OPENROUTER_API_KEYfor LLM enrichment
Quickstart
# Clone and enter the repository
git clone <your-gitea-url>/sgeboers/stemwijzer.git
cd stemwijzer
# Install dependencies
uv sync
# Run the Streamlit app
uv run streamlit run Home.py
# Run the data pipeline (fetch motions, compute embeddings, etc.)
uv run python pipeline/run_pipeline.py
# Run tests
uv run pytest tests/ -q
The app will be available at http://localhost:8501.
Project Structure
├── app.py # Streamlit UI entrypoint
├── database.py # DuckDB schema and queries
├── api_client.py # Tweede Kamer OData API client
├── explorer.py # Explorer page with SVD visualizations
├── pipeline/ # Data ingestion and analysis pipelines
├── analysis/ # SVD, clustering, trajectory, right-wing motion analysis
├── tests/ # pytest test suite
├── docs/ # Documentation, research, and plans
└── data/motions.db # DuckDB database (~18 GB)
Documentation
- ARCHITECTURE.md — Comprehensive architecture overview, tech stack, and contributor guidance
- CODE_STYLE.md — Coding conventions, naming, typing, and testing standards
- docs/solutions/ — Documented solutions to past bugs and best practices
Research
- Overton Window Article — Interactive article: "Has the Dutch Overton window shifted?" with Plotly charts (render with
quarto render) - Overton Synthesis — Detailed synthesis of all indicators and the "acceptance through moderation" verdict
- Overton Reports — 13 appendix reports covering breakpoint analysis, SVD drift, 2D extremity, mechanisms, and more (reading guide)
- Overton Dashboard — Standalone HTML report with gravity-controlled charts and example motions
Tech Stack
- Language: Python 3.13+
- Data: DuckDB via ibis-framework
- UI: Streamlit + Plotly
- ML/Analysis: scipy, scikit-learn, umap-learn
- LLM: QWEN via OpenRouter (OpenAI-compatible)
- Package Manager: uv
License
[Your license here]
