An MCP server for scRNA-Seq analysis with natural language!
Project description
SCMCP
An MCP server for scRNA-Seq analysis with natural language!
🪩 What can it do?
- IO module like read and write scRNA-Seq data with natural language
- Preprocessing module,like filtering, quality control, normalization, scaling, highly-variable genes, PCA, Neighbors,...
- Tool module, like clustering, differential expression etc.
- Plotting module, like violin, heatmap, dotplot
- cell-cell communication analysis
- Pseudotime analysis
- enrichment analysis
❓ Who is this for?
- Anyone who wants to do scRNA-Seq analysis natural language!
- Agent developers who want to call scanpy's functions for their applications
🌐 Where to use it?
You can use scmcp in most AI clients, plugins, or agent frameworks that support the MCP:
- AI clients, like Cherry Studio
- Plugins, like Cline
- Agent frameworks, like Agno
📚 Documentation
scmcphub's complete documentation is available at https://docs.scmcphub.org
🎬 Demo
A demo showing scRNA-Seq cell cluster analysis in a AI client Cherry Studio using natural language based on scmcp
https://github.com/user-attachments/assets/93a8fcd8-aa38-4875-a147-a5eeff22a559
🏎️ Quickstart
Install
Install from PyPI
pip install scmcp
you can test it by running
scmcp run
run scnapy-mcp locally
Refer to the following configuration in your MCP client:
check path
$ which scmcp
/home/test/bin/scmcp
it has many tools , so it couldn't work if you model context is not large...More time, I recommend it is backend mcp server for scanpy-mcp, liana-mcp,cellrank-mcp, so they can use shared Anndata object.
"mcpServers": {
"scmcp": {
"command": "/home/test/bin/scmcp",
"args": [
"run"
]
}
}
run scmcp remotely
Refer to the following configuration in your MCP client:
run it in your server
scmcp run --transport shttp --port 8000
Then configure your MCP client in local AI client, like this:
"mcpServers": {
"scmcp": {
"url": "http://localhost:8000/mcp"
}
}
Intelligent Tool Selection (Experimental)
SCMCP implements an intelligent tool selection system to optimize performance and reduce token usage.
How it Works
The intelligent tool selection system operates in two phases:
- Search_tool: First identifies the most relevant tools for your analysis
- run_tool: Then runs only the selected tools, reducing token consumption
Usage
- Ensure you have the latest version of scmcp-shared installed:
pip install --upgrade scmcp-shared
- Start the server with intelligent tool selection enabled:
export API_KEY=sk-***
export BASE_URL="https://api.openai.com/v1"
export MODEL="gpt-4o"
scmcp run --transport shttp --port 8000 --tool-mode auto
- Configure your MCP client to connect to the server:
{
"mcpServers": {
"scmcp": {
"url": "http://localhost:8000/mcp"
}
}
}
🤝 Contributing
If you have any questions, welcome to submit an issue, or contact me(hsh-me@outlook.com). Contributions to the code are also welcome!
Citing
If you use scmcp in for your research, please consider citing following works:
Wolf, F., Angerer, P. & Theis, F. SCANPY: large-scale single-cell gene expression data analysis. Genome Biol 19, 15 (2018). https://doi.org/10.1186/s13059-017-1382-0
Dimitrov D., Schäfer P.S.L, Farr E., Rodriguez Mier P., Lobentanzer S., Badia-i-Mompel P., Dugourd A., Tanevski J., Ramirez Flores R.O. and Saez-Rodriguez J. LIANA+ provides an all-in-one framework for cell–cell communication inference. Nat Cell Biol (2024). https://doi.org/10.1038/s41556-024-01469-w
Badia-i-Mompel P., Vélez Santiago J., Braunger J., Geiss C., Dimitrov D., Müller-Dott S., Taus P., Dugourd A., Holland C.H., Ramirez Flores R.O. and Saez-Rodriguez J. 2022. decoupleR: ensemble of computational methods to infer biological activities from omics data. Bioinformatics Advances. https://doi.org/10.1093/bioadv/vbac016
Weiler, P., Lange, M., Klein, M. et al. CellRank 2: unified fate mapping in multiview single-cell data. Nat Methods 21, 1196–1205 (2024). https://doi.org/10.1038/s41592-024-02303-9
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file scmcp-0.4.0.tar.gz.
File metadata
- Download URL: scmcp-0.4.0.tar.gz
- Upload date:
- Size: 32.5 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6b6f9d801542566ca18a41e491dd9a453d6caf255be7fe788d30c059ca525b3a
|
|
| MD5 |
1ed0367412f604c9c01d02aaf112fd50
|
|
| BLAKE2b-256 |
920b0f3d6a5239a8e291a6437eacecfb06b2cd48a7ce5305655caada54e3503c
|
Provenance
The following attestation bundles were made for scmcp-0.4.0.tar.gz:
Publisher:
publish.yml on scmcphub/scmcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
scmcp-0.4.0.tar.gz -
Subject digest:
6b6f9d801542566ca18a41e491dd9a453d6caf255be7fe788d30c059ca525b3a - Sigstore transparency entry: 253564192
- Sigstore integration time:
-
Permalink:
scmcphub/scmcp@90cc88b92318472ac5fa6a3250f3e584dc09588e -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/scmcphub
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@90cc88b92318472ac5fa6a3250f3e584dc09588e -
Trigger Event:
release
-
Statement type:
File details
Details for the file scmcp-0.4.0-py3-none-any.whl.
File metadata
- Download URL: scmcp-0.4.0-py3-none-any.whl
- Upload date:
- Size: 6.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c5c8503070fa478797c2216dbe60a94035e56205113e2da9aa72e6124c014ddc
|
|
| MD5 |
01a043ac52e47b5ce7fa66126d140973
|
|
| BLAKE2b-256 |
3e2676407af9197add9306d43d76a549748d88d9f399e2358b09ce56b275d054
|
Provenance
The following attestation bundles were made for scmcp-0.4.0-py3-none-any.whl:
Publisher:
publish.yml on scmcphub/scmcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
scmcp-0.4.0-py3-none-any.whl -
Subject digest:
c5c8503070fa478797c2216dbe60a94035e56205113e2da9aa72e6124c014ddc - Sigstore transparency entry: 253564197
- Sigstore integration time:
-
Permalink:
scmcphub/scmcp@90cc88b92318472ac5fa6a3250f3e584dc09588e -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/scmcphub
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@90cc88b92318472ac5fa6a3250f3e584dc09588e -
Trigger Event:
release
-
Statement type: