Skip to main content

Add your description here

Project description

SAMtools MCP (Model Control Protocol)

A Model Control Protocol implementation for SAMtools, providing a standardized interface for working with SAM/BAM/CRAM files.

Features

  • View and convert SAM/BAM/CRAM files
  • Sort alignment files
  • Index BAM/CRAM files
  • Generate statistics
  • Merge multiple BAM files
  • Calculate read depth
  • Index FASTA files
  • And more...

Core Capabilities

  • File Format Support: Handle SAM (text), BAM (binary), and CRAM (compressed) alignment files
  • Format Conversion: Convert between SAM, BAM, and CRAM formats seamlessly
  • Region-Specific Analysis: Extract and analyze specific genomic regions
  • Flag-Based Filtering: Filter reads based on SAM flags
  • Performance Optimization: Multi-threaded operations for sorting and merging
  • Statistical Analysis: Generate comprehensive alignment statistics

Tools Overview

Tool Description Key Features
view View and convert alignment files - Format conversion (SAM/BAM/CRAM)
- Region filtering
- Flag-based filtering
- Header manipulation
sort Sort alignment files - Coordinate-based sorting
- Name-based sorting
- Memory per thread control
- Multi-threading support
index Index BAM/CRAM files - BAI index generation
- CSI index support
- CRAM index creation
merge Merge multiple BAM/CRAM files - Multi-file merging
- Thread-enabled processing
- Header reconciliation
depth Calculate read depth - Per-base depth calculation
- Region-specific analysis
- Multi-file support
flagstat Generate alignment statistics - Comprehensive flag statistics
- Quality checks
- Paired-end metrics
idxstats BAM/CRAM index statistics - Reference sequence stats
- Mapped/unmapped counts
- Length information
faidx Index FASTA files - FASTA indexing
- Region extraction
- Sequence retrieval

Installation

Using Docker (Recommended)

The easiest way to use SAMtools MCP is through Docker:

# Pull the Docker image
docker pull nadhir/samtools-mcp:latest

# Run the container
docker run -it --rm nadhir/samtools-mcp:latest

# To process BAM files, mount a volume:
docker run -it --rm -v /path/to/your/bam/files:/data nadhir/samtools-mcp:latest

Local Installation

  1. Clone the repository:
git clone https://github.com/your-username/samtools_mcp.git
cd samtools_mcp
  1. Install dependencies:
pip install uv
uv pip install -r requirements.txt

Configuration

MCP Server Configuration

To configure the MCP server to use the Docker image, add the following to your MCP configuration file:

{
  "servers": {
    "samtools": {
      "type": "docker",
      "image": "nadhir/samtools-mcp:latest",
      "volumes": [
        {
          "source": "/path/to/your/data",
          "target": "/data"
        }
      ]
    }
  }
}

Local MCP Configuration

To configure the MCP to run using uv, add the following to your ~/.cursor/mcp.json:

{
  "samtools_mcp": {
    "command": "uv",
    "args": ["run", "--with", "fastmcp", "fastmcp", "run", "/path/to/samtools_mcp.py"]
  }
}

Replace /path/to/samtools_mcp.py with the actual path to your samtools_mcp.py file.

Usage

Basic Commands

  1. View BAM file:
from samtools_mcp import SamtoolsMCP

mcp = SamtoolsMCP()
result = mcp.view(input_file="/data/example.bam")
  1. Sort BAM file:
result = mcp.sort(input_file="/data/example.bam", output_file="/data/sorted.bam")
  1. Index BAM file:
result = mcp.index(input_file="/data/sorted.bam")

Advanced Usage

  1. View specific region with flags:
result = mcp.view(
    input_file="/data/example.bam",
    region="chr1:1000-2000",
    flags_required="0x2",
    output_format="SAM"
)
  1. Sort by read name:
result = mcp.sort(
    input_file="/data/example.bam",
    output_file="/data/namesorted.bam",
    sort_by_name=True
)
  1. Calculate depth with multiple input files:
result = mcp.depth(
    input_files=["/data/sample1.bam", "/data/sample2.bam"],
    region="chr1:1-1000000"
)

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

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

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mseep_samtools_mcp-0.1.0.tar.gz (3.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mseep_samtools_mcp-0.1.0-py3-none-any.whl (2.9 kB view details)

Uploaded Python 3

File details

Details for the file mseep_samtools_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: mseep_samtools_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 3.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.12

File hashes

Hashes for mseep_samtools_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 d9f7ba1613766790514073beb5df59a903aedc3d07ad1307dd38eadafe6524d4
MD5 34913bf67d7938dfed96199c5c383110
BLAKE2b-256 d5a68a3a42152fd1c85145feebf327ed9a5853167b315dd18245f1b90d04f863

See more details on using hashes here.

File details

Details for the file mseep_samtools_mcp-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mseep_samtools_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 102ad81e0d59e39df65977817a53cfbfb2dc2d5b2a3cf7d8ae3ae0f0a503d60e
MD5 b25aae1bf0b0d6f19dc1172159c0c102
BLAKE2b-256 9c0ba5bd4cdc3d485229b4b6eb97690356e91516c1086fb15ef8c030d4e29cfa

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page