blocksnet-mcp
Local MCP server for urban analytics that wraps BlocksNet agent, enabling natural language urban questions to be answered with structured JSON results.
README
blocksnet-mcp
blocksnet-mcp - локальный MCP-сервер городской аналитики поверх BlocksNetAgent.
Сервер предоставляет один основной инструмент analyze_urban_question(...): принимает вопрос на
естественном языке, запускает полный рассуждающий агент BlocksNet на локальной модели города и
возвращает строгий машиночитаемый JSON.
Проект следует подходу WIKI-LLM: документация и директории индексируются так, чтобы LLM могла быстро понять назначение репозитория, выбрать нужные файлы и не загружать весь проект в контекст. Главный навигационный индекс: docs/WIKI-LLM.md.
Концепция
Выбран Вариант 2: не выносить 33 внутренних инструмента blocksnet как отдельные MCP-tools, а
обернуть агента целиком.
Причина: ценность системы не только в расчетах, а в рассуждающем слое агента:
- PTR-цикл
predict -> test -> revise: фальсифицируемые гипотезы до расчетов и классификация исхода. - RAG по инструментам: короткие описания плюс полные карточки через
find_tools/get_tool_help. - Инварианты качества M1-M3, C1/C2/C3, C-Hyp: проверка заземленности, измеренности и самосогласованности.
- Измеренные предложения развития: TPE-оптимизация зон и сценарная проверка
before -> after.
MCP-слой остается тонким: читает настройки, вызывает BlocksNetAgent.run(...), сериализует результат.
Текущий объем
Текущий MVP рассчитан на локальную работу:
| Область | Решение |
|---|---|
| Транспорт | stdio, сервер запускается MCP-клиентом как подпроцесс |
| Данные | локальная папка data/ через DATA_DIR |
| LLM | внешний OpenAI-совместимый API (CHAT_URL, API_KEY, MODEL) |
| Инструмент | analyze_urban_question(question, max_iterations?) |
| Выход | JSON с планом, результатом, гипотезами, измеренными эффектами, ограничениями и артефактами |
Вне текущего объема: UrbanDB-контекст (scenario_id / project_id), HTTP-транспорт, Bearer-авторизация,
Docker-деплой и регистрация в MAS. В этом репозитории реализован только локальный stdio MCP.
Архитектура MVP
Локальный MCP-клиент
-> stdio
-> blocksnet_mcp.server
-> tools_mcp.analyze_urban_question
-> BlocksNetAgent.run(question)
-> serialize.to_json(result)
-> JSON-ответ MCP-клиенту
Структура репозитория:
blocksnet-mcp/
├── README.md
├── .env.example
├── .gitignore
├── requirements.txt
├── .python310/ # локальный Python 3.10.11, gitignored
├── .venv/ # локальное окружение Python 3.10.11, gitignored
├── docs/
│ ├── README.md
│ ├── WIKI-LLM.md
│ ├── overview_and_concept.md
│ ├── architecture.md
│ ├── tool_contract.md
│ ├── deployment.md
│ ├── mcp_repository_plan.md
│ ├── mas_integration_reference.md # 🕘 Future-справка, gitignored
│ └── mas_registration.md # 🕘 Future-справка, gitignored
├── blocksnet_mcp/
│ ├── README.md
│ ├── server.py
│ ├── tools_mcp.py
│ ├── serialize.py
│ ├── settings.py
│ └── __init__.py
├── blocksnet_agent/
│ ├── README.md
│ └── ... ядро агента из blocksnet-agent
├── data/
│ ├── README.md
│ ├── service_type.json
│ ├── archetypes.csv
│ ├── blocks_with_services.gpkg
│ └── acc_mx.pickle
├── tests/
│ ├── README.md
│ ├── test_serialize.py
│ └── test_tool_contract.py
├── scripts/
│ ├── README.md
│ └── smoke_client.py
├── examples/
│ ├── README.md
│ └── test_visualization.ipynb
└── outputs/ # runtime-артефакты, gitignored
Контракт инструмента
analyze_urban_question(question: str, max_iterations: int = 10) возвращает JSON:
{
"question": "...",
"analysis_plan": "...",
"result": "...",
"hypotheses": [
{
"id": "1",
"claim": "...",
"prediction": "...",
"test": "...",
"status": "supported|refuted|inconclusive",
"evidence": "..."
}
],
"measured": {
"pitch": {
"strong_before": 0.732,
"strong_after": 0.781,
"missing_before": 785,
"missing_after": 769
}
},
"recommendation_blocks": [2, 4, 5, 11, 12],
"confidence": 0.78,
"limitations": ["..."],
"artifacts": ["maps/provision.png", "scenario.csv"],
"run_id": "run_20260617_004403"
}
Полная спецификация: docs/tool_contract.md.
Локальный запуск
Рабочее локальное окружение уже создано в репозитории:
| Путь | Назначение | Git |
|---|---|---|
.python310/ |
portable Python 3.10.11 для проекта |
ignored |
.venv/ |
виртуальное окружение на Python 3.10.11 |
ignored |
requirements.txt |
зависимости локального MCP и BlocksNetAgent | yes |
.\.venv\Scripts\python.exe -m pytest tests
.\.venv\Scripts\python.exe scripts\smoke_client.py
.\.venv\Scripts\python.exe -m blocksnet_mcp.server
Минимальный .env:
CHAT_URL=https://openrouter.ai/api/v1
API_KEY=sk-...
MODEL=openai/gpt-4o
DATA_DIR=./data
Пример конфигурации MCP-клиента:
{
"mcpServers": {
"blocksnet": {
"command": "P:/AI_asistent/ITMO/blocksnet-mcp/.venv/Scripts/python.exe",
"args": ["-m", "blocksnet_mcp.server"],
"cwd": "P:/AI_asistent/ITMO/blocksnet-mcp",
"env": {
"CHAT_URL": "https://openrouter.ai/api/v1",
"API_KEY": "sk-...",
"MODEL": "openai/gpt-4o",
"DATA_DIR": "./data"
}
}
}
}
Подробнее: docs/deployment.md.
Индексация WIKI-LLM
| Индекс | Назначение |
|---|---|
| docs/WIKI-LLM.md | Главная карта проекта для LLM-навигации |
| docs/README.md | Человекочитаемый индекс документации |
| blocksnet_mcp/README.md | Индекс реализованного MCP-слоя |
| blocksnet_agent/README.md | Индекс переносимого ядра агента |
| data/README.md | Индекс локальных данных |
| tests/README.md | Индекс контрактных тестов |
| scripts/README.md | Индекс локальных smoke-проверок MCP |
| examples/README.md | Индекс интерактивных блокнотов |
Документация
| Документ | О чем |
|---|---|
| docs/overview_and_concept.md | что строится, зачем MCP-обертка целиком, границы локального режима |
| docs/architecture.md | структура, модули, поток запроса, транспорт |
| docs/tool_contract.md | вход и выход analyze_urban_question |
| docs/deployment.md | локальная установка и подключение MCP-клиента |
| docs/mcp_repository_plan.md | план переноса ядра агента и реализации MVP |
| examples/test_visualization.ipynb | интерактивная визуализация тестов, run logs, артефактов и карт |
docs/mas_integration_reference.md 🕘 |
future-справка по MAS/UrbanDB, локальная и gitignored |
docs/mas_registration.md 🕘 |
future-строки реестра Urban services, локальная и gitignored |
Статус
Локальный MVP реализован: ядро BlocksNetAgent перенесено, stdio MCP-сервер добавлен, JSON-сериализация
и контрактные тесты находятся в tests/. Окружение собрано на Python 3.10.11; pip check чистый,
pytest проходит (7 passed), MCP stdio smoke проходит через scripts/smoke_client.py. Источник истины
по текущему объему - этот README, docs/WIKI-LLM.md, код blocksnet_mcp/, контракт
docs/tool_contract.md и тест-план docs/plans/test_plan.md.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.