Skip to main content

Full GUI control of Mathematica notebooks and kernel via Model Context Protocol

Project description

Mathematica MCP

Turn Mathematica into a first-class tool for AI agents.

A local MCP server that lets AI agents run Mathematica, control notebooks, and verify results. Works with Claude, Cursor, VS Code, Codex, and Gemini.

License: MIT Python 3.10+ Mathematica 14+ CI Repo Published


Watch it in action

Mathematica MCP Demo

An AI agent solving math, generating plots, and controlling a live Mathematica notebook. Errors are returned directly to the agent, no copy-pasting notebook output back into chat.


Why This Exists

LLMs can write Mathematica code, but they can't run it, verify it, or interact with live notebooks. This MCP server bridges that gap:

  • Live notebook control: create, edit, evaluate, and screenshot Mathematica notebooks directly from your AI agent
  • Symbolic + numeric + visual in one MCP: ~82 tools covering algebra, calculus, plotting, data import/export, Wolfram Alpha, and interactive UIs
  • Agent-optimized: compact response shaping, session state tools, and computation journaling designed for how LLM agents actually work
  • Error-aware execution: Mathematica errors and warnings are returned directly to the agent, so it can debug without you manually copying notebook output back into chat
  • Local and private: core execution runs on your machine — optional tools like wolfram_alpha and repository search contact Wolfram's cloud services when invoked

Ask your agent for a derivation, a 3D plot, a notebook edit, or a verification step, and it can actually do it.


Who This Is For

Audience Use Case
Researchers using LLM coding assistants Run Mathematica from Claude/Cursor/VS Code without leaving your editor
Data scientists Import, transform, and visualize data through natural language
Educators Create interactive Mathematica notebooks through AI conversation
Not for Production web services, untrusted multi-tenant environments

What You Can Ask For

"Integrate x^2 sin(x) from 0 to pi, then verify the result."

execute_code("Integrate[x^2 Sin[x], {x, 0, Pi}]")  =>  -4 + Pi^2
verify_derivation(steps=["Integrate[...", "-4 + Pi^2"])  =>  All steps valid

"Plot the sombrero function in a new notebook."

create_notebook(title="Sombrero")
execute_code("Plot3D[Sinc[Sqrt[x^2+y^2]], {x,-4,4}, {y,-4,4}]", style="notebook")
=> [3D surface plot rendered in live notebook]

"Interactive: slider for Sin[n x]"

execute_code("Manipulate[Plot[Sin[n x],{x,0,2Pi}],{n,1,10}]", style="interactive")
=> [Live slider UI in Mathematica frontend]

Beyond these: data import/export (hundreds of formats), Wolfram Alpha queries, notebook reading/analysis, symbolic debugging, and more. See the Technical Reference for the full tool list.


How It Compares

Capability Plain LLM Copy-paste to Mathematica This MCP
Write Mathematica code Yes Yes Yes
Verify math results May hallucinate Manual One tool call
Iterate on errors Guesses without running Manual loop Errors fed back with tips
Structured results No No Yes, with metadata
Generate and view plots No Manual File or notebook
Live notebook control No No Create/edit/eval/screenshot
Interactive UIs (sliders) No Manual Yes, in Mathematica
Read notebooks offline No No Yes, Python parser
Private / local execution N/A Yes Yes*

*Core computation runs locally. Optional tools (wolfram_alpha, repository search) contact Wolfram cloud services when invoked.


Quick Start

From install to first working notebook plot in under 2 minutes.

Prerequisites

  1. Mathematica 14.0+ with wolframscript in your PATH

    • Download Mathematica
    • macOS: Add to ~/.zshrc: export PATH="/Applications/Mathematica.app/Contents/MacOS:$PATH"
  2. uv package manager

    curl -LsSf https://astral.sh/uv/install.sh | sh
    

One-Command Setup

# For Claude Desktop
uvx mathematica-mcp-full setup claude-desktop

# For Cursor
uvx mathematica-mcp-full setup cursor

# For VS Code (requires GitHub Copilot Chat extension)
uvx mathematica-mcp-full setup vscode

# For OpenAI Codex CLI
uvx mathematica-mcp-full setup codex

# For Google Gemini CLI
uvx mathematica-mcp-full setup gemini

# For Claude Code CLI
uvx mathematica-mcp-full setup claude-code

# Optional: select a tool profile (default is "full")
uvx mathematica-mcp-full setup claude-desktop --profile notebook

Then restart Mathematica and your editor. Done!

VS Code: Alternative setup via Command Palette

Prerequisite: GitHub Copilot Chat extension must be installed - MCP support is built into Copilot.

  1. Press Cmd+Shift+P (Mac) / Ctrl+Shift+P (Windows)
  2. Type "MCP" -> Select "MCP: Add Server"
  3. Choose "Command (stdio)": not "pip"
  4. Enter command: uvx
  5. Enter args: mathematica-mcp-full
  6. Name it: mathematica
  7. Choose scope: Workspace or User
Alternative: Interactive Installer
bash <(curl -sSL https://raw.githubusercontent.com/AbhiRawat4841/mathematica-mcp/main/install.sh)

Verify Installation

uvx mathematica-mcp-full doctor

Tip: If you encounter errors after updating, clear the cache:

uv cache clean mathematica-mcp-full && uvx mathematica-mcp-full setup <client>

Execution Styles

Control where results appear with natural language or the style parameter:

Say this... style= What happens
"calculate", "compute", "evaluate", "solve", "what is" "compute" Result appears as text in chat
"plot", "show", "graph", "visualize", "in notebook" "notebook" Executes in the current Mathematica notebook
"new notebook", "fresh notebook", "create notebook" two-step create_notebook() then execute_code(style="notebook")
"interactive", "manipulate", "slider", "dynamic", "animate" "interactive" Live front-end evaluation (sliders, animations)

If you don't include a keyword, the default depends on your tool profile.


Tool Profiles

Choose how many tools to expose:

Profile Tools Best for
math ~28 Pure computation, no notebook UI
notebook ~48 + notebook read/write/screenshot
full (default) ~82 + advanced notebook ops, repositories, admin

Pass --profile during setup or set MATHEMATICA_PROFILE env var.


Built for Agent Workflows

The server is designed for how LLM agents actually work: long conversations with context limits, intermittent failures, and token budgets:

Feature What it does How to use
Compact Responses Strip verbose metadata, keep essentials. Saves tokens. response_detail="compact" on execute_code ("short" is accepted as an alias)
Session Brief One-call snapshot: connection status, recent errors, routing advice get_session_brief()
Computation Journal Ring buffer of recent computations that helps agents recover context across long conversations get_computation_journal()
Smart Caching Pure expressions (Sin[Pi]) survive variable mutations without re-evaluation Always on
Diagnostic Mode Full response + cache epoch + routing hints for debugging response_detail="diagnostic" ("long" and "medium" map to verbose/standard aliases)

Notebook execution is strict about the requested target: if notebook transport fails, the server returns a notebook error instead of silently rerunning the work through CLI fallback.

Routing Intelligence (opt-in)

For power users, the server can learn from transport outcomes and adapt:

# Observe mode: collect stats, no behavior change
export MATHEMATICA_ROUTING_MEMORY=observe

# Advise mode: + routing hints + enables adaptive routing
export MATHEMATICA_ROUTING_MEMORY=advise
export MATHEMATICA_ROUTING_ACTION=compute_cli_skip  # optional: skip failing transport

The adaptive routing circuit-breaker automatically skips persistently failing compute CLI transport with half-open probe recovery. See the Technical Reference for details.

Privacy: Routing memory stores only aggregate counters; the in-memory journal stores short code/output previews (not persisted). Notebook extraction results are cached to ~/.cache/mathematica-mcp/notebooks/ with mtime-based invalidation; delete the directory to clear the cache.


Manual Installation

For full details, troubleshooting, and advanced configuration, see the Installation Guide.

Click to expand quick manual setup
  1. Clone & Install:

    git clone https://github.com/AbhiRawat4841/mathematica-mcp.git
    cd mathematica-mcp
    uv sync
    
  2. Install Mathematica Addon:

    wolframscript -file addon/install.wl
    

    Restart Mathematica after this step.

  3. Configure your editor: add the MCP server to your client's config file. See the Installation Guide for Claude Desktop, Cursor, VS Code, and other client configs.


Documentation


License

MIT License

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

mathematica_mcp_full-0.9.4.tar.gz (116.9 kB view details)

Uploaded Source

Built Distribution

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

mathematica_mcp_full-0.9.4-py3-none-any.whl (131.7 kB view details)

Uploaded Python 3

File details

Details for the file mathematica_mcp_full-0.9.4.tar.gz.

File metadata

  • Download URL: mathematica_mcp_full-0.9.4.tar.gz
  • Upload date:
  • Size: 116.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.5 {"installer":{"name":"uv","version":"0.11.5","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mathematica_mcp_full-0.9.4.tar.gz
Algorithm Hash digest
SHA256 6c357a8db195477ab185b6ed6d4bd53b2f9e3213208c77d7cbaa9e2ed92657f7
MD5 708324a389cfc6a5cd35fddbd83d10cf
BLAKE2b-256 30e1b8d08dbdc955acf936f524e0ef191c8c93a1b750964a86dba4ff9c0b97ef

See more details on using hashes here.

File details

Details for the file mathematica_mcp_full-0.9.4-py3-none-any.whl.

File metadata

  • Download URL: mathematica_mcp_full-0.9.4-py3-none-any.whl
  • Upload date:
  • Size: 131.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.5 {"installer":{"name":"uv","version":"0.11.5","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mathematica_mcp_full-0.9.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0008c4d0d5d9efab91ec779b18c686d754875bb55a943f725c6d4f9afa6aa441
MD5 f749c0a611e9c4adde2ceaa5c9c6b330
BLAKE2b-256 7851669e7844fbe500d50b079386801562fe1b9cb7151acc2cd408250069a4cc

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