
Linear Regression
STDIOEnd-to-end linear regression model training server using Claude and MCP.
End-to-end linear regression model training server using Claude and MCP.
Welcome to Linear Regression MCP! This project demonstrates an end-to-end machine learning workflow using Claude and the Model Context Protocol (MCP).
Claude can train a Linear Regression model entirely by itself, simply by uploading a CSV file containing the dataset. The system goes through the entire ML model training lifecycle, handling data preprocessing, training, and evaluation (RMSE calculation).
First, clone the repository to your local machine:
git clone https://github.com/HeetVekariya/Linear-Regression-MCP cd Linear-Regression-MCP
uv
:uv
is an extremely fast Python package and project manager, written in Rust. It is essential for managing the server and dependencies in this project.
uv
from here.Once uv is installed, run the following command to install all necessary dependencies:
uv sync
To integrate the server with Claude Desktop, you will need to modify the Claude configuration file. Follow the instructions for your operating system:
code ~/Library/Application\ Support/Claude/claude_desktop_config.json
code $env:AppData\Claude\claude_desktop_config.json
mcpServers
section, and replace the placeholder paths with the absolute paths to your uv
installation and the Linear Regression project directory. It should look like this:{ "mcpServers": { "linear-regression": { "command": "ABSOLUTE/PATH/TO/.local/bin/uv", "args": [ "--directory", "ABSOLUTE/PATH/TO/YOUR-LINEAR-REGRESSION-REPO", "run", "server.py" ] } } }
The following tools are available in this project to help you work with the dataset and train the model:
Tool | Description | Arguments |
---|---|---|
upload_file(path) | Uploads a CSV file and stores it for processing. | path : Absolute path to the CSV file. |
get_columns_info() | Retrieves the column names in the uploaded dataset. | No arguments. |
check_category_columns() | Checks for any categorical columns in the dataset. | No arguments. |
label_encode_categorical_columns() | Label encodes categorical columns into numerical values. | No arguments. |
train_linear_regression_model(output_column) | Trains a linear regression model and calculates RMSE. | output_column : The name of the target column. |
I welcome contributions to this project! Whether it's fixing bugs, adding new features, or improving the documentation, feel free to fork the repository and submit pull requests.
If you have any suggestions or feature requests, open an issue, and I'll be happy to discuss them!