SharkMath MCP

SharkMath MCP

A Model Context Protocol server providing 150+ mathematical functions across arithmetic, trigonometry, statistics, unit conversions, and more, consolidated into 15 powerful tools for seamless integration with VS Code Copilot and other MCP-compatible clients.

Category
Visit Server

README

SharkMath MCP

A comprehensive Model Context Protocol (MCP) server providing 150+ mathematical functions consolidated into 15 powerful tools across all mathematical domains. This MCP server integrates seamlessly with VS Code Copilot and other MCP-compatible clients to provide powerful mathematical computation capabilities through parameter-based routing.

๐Ÿš€ Features

15 Consolidated Mathematical Tools

  • calculate_arithmetic - Basic arithmetic operations, expression evaluation, and power operations
  • calculate_trigonometry - Complete trigonometric and inverse functions with degree/radian support
  • calculate_statistics - Statistical operations including central tendency, dispersion, and percentiles
  • convert_units - Universal unit converter supporting 80+ conversions across all measurement types
  • calculate_logarithmic - Logarithmic and exponential functions with domain validation
  • calculate_hyperbolic - Hyperbolic functions with overflow protection
  • format_precision - Number formatting including rounding, floor, ceiling, and absolute value
  • analyze_numbers - Number theory and combinatorial mathematics (primes, GCD, LCM, factorial, etc.)
  • solve_equations - Equation solvers for quadratic and linear equations
  • calculate_geometry_2d - 2D geometry calculations for distance, slope, areas, and perimeters
  • manipulate_matrices - Matrix operations including addition, multiplication, determinant, and transpose
  • financial_calculations - Financial and business calculations including interest, loans, and investment analysis
  • computer_science_tools - Programming utilities including base conversions, hash functions, and algorithm analysis
  • data_analysis - Advanced statistical analysis including correlation, distribution analysis, and outlier detection
  • utility_functions - Helper functions providing mathematical constants, validation, and operation help

๐Ÿ“ฆ Installation

Prerequisites

  • Python 3.8+
  • VS Code with MCP extension support
  • uv package manager (recommended)

Setup

  1. Clone the repository:
git clone https://github.com/tonygod/SharkMath-MCP.git
cd SharkMath-MCP
  1. Install dependencies:
uv venv mcp-env
source mcp-env/bin/activate  # On Windows: mcp-env\Scripts\activate
uv pip install mcp fastmcp
  1. Run the MCP server:
uv run sharkmath_server.py

๐Ÿ”ง VS Code Integration

Configure the MCP server in your VS Code settings (.vscode/mcp.json):

{
  "mcpServers": {
    "sharkmath-mcp": {
      "command": "uv",
      "args": ["--directory", ".", "run", "sharkmath_server.py"],
      "cwd": "/path/to/SharkMath-MCP"
    }
  }
}

๐Ÿ“š API Reference

SharkMath uses parameter-based routing where each consolidated tool accepts an operation parameter to specify the desired function.

Arithmetic Operations - calculate_arithmetic

  • operation="add" - Addition: a + b
  • operation="subtract" - Subtraction: a - b
  • operation="multiply" - Multiplication: a * b
  • operation="divide" - Division with zero-division protection: a / b
  • operation="calculate" - Enhanced expression evaluation with 20+ mathematical functions
    • Basic Functions: sqrt(), pow(), abs(), round()
    • Trigonometric: sin(), cos(), tan(), asin(), acos(), atan()
    • Logarithmic: log(), log10(), ln() (natural log alias)
    • Hyperbolic: sinh(), cosh(), tanh()
    • Rounding: floor(), ceil(), trunc()
    • Constants: pi, e
    • Examples: sqrt(25), sin(pi/2), log(e), sqrt((5-0)^2 + (12-0)^2)
  • operation="power" - Exponentiation: base^exponent
  • operation="square" - Square: nยฒ
  • operation="cube" - Cube: nยณ
  • operation="square_root" - Square root: โˆšn

Statistical Functions - calculate_statistics

  • operation="mean" - Arithmetic mean
  • operation="median" - Median value
  • operation="mode" - Most frequent value
  • operation="standard_deviation" - Standard deviation
  • operation="variance" - Variance calculation
  • operation="range_stats" - Min, max, and range
  • operation="percentile" - Percentile calculation (requires percentile parameter)

Trigonometric Functions - calculate_trigonometry

  • operation="sin" - Sine function
  • operation="cos" - Cosine function
  • operation="tan" - Tangent function
  • operation="asin" - Inverse sine (arcsine)
  • operation="acos" - Inverse cosine (arccosine)
  • operation="atan" - Inverse tangent (arctangent)
  • operation="atan2" - Two-argument arctangent (requires x and y parameters)

Matrix Operations - manipulate_matrices

  • operation="add" - Matrix addition
  • operation="multiply" - Matrix multiplication
  • operation="determinant" - Determinant calculation
  • operation="transpose" - Matrix transpose

Unit Conversions - convert_units

  • Energy: watts, kilowatts, horsepower, joules, calories, btu
  • Temperature: celsius, fahrenheit
  • Length: meters, feet, inches, centimeters, kilometers, miles
  • Weight: kilograms, pounds
  • Volume: liters, gallons
  • Time: seconds, minutes, hours, days, weeks, months, years
  • Area: square_meters, square_feet, acres, hectares
  • Speed: mps, kmh, mph, knots
  • Pressure: pascals, atmospheres, psi, bar
  • Data: bytes, kilobytes, megabytes, gigabytes, terabytes

Financial Calculations - financial_calculations

  • operation="compound_interest" - Compound interest calculation
  • operation="simple_interest" - Simple interest calculation
  • operation="present_value" - Present value calculation
  • operation="future_value" - Future value calculation
  • operation="loan_payment" - Monthly loan payment
  • operation="roi" - Return on investment
  • operation="mortgage_payment" - Mortgage payment calculation

๐Ÿ“– Complete API Documentation - Full reference for all tools and operations

๐Ÿ—๏ธ Architecture

The project uses a consolidated tool architecture with parameter-based routing and FastMCP:

sharkmath_server.py          # Main MCP server (15 consolidated tools)
โ”œโ”€โ”€ arithmetic.py            # calculate_arithmetic (arithmetic + power operations + 20+ math functions)
โ”œโ”€โ”€ trigonometric.py         # calculate_trigonometry (trig + inverse trig functions)
โ”œโ”€โ”€ stats_operations.py      # calculate_statistics (statistical operations + percentiles)
โ”œโ”€โ”€ convert_units.py         # convert_units (80+ unit conversions)
โ”œโ”€โ”€ logarithmic.py           # calculate_logarithmic (log + exponential functions)
โ”œโ”€โ”€ hyperbolic.py            # calculate_hyperbolic (hyperbolic functions)
โ”œโ”€โ”€ precision.py             # format_precision (rounding + precision utilities)
โ”œโ”€โ”€ number_theory.py         # analyze_numbers (number theory + combinatorics)
โ”œโ”€โ”€ solve_equations.py       # solve_equations (quadratic + linear solvers)
โ”œโ”€โ”€ calculate_geometry_2d.py # calculate_geometry_2d (2D geometry calculations)
โ”œโ”€โ”€ matrix_operations.py     # manipulate_matrices (matrix operations)
โ”œโ”€โ”€ financial_calculations.py # financial_calculations (financial + business calcs)
โ”œโ”€โ”€ computer_science_tools.py # computer_science_tools (CS + programming utilities)
โ”œโ”€โ”€ data_analysis.py         # data_analysis (advanced statistical analysis)
โ””โ”€โ”€ utility_functions.py     # utility_functions (constants + validation + help)

Consolidated Tool Pattern

Each module implements parameter-based routing:

  • Single tool registration with operation parameter
  • Function routing based on operation parameter value
  • Comprehensive error handling with โœ…/โŒ prefixes
  • Input validation specific to each mathematical operation
  • Consistent return formatting across all operations

Key Architecture Benefits

  • Reduced tool count: 70+ individual tools โ†’ 15 consolidated tools
  • Improved maintainability: Logical grouping of related functions
  • Better performance: Single tool registration per domain
  • Enhanced usability: Intuitive parameter-based operation selection
  • MCP compatibility: Avoids tool registration limits

๐Ÿงช Testing

Run the comprehensive test suite:

cd Tests
python test_runner.py

Individual Consolidated Tool Testing

Each consolidated tool has its own dedicated test suite:

python test_calculate_arithmetic.py      # 45+ arithmetic operation tests
python test_calculate_trigonometry.py    # 42+ trigonometric function tests
python test_calculate_statistics.py      # 37+ statistical operation tests
python test_convert_units.py             # 51+ unit conversion tests
python test_manipulate_matrices.py       # 31+ matrix operation tests
python test_financial_calculations.py    # 31+ financial calculation tests
python test_computer_science_tools.py    # 41+ CS utility tests
python test_data_analysis.py             # 36+ advanced analysis tests
# ... and more for each consolidated tool

Test Coverage

  • 500+ individual tests across all consolidated tools
  • Parameter validation testing for all operation types
  • Error condition testing with comprehensive edge case coverage
  • Integration testing with MCP server registration verification
  • Regression testing ensuring all original functionality preserved

๐Ÿค Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/new-function)
  3. Add your mathematical function to the appropriate module
  4. Include comprehensive tests
  5. Update documentation
  6. Submit a pull request

Adding New Functions

  1. Choose the appropriate consolidated tool module
  2. Add your operation to the module's operation routing dictionary
  3. Implement the function with proper error handling and validation
  4. Add comprehensive test coverage to the tool's test suite
  5. Update documentation with the new operation parameter

Example: Adding a New Operation

# In arithmetic.py - adding a new operation
def calculate_arithmetic(operation: str, a: float = None, b: float = None, ...):
    operations = {
        "add": lambda: a + b,
        "subtract": lambda: a - b,
        "new_operation": lambda: your_new_function(a, b),  # Add here
        # ... other operations
    }
    
    if operation not in operations:
        return f"โŒ Unsupported operation: {operation}"
    
    try:
        result = operations[operation]()
        return f"โœ… {operation.title()} result: {result}"
    except Exception as e:
        return f"โŒ Error in {operation}: {str(e)}"

๐Ÿ“‹ Requirements

  • Python 3.8+
  • MCP (Model Context Protocol)
  • FastMCP framework

๐Ÿ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ™ Acknowledgments

  • Built on the Model Context Protocol (MCP) framework
  • Uses FastMCP for efficient server implementation
  • Inspired by the need for comprehensive mathematical tools in AI workflows

๐Ÿ“ž Support

  • Create an issue for bug reports or feature requests
  • Check the Tests/ directory for comprehensive function validation
  • Review Docs/sharkmath_tools_refactor.md for architecture details
  • All 15 consolidated tools with 150+ operations are thoroughly tested and documented

SharkMath MCP - Empowering AI with comprehensive mathematical capabilities through efficient consolidated tools ๐Ÿฆˆ๐Ÿ“Š

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