Skip to main content

A Jupyter widget for testing MongoDB AI capabilities such as RAG.

Project description

MongoDB AI Playground

MongoDB AI Playground is a set of interactive widgets for to explore, test, and visualize MongoDB-powered AI capabilities in notebooks, including Retrieval-Augmented Generation (RAG) and GraphRAG workflows, using modern LLM and vector search integrations.


Overview

Screenshot MongoDB AI Playground

Built as a set of AnyWidget Jupyter widgets, this playground is designed for rapid prototyping, learning, and demonstration of GenAI + MongoDB workflows.

Prerequisites

  • An Atlas account with a cluster running MongoDB version 6.0.11, 7.0.2, or later (including release candidates). Ensure your IP address is included in your Atlas project's access list. To learn more, see Create a Cluster.
  • An environment to run interactive Python notebooks such as JupyterLab, Jupyter Notebook, Google Colab and VSCode. Make sure you have widget support enabled (it is enabled by default on most platforms).
  • Create a database and collection (if you choose to use an existing collection, usage with the playground will erase the collection's data. Providing a new collection is recommended)
  • Create an Atlas Vector Search index with the correct dimension associated with the embedding model you will use. The field containing the embedding must be named embedding.

Installation

pip install mongodb-ai-playground

Usage

RAG Playground

from mongodb_ai_playground import MongoDBRAGPlayground

# Example: Pass your own loader, embedding model, LLM, and MongoDB collection
widget = MongoDBRAGPlayground(
    loader=...,              # LangChain loader
    embedding_model=...,     # LangChain embedding model 
    llm=...,                 # LangChain Chat Model (LLM) for answering questions (OpenAI, Claude, DeepSeek, etc.)
    mongo_collection=...,    # PyMongo collection for storing vectors
    index_name=...           # Name of your Atlas Vector Search index, you need to create if you don't have one, with the correct dimension (field containing the embedding is 'embedding')
)
widget # Display the playground widget
  • All interactions are performed via the interactive UI in Jupyter-compatible environments.
  • Visualize chunking, embeddings, vector search results, and question answering.

Notebook examples

Description Link
Wikipedia data + Voyage AI embedding + OpenAI LLM Open In Colab

Development

Setup

To set up the environment for development, clone the repository and install the package in editable mode. This allows changes to the Python code and the JavaScript/CSS (via anywidget's live reloading) to be reflected immediately.

# Clone the repository
git clone https://github.com/mongodb-developer/mongodb-ai-playground.git
cd mongodb-ai-playground

# Create a virtual environment (recommended)
python -m venv venv
source venv/bin/activate  # On Windows use `venv\Scripts\activate`

# Install in editable mode
pip install -e .

Testing in a Notebook

To test the widget during development:

  1. Start JupyterLab or Jupyter Notebook:
    pip install jupyterlab
    jupyter lab
    
  2. Open the example notebook in examples/mongodb_rag_playground_wiki_voyageai_openai.ipynb.
  3. Ensure you have the necessary environment variables or credentials set up (Atlas connection string, OpenAI API key, etc.) as described in the notebook.
  4. Run the notebook cells to interact with the widget. Changes to mongodb_ai_playground/index.js or mongodb_ai_playground/index.css will be reflected upon refreshing the page or re-running the widget cell.

Building the Package

To build the package for distribution (creating .tar.gz and .whl files):

  1. Install the build tool:
    pip install build
    
  2. Run the build command from the root of the repository:
    python -m build
    
  3. The build artifacts will be generated in the dist/ directory.

Features

  • 📄 Document Chunking: Flexible strategies (fixed, recursive, markdown) for splitting documents.
  • 🧠 Embeddings & Vector Search: Store and search embeddings in MongoDB Atlas using langchain-mongodb.
  • 🔎 RAG Playground UI: Step-by-step interface for chunking, embedding, and querying.
  • 🕸️ Knowledge Graph RAG: Build and visualize entity/relation graphs from docs and run graph-based QA.
  • 🧩 Extensible: Built for experimentation with LangChain so that you can use different loaders, embeddings models, LLMs and more.

Project Structure

mongodb_ai_playground/
├── rag_widget.py         # RAG playground widget (chunking, embedding, RAG)
├── graphrag_widget.py    # Graph RAG playground widget (graph ingest, QA)
├── index.js              # JS frontend for RAG widget
├── graphrag.js           # JS frontend for Graph RAG widget
├── index.css             # Shared widget styles
├── __init__.py           # Exports widgets
...

Requirements

  • Python 3.7+
  • Jupyter widget compatible environments (JupyterLab, Jupyter Notebook, Colab, Marimo, etc.)
  • MongoDB Atlas deployment (for vector/graph storage)
  • Any LLM and embedding model using LangChain components (OpenAI, HuggingFace, etc.)

License

This project is licensed under the MIT License.

Acknowledgments

Additional Resources

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mongodb_ai_widgets-0.1.1.tar.gz (181.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mongodb_ai_widgets-0.1.1-py3-none-any.whl (180.2 kB view details)

Uploaded Python 3

File details

Details for the file mongodb_ai_widgets-0.1.1.tar.gz.

File metadata

  • Download URL: mongodb_ai_widgets-0.1.1.tar.gz
  • Upload date:
  • Size: 181.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for mongodb_ai_widgets-0.1.1.tar.gz
Algorithm Hash digest
SHA256 4b31169d6746683d2d2263d1898cd4aa7afecf4480fc60e205ae10ae8f33210b
MD5 1c51456af48ef99056e83b21c1fe4ce1
BLAKE2b-256 8c58d90c2a63be1051ee1df0f8ec3c4281b4ada3ebe222d6bdc9a3822127e537

See more details on using hashes here.

File details

Details for the file mongodb_ai_widgets-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for mongodb_ai_widgets-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 006e1fdee0c85a2c95b9ff7320dae38a7326e0acf72e40e49fb37ff4dda7070f
MD5 4b605867b92eaf5e98dcaff3de6eeb54
BLAKE2b-256 893e2f5165a2082dcfbec9079162f79dee3791d4ea34cfe220016584938ce4dd

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page