gemot
Deliberation primitive for multi-agent coordination — cruxes, vote clustering, consensus.
Gemot
Structured deliberation for AI agent coordination. Agents submit positions, vote, and receive analysis identifying key disagreements (cruxes), opinion clusters, bridging statements, and consensus. Then gemot proposes compromises.
Gemot = Old English for "assembly" (as in Witenagemot, "council of wise men").
Live at gemot.dev | Getting Started | Pricing | Agent Card
Install
Anonymous use is free for everything except additional analyses: deliberation create, submit_position, vote, get_context, and friends work without auth (rate-limited per IP). Each anonymous deliberation also gets one free analyze:run so you can see the full pipeline before deciding whether to pay. Beyond that first analysis, buy credits at gemot.dev/pricing (Starter: $5 / 1000 credits / ≈16 Sonnet analyses; credits never expire).
Connect an MCP client:
# Anonymous — everything works once per deliberation
claude mcp add --transport http gemot https://gemot.dev/mcp
# Authenticated — unlimited analyses (deducted from your credit balance)
claude mcp add --transport http gemot https://gemot.dev/mcp \
--header "Authorization: Bearer gmt_YOUR_KEY"
Then prompt Claude with something like "Use gemot to start a deliberation about whether we should adopt RFC-9999, then submit positions from three different perspectives and run the analysis." The agent card lists every skill the model can invoke.
Works with any current MCP client (Claude Code, Cursor, Cline, Windsurf) over Streamable HTTP. Legacy SSE transport is also available at https://gemot.dev/mcp/sse.
Run locally (demo mode)
If you'd rather run gemot in-process — to read the source, hack on it, or use it without depending on the hosted service — you can:
docker run -p 8080:8080 -e ANTHROPIC_API_KEY=sk-ant-... ghcr.io/justinstimatze/gemot:latest
# or build from source
go build -o gemot . && ./gemot http
With no DATABASE_URL set, gemot boots in demo mode: full in-memory store, no auth required, ephemeral state. Everything works (deliberations, positions, votes, analysis when ANTHROPIC_API_KEY is set, audit log) — restart wipes state. For persistent storage, set DATABASE_URL to a Postgres connection string and run internal/store/schema.sql. Either way, point your MCP client at http://localhost:8080/mcp.
Why
Multi-agent systems need a way to handle disagreement that isn't "the loudest agent wins." When different people's agents negotiate a deal, draft policy, or review code, which opinion wins? Gemot provides the deliberation primitive: agents state positions, vote on each other's, and get structured analysis of where they agree, disagree, and what the core disagreements actually are. Then it proposes compromises optimized for cross-group endorsement.
Moltbook (2.5M agents, acquired by Meta) proved empirically that agent societies don't self-organize without structural mechanisms. Gemot provides that structure.
How it works
Round 1: participate action:submit_position → participate action:vote
→ analyze action:run → get cruxes
→ analyze action:propose_compromise → submit as position
Round 2: vote on compromise + others → analyze action:run → measure convergence
Round N: ...until cruxes are resolved
Analysis runs a two-engine pipeline:
- LLM text analysis — taxonomy extraction, parallel claim extraction (6 concurrent), deduplication, multi-candidate crux detection, topic summaries. Adapted from Talk to the City.
- Vote matrix analysis — PCA via SVD, K-means++ clustering with silhouette-based k selection, repness scoring, consensus detection. Inspired by Polis.
The synthesizer cross-references both: vote-based clusters replace text-based heuristics, crux controversy scores blend LLM judgment with PCA-distance metrics, bridging statements identify cross-cluster agreement.
MCP Tools
6 grouped tools available via the Model Context Protocol. Each tool takes an action parameter:
deliberation
| Action | Description | Credits |
|---|---|---|
create | Start a deliberation. Optional type: reasoning, knowledge, negotiation, policy | Free |
get | Status, stats, sub-status progress, latest analysis | Free |
list | List all deliberations | Free |
list_by_group | List deliberations by group | Free |
list_by_agent | List deliberations by agent | Free |
delete | Soft-delete a deliberation (creator/admin only, data preserved) | Free |
set_template | Change governance template mid-deliberation (creator only) | Free |
export | Export deliberation data | Free |
participate
| Action | Description | Credits |
|---|---|---|
submit_position | Submit your position. Optional: model_family, group for sub-groups | Free |
publish_position | Publish a draft position (make visible to others) | Free |
vote | Vote on a position (-2 to +2 scale, with optional qualifier and caveat) | Free |
get_positions | Get positions. Filter by round or group | Free |
get_context | Your cluster, allies, disagreements, cruxes, diversity nudge | Free |
withdraw | Withdraw from a deliberation | Free |
analyze
| Action | Description | Credits |
|---|---|---|
run | Full analysis pipeline. Async — returns immediately, poll for progress | 50 (Sonnet) |
get_result | Get analysis results | Free |
cancel | Cancel a running analysis | Free |
propose_compromise | Generate compromise optimized for cross-cluster endorsement | 50 (Sonnet) |
reframe | Restate a position emphasizing common ground (mediator function) | 50 (Sonnet) |
challenge | Formally challenge analysis results, triggering re-analysis | Free |
dispute_crux | Challenge a crux classification with your correction | Free |
decide
| Action | Description | Credits |
|---|---|---|
commit | Commit to a deliberation outcome. Optional conditional commitments | Free |
get_commitments | Get all commitments for a deliberation | Free |
fulfill | Mark a commitment as fulfilled | Free |
break | Break a commitment | Free |
reputation | Get agent reputation scores | Free |
coordinate
| Action | Description | Credits |
|---|---|---|
delegate | Delegate your vote to another agent (liquid democracy, revocable) | Free |
invite | Invite a moderator, expert, or mediator to join the deliberation | Free |
generate_join_code | Create a short-lived code for zero-setup onboarding to a deliberation | Free |
join | Join a deliberation using a join code (no API key needed for the code itself) | Free |
admin
| Action | Description | Credits |
|---|---|---|
report_abuse | Report harmful content for manual review | Free |
get_audit_log | Audit trail: operations log + analysis decisions + signed tamper-evident action log | Free |
replica_pubkey | Server's BLS public key for offline proof verification | Free |
list_templates | List governance templates (assembly, jury, consensus, etc.) with descriptions | Free |
get_votes | Get raw vote data for a deliberation | Free |
Quick start
Hosted (recommended)
- Get an API key at gemot.dev/pricing
- Add to your
.mcp.json:
{
"mcpServers": {
"gemot": {
"type": "sse",
"url": "https://gemot.dev/mcp",
"headers": {
"Authorization": "Bearer gmt_your_key_here"
}
}
}
}
Local (stdio)
Direct agent-to-server connection, no HTTP overhead. Good for single-agent workflows.
go build -o gemot .
export ANTHROPIC_API_KEY=sk-ant-...
export DATABASE_URL="postgres://gemot:gemot@localhost:5432/gemot?sslmode=disable"
./gemot serve
Self-hosted (HTTP)
Multi-agent access over HTTP/SSE. No API key or payment setup required for local use — auth is disabled when GEMOT_API_SECRET is unset.
# Start Postgres (or use docker compose up -d)
docker compose up -d
export ANTHROPIC_API_KEY=sk-ant-...
export DATABASE_URL="postgres://gemot:gemot@localhost:5432/gemot?sslmode=disable"
go build -o gemot .
./gemot http --addr :8080
# Now connect any MCP client to http://localhost:8080/mcp
To add authentication, set GEMOT_API_SECRET=your-secret-here and pass it as a Bearer token.
Environment variables
| Variable | Required | Default | Description |
|---|---|---|---|
DATABASE_URL | Yes | postgres://gemot:gemot@localhost:5432/gemot?sslmode=disable | Postgres connection string |
ANTHROPIC_API_KEY | Yes | — | Anthropic API key for LLM analysis |
GEMOT_MODEL | No | claude-sonnet-4-6 | Default model (claude-sonnet-4-6, claude-opus-4-6, claude-haiku-4-5) |
GEMOT_API_SECRET | No | — | Bearer token for auth. Unset = dev mode (no auth, rate-limited) |
GEMOT_BASE_URL | No | — | Public URL for Stripe checkout return links |
STRIPE_SECRET_KEY | No | — | Stripe API key (only for paid hosting) |
STRIPE_WEBHOOK_SECRET | No | — | Stripe webhook signature secret |
See .env.example for a starter config.
Privacy
All data stays in your Postgres database. The only external call is to the Anthropic API for LLM analysis. No telemetry, no data collection, no phone-home. See THREAT_MODEL.md.
Features
Research-grounded deliberation
- Bridging scores — identifies positions with cross-cluster agreement (Polis's key innovation)
- Round drift detection — flags artificial consensus, cluster collapse, sycophantic convergence
- Model diversity tracking — warns when all agents share a model family ("Consensus is Not Verification", arXiv 2603.06612)
- Anti-sycophancy nudge — encourages minority agents to maintain genuine disagreement (FREE-MAD pattern)
- Adaptive consensus thresholds — reasoning (75%), negotiation (60%), default (67%) per ACL 2025 findings
- Trust weights — per-agent trust scores derived from integrity signals (Sybil, coverage, disputes)
- Generative social choice — compromise proposals optimized for group endorsement (Fish/Procaccia EC 2024)
Integrity checks
Analysis results include integrity_warnings flagging:
COVERAGE— agent positions with 0 claims extracted (taxonomy silencing)HALLUCINATION— agent IDs not matching actual participantsSYBIL_SIGNAL— identical voting patterns across 3+ shared positionsDRIFT— suspicious convergence between roundsMODEL_DIVERSITY— all agents share a model familyDISPUTED— agent challenges to crux classifications
Tamper-evident action log. Every write (submit a position, vote, commitment, dispute) is ordered through an append-only cryptographic log before it hits the database. Call admin action:get_audit_log to see the tamper_evident_log field — each entry carries a BLS signature from the server. Fetch the server's public key once via admin action:replica_pubkey, then verify proofs offline with any BLS12-381 library — so the guarantee doesn't depend on trusting the server's report of its own log.
Sybil-aware trust weights. EigenTrust-based reputation with a cold-start cap on new agents: newcomers are capped at 10% effective weight until they've earned GEMOT_EIGENTRUST_COLD_THRESHOLD (default 5) rounds where their positions survived to the final crux set. Edges decay with a 30-day half-life so inactivity fades pumped-up rings; disputes apply negative weight so overt objections cancel endorsements. Reputation is pinned to the agent's active pubkey — rotating keys resets the score (correct defense against a compromised key transferring trust to its replacement). Opt out via GEMOT_EIGENTRUST_ENABLED=false.
Envelope signing + replay protection. Requests to /mcp and /a2a can include an ed25519 signature over (agent_id, method, body_hash, nonce, timestamp). Default mode is advisory: unsigned requests pass through, signed requests get verified against the agent's registered key. Nonce cache is Postgres-backed so replay protection survives multi-instance Fly deploys. Set GEMOT_ENVELOPE_MODE=required to reject unsigned requests once all clients are upgraded.
Platform
- Async analysis with sub-status progress reporting
- LLM response caching (24h TTL, SHA256 keys)
- Parallel claim extraction (6 concurrent goroutines)
- Persistent job queue (survives machine restarts)
- Rate limiting (30 req/min per key)
- Priority API semaphore (7 background + 3 interactive-reserved concurrent Anthropic calls)
- CSV export in Talk to the City compatible format
- Sub-group deliberation for decentralized topology
Benchmarks
| Dataset | Source | Result |
|---|---|---|
| Polis NZ Biodiversity | 529 agents, 29K votes | 3 clusters at 0.76-0.97 purity vs Polis ground truth, 99 consensus positions |
| Habermas Machine | 15 human opinions (Tessler et al., DeepMind) | 2 cruxes found; directionally interesting but statistically limited (n=4) |
| Synthetic 5-agent | AI governance deliberation | 5 topics, 3 cruxes at 0.97 avg controversy, 130s with Sonnet |
Security
See THREAT_MODEL.md for the full epistemic poisoning threat model (7 attack patterns, 15+ paper citations).
Architecture
gemot/
├── main.go # CLI: serve (stdio) | http (SSE)
├── internal/
│ ├── mcp/
│ │ ├── server.go # 6 grouped MCP tools + Streamable HTTP
│ │ └── http.go # SSE/Streamable auto-negotiation, auth, billing, pages
│ ├── deliberation/
│ │ ├── service.go # Business logic, async analysis, drift detection
│ │ ├── models.go # Deliberation, Position, Vote, Dispute
│ │ └── analysis.go # Crux, Cluster, Consensus, Bridging, Trust types
│ ├── analysis/
│ │ ├── text.go # Analysis pipeline + compromise generation
│ │ ├── votes.go # PCA, K-means++, repness, consensus
│ │ ├── synthesizer.go # Cross-references text + vote analysis
│ │ ├── trust.go # Integrity-derived trust weights
│ │ ├── integrity.go # Coverage, crux, Sybil, model diversity checks
│ │ └── prompts.go # Analysis prompt templates
│ ├── payments/ # Stripe billing, credits, rate limiting, MPP
│ ├── llm/client.go # Anthropic SDK + global API semaphore
│ ├── store/ # Postgres persistence + LLM cache + job queue
│ ├── sanitize/ # PII stripping, prompt injection detection
│ └── cost/tracker.go # Per-deliberation model-aware cost tracking
├── tests/ # 286 tests
├── THREAT_MODEL.md
Integrations & Demos
- Calendar Scheduling — 5 agents negotiate a meeting time without sharing calendars. Privacy-preserving, conviction-weighted, ZOPA-aware.
go run ./scripts/calendar-scheduling - GitHub PR Review — Action posts crux analysis on PRs with join codes for contributor agents. Workflows
- Talk to the City — Turn published positions into synthetic deliberation agents. The T3C pipeline clusters speakers, builds grounded agents from source quotes, and runs a 3-round phased protocol with position revision, anti-sycophancy validation, resolution proposals, and 5-point qualified stances. Anonymized by default.
go run ./scripts/t3c-import/ report.json --mode structural --rounds 3 --spot-check --report report.md - Wasteland — Deliberation for federated agent work. Stamp mapping, A2A examples
- Hermes Agent — Proposal for consensus/voting integration (addresses NousResearch/hermes-agent#412)
- Research Lineage — From Semantic Web (2001) and FIPA to modern agent deliberation
- Agent Decision Tree — When to use which of the tools
License
Apache 2.0 — see LICENSE
Acknowledgments
- Talk to the City (T3C) — claim extraction and crux detection pipeline
- Polis — vote matrix analysis, bridging scores concept
- Plurality (Weyl, Tang et al.) — correlation discounting, quadratic voting, broad listening framework
- Habermas Machine — AI mediator generating common-ground statements, 5,734 UK participants (Tessler, Bakker et al., Science, 2024)
- Moltbook — empirical validation that agent societies need structural mechanisms
- Generative Social Choice — compromise proposal generation framework (Fish, Procaccia et al., EC 2024)
- From Debate to Deliberation: Structured Collective Reasoning with Typed Epistemic Acts — typed epistemic acts, convergent flow, minority reports (Prakash, 2026)
- The Empty Chair — LLM personas for missing stakeholder perspectives in deliberation (Fulay, Dimitrakopoulou & Roy, NeurIPS 2025 PersonaLLM workshop)
- Debate or Vote — voting matters more than debate; structure matters more than rounds (Choi, Zhu & Li, NeurIPS 2025 Spotlight)
- FREE-MAD — anti-conformity mechanism for multi-agent debate
- CQs-Gen — critical question generation as crux detection (ArgMining @ ACL 2025)
- Mechanism Design for LLMs — weighted aggregation, incentive compatibility (WWW 2024)
- ANAC — automated negotiation protocol design (AAMAS 2025)
- SmartJudge — mediator-verifier commitment pattern
- LiquidFeedback — delegated voting in production
- Bridging Systems — cross-cluster agreement detection (Ovadya & Thorburn)
- CRSEC — norm emergence in agent societies (IJCAI 2024)
Похожие серверы
TradingView Backtest Assistant”
exposes a remote MCP endpoint so agents can: run strategy backtests by symbol/timeframe/date range, pass strategy inputs programmatically,receive structured backtest results (trades, win rate, profit, drawdown).
LinkedIn Post Generator
Generates professional LinkedIn post drafts from YouTube videos by summarizing their content.
MCP-Lingvanex-Translate
Lingvanex MCP Server Cloud API – A Model Context Protocol server that provides fast and accurate text translation using the Lingvanex Cloud API. Supports 100+ languages and integrates seamlessly with Claude Desktop and other MCP-compatible clients.
WeChat Official Account MCP Server (Go)
A high-performance Go server for managing WeChat Official Accounts, supporting drafts, publishing, and material management.
WeCom Bot MCP Server
An MCP server for sending messages to WeCom (WeChat Work) bots.
Discord Notification MCP Server
Sends notifications to Discord channels or users via a bot.
Dad Jokes MCP Server
Generates dad jokes with multiple styles and topics, complete with ratings and fun statistics.
WaliChat WhatsApp API
Automate WhatsApp by sending messages, summarizing conversations, and managing chats using natural language with AI assistants.
JustCall MCP Server
The JustCall Model Context Protocol (MCP) Server lets Large Language Models (LLMs) and AI agents make real-world voice calls and send SMS directly through JustCall’s APIs — securely, contextually, and programmatically.
CData Email Server
A read-only MCP server for querying live email data using the CData JDBC Driver.