Markdown3D MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Markdown3D MCP Serverconvert this markdown to 3D: # My Research Notes"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Markdown3D MCP Server
Transform markdown documents into immersive 3D visualizations using the NM3 format
Markdown3D MCP is a Model Context Protocol (MCP) server that intelligently converts markdown documents into three-dimensional spatial representations. Using semantic analysis, cross-reference detection, and optimized spatial layout algorithms, it creates navigable 3D knowledge structures that preserve document hierarchy and relationships.
โจ Features
๐ฏ Semantic Analysis - Intelligent content classification using NLP to determine node types and relationships
๐จ Smart Color Mapping - Context-aware color assignment based on content semantics and tone
๐ Geometric Intelligence - Automatic shape selection based on content structure (spheres, cubes, cylinders, pyramids, tori)
๐ Cross-Reference Detection - Parses
[[node-id]]patterns and builds relationship graphs๐ Spatial Optimization - Force-directed layout algorithms for readable 3D arrangements
โก Multi-Layer Caching - LRU caches with intelligent eviction for sub-second repeat requests
๐ Streaming Processing - Handle documents of any size with constant memory usage
๐ Parallel Processing - Worker thread pool for multi-core spatial optimization
๐ Performance Monitoring - Prometheus metrics and detailed performance statistics
๐พ Memory Management - Automatic monitoring and garbage collection
โ Strict Validation - Ensures compliance with NM3 specification (16 colors, 5 shapes)
โก MCP Integration - Seamless integration with Claude Desktop and other MCP clients
๐งช Comprehensive Testing - Full test suite with validation and error handling
Related MCP server: Obsidian Elite RAG MCP Server
๐ Table of Contents
๐ Installation
Prerequisites
Node.js 20.x or higher
npm or yarn
Claude Desktop (for MCP integration)
Install from npm
npm install -g markdown3d-mcpInstall from source
# Clone the repository
git clone https://github.com/yourusername/markdown3d-mcp.git
cd markdown3d-mcp
# Install dependencies
npm install
# Build the project
npm run buildConfigure Claude Desktop
Add the server to your Claude Desktop configuration:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
Linux: ~/.config/Claude/claude_desktop_config.json
{
"mcpServers": {
"markdown3d": {
"command": "node",
"args": ["/absolute/path/to/markdown3d-mcp/dist/index.js"]
}
}
}Verify Installation
# Run standalone test
npm run test
# Start development server
npm run devโก Quick Start
Using with Claude Desktop
Restart Claude Desktop after configuration
Check the ๐ MCP icon to verify "markdown3d" is connected
Use the transformation tool:
Please use the transform_to_nm3 tool to convert this markdown:
# My Research
## Key Findings
- Discovery 1
- Discovery 2Command Line Usage
# Transform a markdown file
node dist/index.js < input.md > output.nm3
# Run test client
npm run test๐ Usage
MCP Tools
transform_to_nm3
Transforms markdown content into NM3 3D visualization format with performance optimizations.
Parameters:
markdown(required): Markdown content to transformtitle(optional): Document title overrideauthor(optional): Author name overrideoptions(optional): Performance options objectuseCache(boolean, default: true): Enable multi-layer cachinguseStreaming(boolean, default: true): Enable streaming for large documentschunkSize(number, default: 1000): Lines per chunk for streaming
Example:
{
"markdown": "# Introduction\n\nThis is a test document.",
"title": "Test Document",
"author": "John Doe",
"options": {
"useCache": true,
"useStreaming": true
}
}Returns: Valid NM3 XML string
Performance Notes:
First request may take longer as caches warm up
Identical markdown served from cache in <10ms
Documents >50KB automatically use streaming
Cache hit rate typically >80% after warmup
validate_nm3
Validates NM3 XML for compliance with the specification.
Parameters:
xml(required): NM3 XML to validate
Returns: Validation result with success status and error details
get_performance_stats
Retrieves detailed performance and cache statistics from the server.
Parameters: None
Returns: Performance report including:
Cache statistics (hits, misses, hit rates) for all cache layers
Memory usage (heap, RSS, percentage)
Prometheus metrics (transform duration, counts, etc.)
Example Response:
# Performance Statistics
## Cache Stats
### parse
- Hits: 150
- Misses: 50
- Hit Rate: 75.00%
- Keys: 45
### transform
- Hits: 140
- Misses: 60
- Hit Rate: 70.00%
- Keys: 35
### xml
- Hits: 145
- Misses: 55
- Hit Rate: 72.50%
- Keys: 40
## Memory Stats
- Heap Used: 245.67MB
- Heap Total: 512.00MB
- Percent Used: 47.98%
- RSS: 385.23MB
## Prometheus Metrics
...clear_cache
Clears all caches to free memory or reset performance state.
Parameters: None
Returns: Confirmation message
Use Cases:
Free memory when approaching limits
Reset cache state for testing
Clear stale cached data
Force fresh transformations
Note: After clearing cache, first requests will take longer as caches rebuild.
API Usage
import { MarkdownParser } from './core/parser.js';
import { SimpleTransformer } from './core/transformer.js';
import { NM3XMLBuilder } from './core/xml-builder.js';
// Parse markdown
const parser = new MarkdownParser();
const sections = parser.parse(markdownContent);
// Transform to NM3
const transformer = new SimpleTransformer();
const nm3Doc = transformer.transform(sections);
// Build XML
const xmlBuilder = new NM3XMLBuilder();
const xml = xmlBuilder.buildXML(nm3Doc);๐ง How It Works
Transformation Pipeline
Markdown โ Parser โ Semantic Analysis โ Transformer โ XML Builder โ NM3Parsing: Markdown is tokenized and structured into hierarchical sections
Analysis: Content is analyzed for semantic meaning, patterns, and relationships
Transformation: Sections are converted to 3D nodes with appropriate shapes, colors, and positions
XML Generation: Valid NM3 XML is built with proper CDATA wrapping and validation
Color Mapping Rules
Color | Semantic Meaning | Triggers |
| Urgent/Critical | error, warning, critical, urgent |
| Information | main sections, documentation |
| Solutions/Success | solution, complete, done, success |
| Questions/Ideas | questions, how, why, what |
| References/Sources | citation, reference, source, link |
| Warnings/Attention | attention, caution, note |
| Fresh Ideas | new, innovation, idea, proposal |
| Technical/Code | code blocks, technical content |
| Personal Notes | subjective, opinion, note |
| Archive/Deep Content | nested content, completed items |
Shape Assignment Logic
Shape | Usage | Best For |
๐ต Sphere | Atomic concepts | Single ideas, definitions, standalone concepts |
๐ฆ Cube | Structured data | Categories, tables, structured information |
๐ Cylinder | Processes | Timelines, steps, sequential processes |
๐บ Pyramid | Hierarchies | Priority lists, organizational structures |
๐ฉ Torus | Cycles | Loops, feedback systems, continuous processes |
Spatial Layout Strategy
Z-axis: Importance/temporal ordering (important content forward)
Y-axis: Abstraction levels (high-level concepts higher)
X-axis: Categorical grouping (related content clustered)
Hierarchy: Parent-child relationships via containment links
Spacing: Dynamic based on node importance and relationships
โก Performance
Key Performance Metrics
Markdown3D MCP is optimized for production workloads with Phase 4 performance enhancements:
Metric | Target | Description |
Cached Requests | <10ms | Repeat transformations served from cache |
Small Documents | <500ms | Documents with <100 nodes, first request |
Medium Documents | <2s | Documents with 100-1000 nodes |
Large Documents | <5s | Documents with 1000-5000 nodes (with streaming) |
Memory Footprint | <500MB | Under normal production load |
Cache Hit Rate | >80% | After initial warmup period |
Performance Features
Multi-Layer Caching System
Parse Cache: 100MB LRU cache with 30-minute TTL for parsed markdown
Transform Cache: 50MB LRU cache with 15-minute TTL for NM3 documents
XML Cache: NodeCache with 100 keys and 10-minute TTL
SHA-256 Hashing: Deterministic cache keys for reliable hit detection
Streaming Processing
Automatic activation for documents >50KB
Constant memory usage regardless of document size
Line-by-line parsing with chunked processing
Handles multi-GB documents efficiently
Parallel Processing
Worker thread pool for CPU-intensive operations
Multi-core spatial optimization
Configurable worker count (default: CPU cores - 1)
Automatic load balancing
Performance Monitoring
Prometheus metrics integration
Real-time cache hit/miss statistics
Memory usage tracking
Transform duration histograms
Node count distributions
Memory Management
Automatic monitoring every 30 seconds
Warning threshold: 400MB heap usage
Critical threshold: 800MB heap usage
Automatic garbage collection on critical status
Detailed memory statistics
Optimization Guidelines
For best performance:
Enable Caching: Cache is enabled by default; ensure it's not disabled
Reuse Content: Identical markdown will be served from cache in <10ms
Large Documents: Documents >50KB automatically use streaming
Memory Limits: Monitor memory usage with
get_performance_statstoolClear Cache: Use
clear_cachetool if memory becomes constrained
๐จโ๐ป For Developers
Project Structure
markdown3d-mcp/
โโโ src/
โ โโโ index.ts # Entry point
โ โโโ server.ts # MCP server implementation
โ โโโ core/
โ โ โโโ parser.ts # Markdown parsing
โ โ โโโ transformer.ts # Basic transformation
โ โ โโโ enhanced-transformer.ts # Advanced transformation (Phase 2)
โ โ โโโ optimized-transformer.ts # Performance-optimized transformer (Phase 4)
โ โ โโโ xml-builder.ts # NM3 XML generation
โ โ โโโ reference-extractor.ts # Cross-reference detection
โ โ โโโ content-classifier.ts # Semantic analysis
โ โ โโโ intelligent-shape-assigner.ts
โ โ โโโ intelligent-color-mapper.ts
โ โ โโโ spatial-optimizer-v2.ts # Spatial layout optimization (Phase 3)
โ โ โโโ collision-detector.ts # Collision detection (Phase 3)
โ โ โโโ force-directed-3d.ts # Force-directed layout (Phase 3)
โ โ โโโ layout-templates.ts # Layout templates (Phase 3)
โ โ โโโ octree.ts # Octree spatial indexing (Phase 3)
โ โ โโโ cache-manager.ts # Multi-layer caching (Phase 4)
โ โ โโโ stream-processor.ts # Streaming processor (Phase 4)
โ โ โโโ worker-pool.ts # Worker thread pool (Phase 4)
โ โ โโโ metrics.ts # Performance metrics (Phase 4)
โ โ โโโ memory-monitor.ts # Memory management (Phase 4)
โ โโโ models/
โ โ โโโ types.ts # TypeScript interfaces
โ โโโ constants/
โ โ โโโ validation.ts # Valid colors and shapes
โ โโโ utils/ # Utility functions
โ โโโ handlers/ # Additional handlers
โโโ docs/ # Documentation
โ โโโ Markdown3D-Phase0.md # Overview
โ โโโ Markdown3D-Phase1.md # Foundation implementation
โ โโโ Markdown3D-Phase2.md # Advanced features
โ โโโ Markdown3D-Phase3.md # Spatial optimization
โ โโโ Markdown3D-Phase4.md # Performance & scalability
โ โโโ instruct/ # Detailed phase instructions
โโโ tests/ # Test suite
โโโ output/ # Generated NM3 files
โโโ specs/ # NM3 specifications
Development Workflow
# Install dependencies
npm install
# Development mode (watch for changes)
npm run dev
# Build for production
npm run build
# Run tests
npm run test
# Start MCP server
npm startBuilding From Source
# Clone repository
git clone https://github.com/yourusername/markdown3d-mcp.git
cd markdown3d-mcp
# Install dependencies
npm install
# Build TypeScript
npm run build
# Test the build
node dist/index.jsDevelopment Phases
The project is organized into 6 development phases:
Phase 1: Foundation & Basic Functionality โ
Working MCP server with basic transformation
Strict validation (16 colors, 5 shapes)
Simple spatial positioning
Phase 2: Advanced Parsing & Intelligence โ
Cross-reference detection
Semantic analysis with NLP
Intelligent shape and color assignment
Relationship mapping
Phase 3: Spatial Optimization โ
Force-directed graph algorithms
Collision detection and resolution
Layout templates
Octree spatial indexing
Phase 4: Performance & Scalability โ
Multi-layer caching (parse, transform, XML)
Streaming processing for large documents
Worker thread pool for parallel processing
Performance monitoring with Prometheus metrics
Memory management with automatic GC
Optimized transformer with intelligent caching
Phase 5: Testing & Quality Assurance (Planned)
Comprehensive test suite
Validation framework
Error recovery
Benchmark suite
Phase 6: Production & Deployment (Planned)
Docker containerization
CI/CD pipelines
Monitoring and logging
Documentation
Testing
# Run all tests
npm run test
# Test with specific markdown file
npm run test -- --file docs/test-book.md
# Validate NM3 output
node dist/index.js validate output/test.nm3Code Style
TypeScript with strict mode enabled
ESModules (
.jsimports required)Functional programming patterns preferred
Comprehensive error handling
Detailed logging for debugging
๐ NM3 Format
NM3 (Navigable Markdown 3D) is an XML-based format for representing documents in 3D space. Each document consists of:
Metadata: Title, author, creation date, tags
Camera: Initial viewpoint and field of view
Nodes: 3D geometric shapes representing content
Links: Relationships between nodes
Key Features
16 Allowed Colors: Pastel palette for visual harmony
5 Geometric Types: Sphere, Cube, Cylinder, Pyramid, Torus
CDATA Content: Preserves markdown formatting
Spatial Positioning: 3D coordinates (x, y, z)
Link Types: 13 semantic relationship types
Specification
For the complete NM3 XML specification, see:
NM3 Format Specification (placeholder - link to your spec)
Sample NM3 Structure
<?xml version="1.0" encoding="UTF-8"?>
<nm3 version="1.0">
<meta title="Document Title" created="2025-01-01T00:00:00Z" author="Author"/>
<camera position-x="0" position-y="10" position-z="20"
look-at-x="0" look-at-y="0" look-at-z="0" fov="75"/>
<nodes>
<node id="intro" type="sphere" x="0" y="0" z="0"
color="pastel-blue" scale="1.5">
<title>Introduction</title>
<content><![CDATA[# Introduction
This is the content...]]></content>
</node>
</nodes>
<links>
<link from="intro" to="chapter1" type="leads-to" color="pastel-gray"/>
</links>
</nm3>๐จ Visualization
Viewing NM3 Files
To view the generated 3D visualizations, use the Careless-Canvas-3D application:
๐ Careless-Canvas-3D Viewer (placeholder link)
The Careless-Canvas-3D viewer provides:
Interactive 3D navigation
Node selection and content viewing
Link traversal
Multiple camera modes
Export and sharing options
Alternative Viewers
NM3 files can also be viewed with:
Any XML-compatible 3D visualization tool
Custom Three.js implementations
VR/AR compatible viewers
Screenshots
(Add screenshots of visualized documents here)
๐ Citation
Related Projects
(Placeholder for related NM3 works, inspirations, and acknowledgments)
๐ค Contributing
Contributions are welcome! Please see our Contributing Guidelines for details.
How to Contribute
Fork the repository
Create a feature branch (
git checkout -b feature/amazing-feature)Commit your changes (
git commit -m 'Add amazing feature')Push to the branch (
git push origin feature/amazing-feature)Open a Pull Request
Development Setup
# Fork and clone
git clone https://github.com/yourusername/markdown3d-mcp.git
# Create branch
git checkout -b feature/my-feature
# Install dependencies
npm install
# Make changes and test
npm run dev
npm run test
# Build
npm run buildCode of Conduct
We follow the Contributor Covenant Code of Conduct. Please be respectful and inclusive in all interactions.
๐ License
This project is licensed under the ISC License - see the LICENSE file for details.
๐ Links
GitHub Repository: https://github.com/yourusername/markdown3d-mcp
NPM Package: https://www.npmjs.com/package/markdown3d-mcp
Documentation: https://markdown3d-docs.example.com
Issue Tracker: https://github.com/yourusername/markdown3d-mcp/issues
MCP Protocol: https://modelcontextprotocol.io
๐ Citation
Academic Citation
If you use this codebase in your research or project, please cite:
@software{markdown3d_mcp,
title = {Markdown3D MCP: MCP transforms MD into NM3 formatted xml},
author = {[Drift Johnson]},
year = {2025},
url = {https://github.com/MushroomFleet/Markdown3D-MCP},
version = {1.0.0}
}Donate:

Made with โค๏ธ by the Markdown3D team
Transform your documents into navigable 3D knowledge spaces
Support This Project
If you found this useful, please star the repo โ it helps others discover it!
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
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/MushroomFleet/Markdown3D-MCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server