circuit-sim-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@circuit-sim-mcpCreate a voltage divider with R1=1k, R2=2k, V1=5V and run DC analysis"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Circuit Simulation MCP Server
A Model Context Protocol (MCP) server that provides circuit simulation capabilities using PySpice. This server allows you to create, simulate, and analyze electronic circuits through a simple tool-based interface.
✅ System Status
Fully Tested & Production Ready - PySpice 1.5 + ngspice 44 compatibility verified on ARM64/Apple Silicon macOS.
100% Test Coverage: All simulation functions validated and working
Platform Verified: macOS ARM64 with Homebrew ngspice 44 installation
Component Support: Resistors, capacitors, inductors, voltage/current sources, diodes, LEDs, transistors
Analysis Types: DC, AC, and Transient analysis all fully functional
Related MCP server: ltspice-mcp
Features
Circuit Creation: Define circuits with various components (resistors, capacitors, inductors, voltage/current sources, diodes, transistors)
Multiple Analysis Types:
DC Analysis (steady-state)
AC Analysis (frequency response)
Transient Analysis (time-domain)
Circuit Management: List circuits, get detailed information, export data
Visualization: Generate plots of simulation results
SPICE Integration: Uses PySpice for accurate circuit simulation
Built-in Debugging: Comprehensive error reporting and circuit validation
Installation
Prerequisites
Python 3.8+
Ngspice: The underlying SPICE simulator
macOS (Recommended - Tested Configuration):
# Install ngspice with ARM64 compatibility /opt/homebrew/bin/brew install ngspice libngspiceUbuntu/Debian:
sudo apt-get install ngspiceWindows: Download from ngspice website
Install the Package
# Clone the repository
git clone <repository-url>
cd circuit-sim-mcp
# Install in development mode
pip install -e .Environment Setup (macOS ARM64)
For optimal compatibility on Apple Silicon Macs, set up the library path:
export DYLD_LIBRARY_PATH="/opt/homebrew/Cellar/libngspice/44.2/lib:$DYLD_LIBRARY_PATH"Add this to your shell profile (.zshrc, .bash_profile) for persistence.
Dependencies
The package will automatically install:
mcp- Model Context Protocol Python SDKpydantic- Data validationnumpy- Numerical computationsmatplotlib- Plotting (optional)
Usage
Running the MCP Server
The server can be run as a standalone MCP server:
python -m circuit_sim_mcpUsing with MCP Clients
Configure your MCP client to use this server:
{
"mcpServers": {
"circuit-sim": {
"command": "python3",
"args": ["-m", "circuit_sim_mcp"],
"env": {
"DYLD_LIBRARY_PATH": "/opt/homebrew/Cellar/libngspice/44.2/lib"
}
}
}
}Note: The DYLD_LIBRARY_PATH environment variable is crucial for ARM64/Apple Silicon compatibility with ngspice 44.
Available Tools
create_circuit- Create a new circuit with components and validationvalidate_circuit- Check circuit for common issues and get recommendationssimulate_dc- Perform DC analysis (steady-state voltages)simulate_ac- Perform AC analysis (frequency response)simulate_transient- Perform transient analysis (time-domain behavior)plot_results- Generate professional plots and visualizationsexport_data- Export simulation data (JSON, CSV, TXT formats)list_circuits- List all created circuitsget_circuit_info- Get detailed circuit information and netlistscreate_example_circuit- Create guaranteed working example circuits for learningdebug_simulation- Debug simulation failures with detailed SPICE outputlist_available_models- Show available component models and parameters
Example
Here's a simple voltage divider example:
import asyncio
from circuit_sim_mcp.server_basic import CircuitSimServer
async def main():
sim_server = CircuitSimServer()
server = sim_server.server
# Create a voltage divider circuit
components = [
{
"component_type": "voltage_source",
"name": "V1",
"voltage": 10.0,
"nodes": ["vin", "gnd"],
"source_type": "DC"
},
{
"component_type": "resistor",
"name": "R1",
"resistance": 1000.0,
"nodes": ["vin", "vout"]
},
{
"component_type": "resistor",
"name": "R2",
"resistance": 1000.0,
"nodes": ["vout", "gnd"]
}
]
# Create the circuit
result = await server.call_tool("create_circuit", {
"name": "voltage_divider",
"components": components
})
# Perform DC analysis
dc_result = await server.call_tool("simulate_dc", {
"circuit_name": "voltage_divider",
"output_nodes": ["vin", "vout", "gnd"]
})
print(f"DC Analysis: {dc_result}")
if __name__ == "__main__":
asyncio.run(main())See examples/simple_voltage_divider.py for a complete working example.
Component Types
Supported Components
Resistor:
{"component_type": "resistor", "name": "R1", "resistance": 1000.0, "nodes": ["n1", "n2"]}Capacitor:
{"component_type": "capacitor", "name": "C1", "capacitance": 1e-6, "nodes": ["n1", "n2"]}Inductor:
{"component_type": "inductor", "name": "L1", "inductance": 1e-3, "nodes": ["n1", "n2"]}Voltage Source:
{"component_type": "voltage_source", "name": "V1", "voltage": 5.0, "nodes": ["n1", "n2"], "source_type": "DC"}Current Source:
{"component_type": "current_source", "name": "I1", "current": 1.0, "nodes": ["n1", "n2"], "source_type": "DC"}Diode:
{"component_type": "diode", "name": "D1", "nodes": ["n1", "n2"], "model": "D"}LED:
{"component_type": "diode", "name": "LED1", "nodes": ["anode", "cathode"], "model": "LED"}Transistor:
{"component_type": "transistor", "name": "Q1", "transistor_type": "npn", "nodes": ["collector", "base", "emitter"], "model": "2N2222"}
Alternative Value Fields
Components also accept "value" as an alternative to specific field names:
Resistor:
"value": 1000(same as"resistance": 1000)Capacitor:
"value": 1e-6(same as"capacitance": 1e-6)Sources:
"value": 5.0(same as"voltage": 5.0or"current": 1.0)
Node Names
⚠️ Important: Node names cannot be Python keywords. Use descriptive names like:
vin,vout(instead ofin,out)vcc,vdd,gnd(instead ofclass,def,if)
Branch Structure
This repository has two main branches with different feature sets:
🌟 main branch (Current - Basic Version)
Purpose: Core circuit simulation functionality
Target: Users who need basic circuit analysis
Features: Essential circuit creation, simulation (DC/AC/Transient), and data export
Complexity: Simple, focused, easy to understand and extend
🚀 advanced-features branch
Purpose: Full-featured version with AI-powered analysis
Target: Professional users and complex circuit design
Features: Everything in main + intelligent datasheet prompting, complexity analysis, datasheet-based components
Complexity: Advanced features for sophisticated circuit analysis
To access advanced features:
git checkout advanced-featuresArchitecture
server_basic.py: Basic MCP server implementation using FastMCPcircuit.py: Circuit representation and component definitionssimulator.py: PySpice integration and simulation engine__main__.py: Entry point for running the server
Development
Running Tests
python -m pytest tests/Adding New Components
Add the component class to
circuit.pyUpdate the
Component.from_dict()methodAdd netlist generation in
Circuit._component_to_netlist()
Troubleshooting
PySpice Version Compatibility
Fixed in this version: PySpice 1.5 is patched to work with ngspice 44. If you encounter version compatibility issues:
Verify ngspice version:
ngspice --versionshould show version 44.xCheck PySpice patching: Our system automatically handles PySpice 1.5 compatibility with ngspice 44
For fresh installations: Follow the macOS ARM64 setup above
Library Path Issues (macOS ARM64)
If you see library loading errors:
# Set the correct library path for ARM64 Homebrew ngspice
export DYLD_LIBRARY_PATH="/opt/homebrew/Cellar/libngspice/44.2/lib:$DYLD_LIBRARY_PATH"PySpice Import Errors
If you get PySpice import errors:
Ensure ngspice is installed and in your PATH
Check architecture compatibility (x86_64 vs arm64)
For ARM64 Macs, use the Homebrew paths shown above
Reinstall dependencies if needed:
pip uninstall numpy PySpice pip install numpy PySpice
Simulation Failures
If simulations fail:
Use the debug tools: Run
debug_simulationtool to get detailed SPICE outputCheck circuit validation: Use
validate_circuittool to identify common issuesVerify ground connections: Ensure your circuit has a 'gnd' or '0' node
Check component values: Extreme values can cause convergence issues
Advanced Features
For advanced features like intelligent datasheet prompting, circuit complexity analysis, and datasheet-based components, check out the advanced-features branch:
git checkout advanced-featuresLicense
MIT License - see LICENSE file for details.
Contributing
Fork the repository
Create a feature branch
Make your changes
Add tests
Submit a pull request
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/ghensley/circuit-sim-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server