OpenLMlib

OpenLMlib

Provides AI assistants with a local knowledge base and research library, enabling semantic and full-text retrieval, memory persistence, and multi-agent collaboration via 58 MCP tools.

Category
Visit Server

README

OpenLMlib

Local knowledge and research library for LLM workflows

Store, retrieve, and collaborate on findings with semantic search, full-text search, and multi-agent collaboration sessions.

๐Ÿ“š Full Documentation ยท Quickstart ยท MCP Tools ยท CollabSessions


Features

  • Knowledge Base: SQLite metadata + JSON findings + FAISS/Numpy vector index
  • Semantic Retrieval: Multi-phase retrieval with semantic + lexical search, deduplication, and reranking
  • MCP Server: 58 tools for AI assistants (17 core + 10 memory + 31 collaboration)
  • CollabSessions: Multi-agent collaboration with message passing, artifacts, and templates
  • CLI: Full command-line interface for management and diagnostics
  • Portable: Findings exportable as JSON, easy backup and restore

Quickstart

Installation

npm install -g openlmlib
openlmlib setup  # Interactive wizard with React TUI

Other options:

pipx (Python only)

pipx install openlmlib
openlmlib setup

From Source

git clone https://github.com/Vedant9500/LMlib.git
cd LMlib
pip install -e .
openlmlib setup

Note: The embedding model (~100-500MB) downloads during setup, not installation.

First Steps

# Check health
openlmlib doctor

# Add a finding
openlmlib add \
  --project myproj \
  --claim "Contextual chunking improves retrieval by 15-30%" \
  --confidence 0.85 \
  --evidence "https://arxiv.org/example" \
  --reasoning "Benchmarks show context-aware chunking outperforms fixed-size"

# Search
openlmlib query "retrieval techniques" --final-k 5

# List findings
openlmlib list --limit 20

Configure AI Assistants

# Interactive setup (recommended)
openlmlib setup

# Or configure specific IDEs
openlmlib mcp-config --ide vscode --ide cursor

# Codex CLI / Claude Code
openlmlib mcp-config --ide codex_cli --ide claude_code

Each MCP client needs its own config entry. A custom prompt in Antigravity can encourage OpenLMlib usage there, but Codex or Claude will not see the MCP until openlmlib is registered in their MCP config and the client is restarted or refreshed.

Supported clients: VS Code, Cursor, Claude Desktop, Claude Code, Gemini CLI, Aider, Windsurf, Zed, Cline, and more.


What Can You Do?

๐Ÿ“š Build a Knowledge Base

Store findings from research, experiments, or analysis with structured metadata:

openlmlib add \
  --project retrieval \
  --claim "Dynamic chunk sizing reduces hallucination by 20%" \
  --confidence 0.78 \
  --evidence "https://example.com/study" \
  --reasoning "Adaptive chunk size based on query complexity..." \
  --caveats "Requires query complexity estimation" \
  --tags retrieval,chunking,evaluation

๐Ÿ” Retrieve with Context

Multi-phase retrieval combines semantic similarity, lexical matching, and recency:

# Semantic search with reasoning traces
openlmlib query "contextual retrieval" \
  --final-k 5 \
  --reasoning-trace

# With filters
openlmlib query "retrieval" \
  --project myproj \
  --tags retrieval \
  --confidence-min 0.8

๐Ÿค– Use with AI Assistants

58 MCP tools let AI assistants securely access and modify your knowledge base:

Core Tools (17):

  • init_library, health - Setup and diagnostics
  • save_finding, delete_finding - Write operations (require confirmation)
  • retrieve_findings, search_findings, search_knowledge - Retrieval and search
  • list_findings, get_finding - Browse findings
  • retrieve_context - Format findings for LLM prompts
  • start_research, end_session - Composite workflow tools
  • check_context, save_finding_auto - Convenience tools
  • evaluate_retrieval, get_usage_analytics, help_library - Utilities

๐Ÿ“– See all 58 tools โ†’

๐Ÿ‘ฅ Multi-Agent Collaboration

CollabSessions enable structured collaboration between multiple LLM agents:

# Create session from template
openlmlib-mcp --call create_from_template '{
  "template_id": "deep_research",
  "title": "Research on Retrieval",
  "created_by": "gpt-4"
}'

# Join session
openlmlib-mcp --call join_session '{
  "session_id": "sess_20260409_abc12345",
  "model": "claude-3",
  "role": "worker"
}'

# Send and receive messages
openlmlib-mcp --call send_message '{...}'
openlmlib-mcp --call poll_messages '{...}'

# Add artifacts (reports, analysis)
openlmlib-mcp --call save_artifact '{...}'

Available Templates:

  • deep_research - Comprehensive research (5 steps, 5 agents)
  • code_review - Multi-agent code review (5 steps, 4 agents)
  • market_analysis - Market/competitor analysis (4 steps, 4 agents)
  • incident_investigation - Root cause analysis (4 steps, 3 agents)
  • literature_review - Academic literature review (6 steps, 5 agents)

๐Ÿ“– Full CollabSessions guide โ†’

๐Ÿง  Memory System (Session Persistence & Retrieval)

OpenLMlib includes a powerful memory system that persists session knowledge across work sessions, enabling AI assistants to "remember" what happened in previous sessions and continue work seamlessly.

Key Features:

  • Session Lifecycle: Start/end sessions with automatic context injection and summarization
  • Progressive Retrieval: 3-layer disclosure (search index โ†’ timeline โ†’ full details) for token efficiency
  • Retroactive Ingestion: Auto-ingest session activity from git history โ€” no manual logging needed!
  • Caveman Compression: Ultra-compressed context injection (46% token savings)

Memory Tools (10 tools):

session_start           - Start session with context from previous sessions
session_end             - End session and auto-generate summary
log_observation         - Log tool executions for memory building
search_memory           - Layer 1: Search index (~75 tokens/result)
memory_timeline         - Layer 2: Chronological context (~200 tokens/result)
get_observations        - Layer 3: Full details (~750 tokens/result)
inject_context          - Auto-inject relevant context at session start
session_recap           - Synthesized recap of recent sessions (~150-250 tokens)
topic_context           - Deep dive on specific topics (~500-800 tokens)
ingest_git_history      - Auto-ingest from git history (no manual logging!)

Example Workflow:

# Start of session - automatically loads relevant context
session_start(
    session_id="sess_20260414_001",
    query="memory retrieval optimization"
)
# Returns: Context from previous sessions with relevant observations

# During work - observations are logged automatically
log_observation(
    session_id="sess_20260414_001",
    tool_name="Edit",
    tool_input="Modified memory_retriever.py",
    tool_output="Added auto_inject_context method"
)

# End of session - auto-generates summary
session_end(session_id="sess_20260414_001")
# Creates synthesized knowledge: files touched, decisions, next steps

# Next session - continue seamlessly
session_recap(limit=3)
# Returns: Structured knowledge from last 3 sessions

Token Efficiency:

  • Layer 1 only: 75 tokens/result (search index for filtering)
  • Layer 1+2: 275 tokens/result (timeline context)
  • Layer 1+2+3: 1,025 tokens/result (full details only for relevant items)
  • vs. full dump: 3-13x token savings!

๐Ÿ“– Memory System Guide โ†’


Architecture

OpenLMlib
โ”œโ”€โ”€ Knowledge Base
โ”‚   โ”œโ”€โ”€ SQLite (metadata, full-text search)
โ”‚   โ”œโ”€โ”€ FAISS/Numpy (vector index)
โ”‚   โ””โ”€โ”€ JSON findings (portable, human-readable)
โ”‚
โ”œโ”€โ”€ MCP Server (58 tools)
โ”‚   โ”œโ”€โ”€ 17 core library tools
โ”‚   โ”œโ”€โ”€ 10 memory tools (session lifecycle, progressive retrieval, retroactive ingestion)
โ”‚   โ””โ”€โ”€ 31 collaboration tools
โ”‚
โ”œโ”€โ”€ CLI
โ”‚   โ”œโ”€โ”€ Setup and configuration
โ”‚   โ”œโ”€โ”€ Finding management
โ”‚   โ””โ”€โ”€ Diagnostics (doctor command)
โ”‚
โ””โ”€โ”€ CollabSessions
    โ”œโ”€โ”€ Message bus (SQLite + JSONL)
    โ”œโ”€โ”€ Artifact store
    โ”œโ”€โ”€ Session templates
    โ””โ”€โ”€ Context compaction

Documentation

๐Ÿ“š Complete documentation is in the docs/ folder:


CLI Reference

# Setup and diagnostics
openlmlib setup          # First-run bootstrap
openlmlib doctor         # Health check
openlmlib --version      # Show version

# Knowledge base
openlmlib init           # Initialize storage
openlmlib add            # Add finding
openlmlib list           # List findings
openlmlib get            # Get finding details
openlmlib query          # Semantic retrieval
openlmlib delete         # Delete finding

# Collaboration
openlmlib-mcp            # MCP server (auto-configured)

# Backup and restore
openlmlib backup         # Create backup
openlmlib restore        # Restore from backup

Configuration

Global Install

  • Settings: ~/.openlmlib/config/settings.json
  • Data: ~/.openlmlib/data/

Local/Dev Install

  • Pass --settings /path/to/settings.json

Uninstallation

# Remove package
npm uninstall -g openlmlib    # if installed via npm
pipx uninstall openlmlib      # if installed via pipx
pip uninstall openlmlib       # if installed from source

# Remove data (optional)
rm -rf ~/.openlmlib           # global install data
rm -rf data/                  # local install data

Development

git clone https://github.com/Vedant9500/LMlib.git
cd LMlib
python -m venv .venv
source .venv/bin/activate  # Windows: .venv\Scripts\activate
pip install -e ".[dev,faiss]"

# Run tests
python -m pytest tests/ -v

# Run MCP server manually
python -m openlmlib.mcp_server --settings ./config/settings.json

Notes

  • Vector Search: Uses FAISS if installed, otherwise Numpy fallback
  • Embedding Model: sentence-transformers/all-MiniLM-L6-v2 (default)
  • Python: Requires 3.10+
  • Global vs Local: Global installs use ~/.openlmlib/, local uses project data/

Releases


Contributing

See CONTRIBUTING.md for development workflow and guidelines.


License

MIT License - see LICENSE

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured