MCP server for tracking student learning via a knowledge graph
Project description
Knowledge Graph MCP Server
An MCP (Model Context Protocol) server for tracking student learning via a knowledge graph. Built with FastMCP, it enables LLMs to build, query, and update a personalized knowledge map with spaced repetition scheduling.
Features
- Knowledge Graph Storage: SQLite-backed graph with concepts as nodes and relationships as edges
- Multi-dimensional Mastery Tracking: Track recall, application, and explanation abilities separately
- Spaced Repetition (SM-2): Automatic scheduling of review sessions based on performance
- Misconception Tracking: Record and query common misconceptions for targeted remediation
- Intelligent Queries: Find knowledge gaps, ready-to-learn concepts, struggling areas
- Mermaid Visualization: Generate visual diagrams of the knowledge graph
Installation
Option 1: Install from Smithery (Recommended)
Install directly via Smithery:
npx @smithery/cli install @zcsabbagh/knowledge-graph-mcp --client claude
Or use the hosted version at: https://smithery.ai/server/@zcsabbagh/knowledge-graph-mcp
Option 2: Install from source
Prerequisites: Python 3.10+
git clone https://github.com/zcsabbagh/knowledge-graph-mcp.git
cd knowledge-graph-mcp
pip install -e .
Usage
Running the Server
# From the project root
python -m knowledge_graph_mcp.server
Configure with Claude Code
Add to your Claude Code MCP settings (~/.claude/settings.json):
{
"mcpServers": {
"knowledge-graph": {
"command": "python",
"args": ["-m", "knowledge_graph_mcp.server"],
"cwd": "/path/to/knowledge-graph-mcp"
}
}
}
Configure with Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"knowledge-graph": {
"command": "python",
"args": ["-m", "knowledge_graph_mcp.server"],
"cwd": "/path/to/knowledge-graph-mcp"
}
}
}
MCP Tools
1. add_node
Create a new concept node.
add_node(
concept="Quadratic Formula",
description="Formula for solving ax² + bx + c = 0",
domain="mathematics",
difficulty=0.7,
tags=["algebra", "formulas"]
)
2. add_edge
Create relationships between concepts.
Relation types:
prerequisite- Must learn source before targetbuilds_on- Target extends source conceptrelated_to- Concepts are connectedcontradicts- Common misconceptionapplies_to- Application domainparent_of- Category hierarchy
add_edge(
source_concept="Algebra",
target_concept="Quadratic Formula",
relation_type="prerequisite"
)
3. update_node
Update mastery and record reviews. Providing a quality rating (0-5) triggers spaced repetition scheduling.
update_node(
node_id="quadratic_formula",
quality=4, # SM-2 rating: 0=blackout, 5=perfect
mastery_application=0.6,
misconception_detected="forgets ± sign"
)
4. query_graph
Intelligent queries for learning insights.
Query types:
prerequisites- All prerequisites for a conceptready_to_learn- Concepts where prereqs are mastereddue_for_review- Needs review based on schedulestruggling- High difficulty + low masterystalled- Multiple reviews, no improvementmisconceptions- Concepts with detected misconceptionsknowledge_gaps- Low mastery blocking progressnext_recommended- Best concept to study next
query_graph(query_type="next_recommended", domain="mathematics")
5. read_subgraph
Get the neighborhood around a concept with Mermaid visualization.
read_subgraph(
center_node="calculus",
depth=2,
direction="upstream", # or "downstream", "both"
output_format="both" # "json", "mermaid", or "both"
)
6. get_learning_path
Get ordered prerequisites for a target concept.
get_learning_path(target_concept="calculus")
7. get_statistics
Get learning progress metrics.
get_statistics(domain="mathematics")
How It Works
Data Model
Nodes represent concepts with:
- Mastery levels (overall, recall, application, explanation)
- Spaced repetition data (ease factor, interval, next review date)
- Difficulty rating and review history
- Tags and detected misconceptions
Edges represent relationships with:
- Relation type (prerequisite, builds_on, etc.)
- Strength/confidence rating
- Optional reasoning
Spaced Repetition (SM-2)
When you call update_node with a quality rating:
- 5: Perfect response → longer interval
- 4: Correct with hesitation
- 3: Correct with difficulty
- 2-0: Incorrect → reset interval
The algorithm calculates the next optimal review date based on performance history.
Mastery Calculation
Overall mastery combines dimensional scores:
mastery_level = 0.3 × recall + 0.4 × application + 0.3 × explanation
Storage
Data is stored in SQLite at ~/.knowledge_graph/knowledge.db by default.
Example Workflow
1. LLM discovers student doesn't know "quadratic formula"
→ add_node(concept="Quadratic Formula", difficulty=0.7)
2. LLM identifies prerequisites
→ add_edge("Algebra", "Quadratic Formula", "prerequisite")
3. Student attempts problem, struggles
→ update_node("quadratic_formula", quality=2,
misconception_detected="confuses ± with +")
4. LLM decides what to teach next
→ query_graph("next_recommended")
5. Visualize the learning path
→ get_learning_path("quadratic_formula")
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file knowledge_graph_mcp-0.1.0.tar.gz.
File metadata
- Download URL: knowledge_graph_mcp-0.1.0.tar.gz
- Upload date:
- Size: 21.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fac3c263cc800eb9c267b6471d80995c329f3f6cca0429b4c3488638bde6616b
|
|
| MD5 |
497e8c2bee31975b1e617a02d8a0c33e
|
|
| BLAKE2b-256 |
8f3068554446556e4df73f1d63990611aa8fcb5f72bdda32618e34da727f7886
|
File details
Details for the file knowledge_graph_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: knowledge_graph_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 26.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e9155793357d67a8cf7381594837192fd5d35f792c72bcc6e8ef9a4e483eddb4
|
|
| MD5 |
5096a7781f880322b0b68a62a0d2fae2
|
|
| BLAKE2b-256 |
8d0ed6ffe5c70f6dc47be40f7c1baee89579d00aa8e7d7454e80f165f1b433c5
|