Metadata-Version: 2.4
Name: mathematica_mcp
Version: 0.1.9
Summary: MCP server for WolframScript
Project-URL: Homepage, https://github.com/lars20070/mathematica-mcp
Project-URL: Repository, https://github.com/lars20070/mathematica-mcp
Project-URL: Issues, https://github.com/lars20070/mathematica-mcp/issues
Author-email: Lars Nilse <l.nilse@dunelm.org.uk>
License-File: LICENSE
Keywords: mathematica,mcp,model-context-protocol,wolframscript
Requires-Python: <3.14,>=3.10
Requires-Dist: fastmcp>=2.13.0.1
Requires-Dist: loguru>=0.7.3
Requires-Dist: pydantic-settings>=2.8.1
Requires-Dist: pydantic>=2.10.6
Description-Content-Type: text/markdown

# Mathematica MCP Server

<!-- mcp-name: io.github.lars20070/mathematica-mcp -->

[![Build](https://github.com/lars20070/mathematica-mcp/actions/workflows/build.yaml/badge.svg)](https://github.com/lars20070/mathematica-mcp/actions/workflows/build.yaml)
[![Python Version](https://img.shields.io/badge/dynamic/toml?url=https://raw.githubusercontent.com/lars20070/mathematica-mcp/master/pyproject.toml&query=project.requires-python&label=python)](https://www.python.org/downloads/)
[![License](https://img.shields.io/github/license/lars20070/mathematica-mcp)](https://github.com/lars20070/mathematica-mcp/blob/master/LICENSE)
[![PyPI version](https://badge.fury.io/py/mathematica-mcp.svg)](https://badge.fury.io/py/mathematica-mcp)

MCP server that wraps Mathematica's `wolframscript` command-line interface. It provides tools to evaluate Wolfram Language code and retrieve information about the Wolfram Engine installation.

| Tool | Description |
|------|-------------|
| `evaluate` | Evaluates a Wolfram Language script |
| `version_wolframscript` | Returns version of `wolframscript` |
| `version_wolframengine` | Returns version of Wolfram Engine |
| `licensetype` | Returns license type of Wolfram Engine |

## Background

* *Wolfram Language*: symbolic programming language e.g. `Integrate[x*Sin[x], x]`
* *Wolfram Engine*: kernel for running Wolfram Language code
* *WolframScript*: command-line interface to Wolfram Engine
* *Mathematica*: notebook interface to Wolfram Engine

Both Wolfram Engine and WolframScript are [freely available](https://www.wolfram.com/engine/) for personal use.

## Installation

1. Please ensure WolframScript is installed and activated on your system.

```bash
wolframscript -version
wolframscript -activate
wolframscript -code "Integrate[x*Sin[x], x]"
```

2. Install the [uv package manager](https://docs.astral.sh/uv/getting-started/installation/).

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

3. Edit the Claude Desktop config file and add the `mathematica-mcp` server. Note that `uvx` sets up an environment, installs the `mathematica-mcp` package, and runs the server by calling the `mathematica-mcp` entry point defined in [`pyproject.toml`](pyproject.toml). No cloning of the repository is necessary. The logs are written to the default user log directory, e.g. `~/Library/Logs/mathematica_mcp/mathematica_mcp.log` on macOS.

```json
{
  "mcpServers": {
    "mathematica-mcp": {
      "command": "uvx",
      "args": [
        "mathematica-mcp"
      ]
    }
  }
}
```
*Claude Desktop config file on macOS:* `~/Library/Application Support/Claude/claude_desktop_config.json`

4. Alternatively, you can clone the repository and then modify or extend the MCP server code. In this case, make sure to update the path to the local repository in the Claude Desktop config file.

```json
{
  "mcpServers": {
    "mathematica-mcp": {
      "command": "uv",
      "args": [
        "--directory",
        "/Users/lars/Code/mathematica-mcp",
        "run",
        "mathematica-mcp"
      ]
    }
  }
}
```
*Claude Desktop config file on macOS:* `~/Library/Application Support/Claude/claude_desktop_config.json`
