NOUZ MCP Server
The NOUZ MCP Server is a semantic knowledge engine for Obsidian that enables AI agents to intelligently structure, analyze, and navigate knowledge bases through vector embeddings and graph relationships. All core operations run locally, ensuring privacy.
File Operations
Read/write Obsidian notes with YAML frontmatter and metadata via
read_file/write_fileBrowse and filter the vault by domain sign, hierarchy level, subfolder, or missing metadata via
list_filesReindex the entire vault into SQLite (optionally with embeddings) via
index_all
Graph Navigation
Traverse parent-child relationships with
get_children/get_parentsGet a compact one-line structural formula
(children)[entity]{parents}showing a note's position viaformat_entity_compact
Semantic Analysis & Metadata
Suggest domain sign, hierarchy level, semantic bridges, and drift warnings for a note via
suggest_metadataFind semantically appropriate parent notes for orphaned notes via
suggest_parentsDetect
core_driftwhen a note's declared intent (sign) diverges from its actual content (core_mix)
Embeddings & Domain Calibration
Generate vector embeddings for arbitrary text via
embedCalibrate core domain vectors from reference texts (etalons) via
calibrate_coresRecalculate automatic domain signs for all notes via
recalc_signs(supports dry-run)Perform bottom-up semantic aggregation (L4→L3→L2) to compute
core_mixviarecalc_core_mix
Hierarchical Modeling
Supports 5 entity levels: Core (L1), Pattern (L2), Module (L3), Quant (L4), Artifact (L5)
Three operating modes: LUCA (graph only), PRIZMA (graph + semantics), SLOI (strict 5-level hierarchy)
Relationship Discovery
Identifies three bridge types between notes: semantic (similar content), tag (shared concepts), and analogical (similar structural roles across domains)
Configuration
Configurable classification and bridge detection thresholds, embedding provider (LM Studio, Ollama, or cloud APIs), and core domain definitions.
Manages notes in an Obsidian vault, providing tools to read, write, and navigate markdown files with YAML frontmatter, including bidirectional link tracking (parents/children), semantic indexing, and hierarchical organization across five knowledge levels.
Integrates with Ollama for local embedding generation, enabling semantic search, similarity matching, and automated metadata suggestions using locally-hosted language models.
Integrates with OpenAI's API for cloud-based embedding generation, supporting semantic analysis, core sign calibration, and vector similarity operations for knowledge graph navigation.
NOUZ — Семантический MCP-сервер для вашей базы знаний
Структура появляется из содержания.
Работает с Obsidian, Logseq и любыми директориями Markdown-файлов.
Зачем нужен Nouz
NOUZ выступает прослойкой между вашей базой заметок и AI-агентом. Он помогает превратить разрозненные Markdown-файлы в граф, с которым можно работать через MCP:
Автоматическая классификация (Семантика) Вы задаете "Ядра" — базовые домены вашей базы (например: Systems Analysis, Data & Science, Engineering). Когда вы добавляете новую заметку, NOUZ читает ее текст, сравнивает векторы и предлагает доменный знак или комбинацию доменов.
Поиск связей между заметками Сервер строит направленный граф (DAG) и предлагает связи, которые можно проверить перед записью:
Семантические мосты: две заметки из разных доменов указывают на одну и ту же идею.
Явные
tag-связи можно хранить вручную вparents_meta;suggest_metadataтакже предлагает read-onlytag_bridgesпо пересечению явных канонических YAML-тегов.
Отслеживание эволюции базы (Дрифт) NOUZ агрегирует данные снизу вверх. Если модуль начинался как один домен, а новые заметки постепенно уводят его в другой, сервер покажет расхождение (
core_drift).
В зависимости от ваших задач NOUZ работает в трех режимах: от простого графа (LUCA) до строгой 5-уровневой иерархии (SLOI).
Related MCP server: Semantic Mesh Memory (SEM) MCP Server
Как это работает
Вы описываете домены в
config.yaml— какую область покрывает каждый домен и по каким признакам текста его узнавать.Сервер превращает описания в векторы-эталоны (локально, через LM Studio или Ollama).
Каждая новая заметка проецируется на эти оси. Знак определяется содержанием, или вами.
L4 получает доменный профиль из классификации текста, а L3/L2 собирают
core_mixиз дочерних узлов. Еслиsignмодуля расходится сcore_mix, сервер сообщает оcore_drift.
Семантические мосты находят связи между заметками из разных доменов, когда тексты близки по смыслу. Если для обеих заметок уже есть chunk_embeddings, мост дополнительно проверяется лучшей парой чанков и возвращает конкретное evidence. Теги остаются явной пользовательской разметкой.
Быстрый старт
pip install nouz-mcp
OBSIDIAN_ROOT=/path/to/vault nouz-mcpБез config.yaml сервер стартует в режиме LUCA — граф без семантики, работает сразу.
Чтобы включить семантический режим, создайте локальный конфиг из шаблона:
cp config.template.yaml config.yamlВ Windows PowerShell:
Copy-Item config.template.yaml config.yamlИли из исходников:
git clone https://github.com/Semiotronika/NOUZ-MCP
cd NOUZ-MCP
pip install -r requirements.txt
cp config.template.yaml config.yaml
OBSIDIAN_ROOT=./vault python server.pyПодключение к Claude Desktop, Cursor, Opencode или любому MCP-клиенту:
{
"mcpServers": {
"nouz": {
"command": "nouz-mcp",
"env": {
"OBSIDIAN_ROOT": "/path/to/vault",
"NOUZ_CONFIG": "/absolute/path/to/config.yaml",
"EMBED_API_URL": "http://127.0.0.1:1234/v1"
}
}
}
}Инструменты MCP
Инструмент | Зачем |
| Знак, уровень, мосты, drift-предупреждения |
| Записать заметку с YAML-разметкой |
| Обновить только YAML, не меняя текст заметки |
| Прочитать заметку + метаданные |
| Обновить векторы-эталоны ядер |
| Пересчитать знаки всех заметок |
| Пересчитать агрегацию снизу вверх |
| Переиндексировать всю базу; с |
| Получить вектор для текста |
| Разрезать Markdown-текст на стабильные retrieval-чанки |
| Разрезать тело одной заметки на стабильные retrieval-чанки |
| Искать по сохранённым chunk embeddings; по умолчанию снижает cosine-bias через mean-centered scoring |
| Список с фильтрами по уровню, знаку |
| Пройти вниз по графу |
| Пройти вверх по графу |
| Найти родителей для сироты |
| Создать сущность в один шаг (авто sign/parents, теги только явно) |
| Автозаполнение файлов без разметки |
Установите NOUZ_READ_ONLY=true, чтобы скрыть и заблокировать инструменты,
которые меняют базу (write_file, update_metadata, index_all, пересчёты,
обработку сирот и создание сущностей). Read-only инструменты вроде read_file,
suggest_metadata, embed, chunk_text, chunk_file и search_chunks останутся
доступны. В режиме NOUZ_READ_ONLY=true read-only инструменты по умолчанию не
обновляют SQLite-кэш, а startup пропускает DB init/index/calibration; если это
нужно, включите NOUZ_CACHE_WRITE=true.
chunk_text и chunk_file возвращают chunker_version, стабильный id,
координаты фактического текста чанка (start_char/end_char), координаты тела
без overlap (body_start_char/body_end_char) и hash-поля. index_all с
with_embeddings=true сохраняет эти чанки в SQLite-таблицу chunk_embeddings,
а search_chunks ранжирует их по semantic score к запросу. В режиме
score_mode=auto большие неприцельные наборы кандидатов ранжируются по mean-centered cosine,
чтобы снизить анизотропный общий фон embedding-пространства. Для диагностики
каждый match возвращает активный score, а также score_raw и
score_centered; поиск внутри path по умолчанию сохраняет raw-ранжирование,
а score_mode=raw сохраняет legacy cosine-поведение.
semantic_bridges остаются связями между заметками, но при наличии сохранённых
чанков для обеих сторон NOUZ требует подтверждающую пару фрагментов. Такой bridge
возвращает note_score, chunk_score, chunk_score_raw,
chunk_score_centered, chunk_score_mode и evidence со span/snippet для
обеих заметок. Если чанки ещё не проиндексированы, мост сохраняет старый
note-level fallback с evidence_status: chunk_embeddings_unavailable.
parents_meta.link_type поддерживает ручные связи hierarchy, semantic,
temporary, tag, analogy и error. NOUZ не генерирует аналогии
автоматически. tag_bridges в suggest_metadata являются предложениями по
явным YAML-тегам и сами не записываются в файл.
YAML-теги считаются явной метаданной: NOUZ нормализует их к каноническому
slug-виду (agent-context, опционально area/topic) и отбрасывает очевидные
не-теги: hex-цвета, URL, числовые токены, пустые значения и none/null.
suggest_metadata возвращает tag_quality, чтобы агент видел, какие теги
приняты для будущих tag_bridges, а какие значения были отброшены.
Для автоматизации тегов suggest_metadata также возвращает read-only
tag_candidates: кандидаты из уже принятого YAML-словаря тегов в индексе и
явных inline #tag в тексте. Кандидаты не записываются в YAML автоматически;
если их принять через update_metadata, обычные tag_bridges начнут работать
по этим тегам. До записи возможные связи возвращаются отдельно как
candidate_tag_bridges. Для каждого кандидата NOUZ временно режет текущий
текст на чанки и возвращает evidence с chunk_id, заголовком, координатами и
коротким фрагментом. Это не требует заранее заполненной таблицы
chunk_embeddings.
Конфигурация
Минимальный config.yaml:
mode: prizma
etalons:
- sign: S
name: Systems Analysis
text: >
Methodology for analysing complex objects: feedback loops,
emergent properties, self-regulation, bifurcation points.
Cybernetics, synergetics, dissipative structures, catastrophe
theory, autopoiesis — tools for understanding how the whole
exceeds the sum of its parts. Not data and not code — a way
of thinking about how parts form a whole and why systems
behave non-linearly.
- sign: D
name: Data & Science
text: >
Physics and cosmology: from subatomic particles to the large-scale
structure of the Universe. Lagrangians, curvature tensors, scattering
cross-sections, quarks, bosons, fermions, plasma, vacuum fluctuations,
cosmic microwave background, cosmological constant, decoherence.
Pure science about the nature of matter, energy and spacetime.
- sign: E
name: Engineering
text: >
Software engineering, machine learning and infrastructure: writing
and debugging code, deployment, containerisation, neural networks,
inference, tokenisation, data serialisation, microservices, CI/CD,
automated testing, refactoring, Git, Docker, Kubernetes, APIs.
The practical discipline of building computational systems from
architecture to production.
thresholds:
sign_spread: 0.05
confident_spread: 60.0
pattern_second_sign_threshold: 30.0
semantic_bridge_threshold: 0.55
parent_link_threshold: 0.55
artifact_signs:
- sign: n
name: Note
text: Short note, observation, fragment.
- sign: c
name: Concept
text: Definition, concept, entity description.
- sign: r
name: Reference
text: External source, documentation, link, citation.
- sign: l
name: Log
text: Session log, chronology, dialogue record.
- sign: u
name: Update
text: Update, release note, changelog entry.
- sign: h
name: Hypothesis
text: Hypothesis, assumption, speculative idea.
- sign: s
name: Specification
text: Technical specification, instruction, requirements.После настройки запустите calibrate_cores — сервер создаст эталонные векторы.
Проверьте попарные косинусы: mean-centered между разными доменами должен быть
заметно ниже сырого. Если все пары примерно одинаковые — усильте различия в текстах.
Отдельную проверку эталонов можно запустить из установленного пакета:
nouz-calc-etalons --config config.yaml.
etalons — это смысловые домены, которые сравниваются через эмбеддинги.
artifact_signs — тип материала для артефактов L5: заметка, концепт, ссылка, лог, обновление, гипотеза или спецификация. Это эвристическая метка, а не отдельный эталон для эмбеддингов. В публичной схеме домены обычно обозначаются заглавными буквами (S/D/E), а типы материала — строчными (n/c/r/l/u/h/s); их можно заменить в конфиге, если знаки короткие и не конфликтуют с доменами. При необходимости для любого типа можно добавить keywords: тогда сервер будет использовать ваши слова для эвристики вместо встроенного RU/EN набора.
Реальный пример расчёта
Вот фактические результаты для эталонов S/D/E с моделью text-embedding-granite-embedding-278m-multilingual:
=== Pairwise Cosine (raw) ===
S↔D: 0.5894 S↔E: 0.5862 D↔E: 0.6022
=== Pairwise Cosine (mean-centered) ===
S↔D: -0.5059 S↔E: -0.5117 D↔E: -0.4822Отрицательные mean-centered значения здесь хороший результат: после вычитания среднего вектора домены хорошо расходятся. Самоклассификация: S→99.4%, D→97.5%, E→96.9%.
Переменная | По умолчанию | Описание |
|
| Путь к хранилищу |
| (пусто) | Абсолютный путь к |
|
| Имя файла SQLite-кэша внутри |
| (пусто) | Полный путь к SQLite-кэшу; имеет приоритет над |
|
|
|
|
| Эндпоинт для эмбеддингов |
| (пусто) | API-ключ, если нужен |
| (пусто) | Имя модели |
Приватность
Компонент | Локально? |
Эмбеддинги (LM Studio / Ollama) | ✅ Да |
Ваши заметки | ✅ Да |
Сервер NOUZ | ✅ Да |
Контекст AI-агента (Claude, ChatGPT) | ❌ Уходит в облако |
Всё критичное остаётся на вашей машине.
Разработка
git clone https://github.com/Semiotronika/NOUZ-MCP
cd NOUZ-MCP
pip install -e .
python -m compileall -q nouz_mcp pytest_smoke.py scripts
python -m pytest -q
python test_server.pyСсылки
MIT License © 2026 Semiotronika
Косинусы считаются. Синтаксис меняется. Семантика остаётся.
Maintenance
Appeared in Searches
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Semiotronika/NOUZ-MCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server