boltz2-binding-affinity

Predict protein-ligand binding affinity using Boltz-2 model to assess molecular interactions and binding probability for drug discovery.

Best use case

boltz2-binding-affinity is best used when you need a repeatable AI agent workflow instead of a one-off prompt.

Predict protein-ligand binding affinity using Boltz-2 model to assess molecular interactions and binding probability for drug discovery.

Teams using boltz2-binding-affinity should expect a more consistent output, faster repeated execution, less prompt rewriting.

When to use this skill

  • You want a reusable workflow that can be run more than once with consistent structure.

When not to use this skill

  • You only need a quick one-off answer and do not need a reusable workflow.
  • You cannot install or maintain the underlying files, dependencies, or repository context.

Installation

Claude Code / Cursor / Codex

$curl -o ~/.claude/skills/boltz2-binding-affinity/SKILL.md --create-dirs "https://raw.githubusercontent.com/SpectrAI-Initiative/InnoClaw/main/.claude/skills/boltz2-binding-affinity/SKILL.md"

Manual Installation

  1. Download SKILL.md from GitHub
  2. Place it in .claude/skills/boltz2-binding-affinity/SKILL.md inside your project
  3. Restart your AI agent — it will auto-discover the skill

How boltz2-binding-affinity Compares

Feature / Agentboltz2-binding-affinityStandard Approach
Platform SupportNot specifiedLimited / Varies
Context Awareness High Baseline
Installation ComplexityUnknownN/A

Frequently Asked Questions

What does this skill do?

Predict protein-ligand binding affinity using Boltz-2 model to assess molecular interactions and binding probability for drug discovery.

Where can I find the source code?

You can find the source code on GitHub using the link provided at the top of the page.

SKILL.md Source

# Boltz-2 Protein-Ligand Binding Affinity Prediction

## Usage

### 1. MCP Server Definition

```python
import asyncio
import json
from contextlib import AsyncExitStack
from mcp.client.streamable_http import streamablehttp_client
from mcp import ClientSession

class DrugSDAClient:
    """DrugSDA-Model MCP Client"""

    def __init__(self, server_url: str, api_key: str):
        self.server_url = server_url
        self.api_key = api_key
        self.session = None

    async def connect(self):
        """Establish connection and initialize session"""
        print(f"server url: {self.server_url}")
        try:
            self.transport = streamablehttp_client(
                url=self.server_url,
                headers={"SCP-HUB-API-KEY": self.api_key}
            )
            self._stack = AsyncExitStack()
            await self._stack.__aenter__()
            self.read, self.write, self.get_session_id = await self._stack.enter_async_context(self.transport)

            self.session_ctx = ClientSession(self.read, self.write)
            self.session = await self._stack.enter_async_context(self.session_ctx)

            await self.session.initialize()
            session_id = self.get_session_id()

            print(f"✓ connect success")
            return True

        except Exception as e:
            print(f"✗ connect failure: {e}")
            import traceback
            traceback.print_exc()
            return False

    async def disconnect(self):
        """Disconnect from server"""
        try:
            if hasattr(self, '_stack'):
                await self._stack.aclose()
            print("✓ already disconnect")
        except Exception as e:
            print(f"✗ disconnect error: {e}")
    def parse_result(self, result):
        """Parse MCP tool call result"""
        try:
            if hasattr(result, 'content') and result.content:
                content = result.content[0]
                if hasattr(content, 'text'):
                    return json.loads(content.text)
            return str(result)
        except Exception as e:
            return {"error": f"parse error: {e}", "raw": str(result)}
```

### 2. Boltz-2 Binding Affinity Workflow

This workflow predicts protein-ligand binding affinity using the Boltz-2 deep learning model, providing affinity probabilities and 3D complex structures.

**Workflow Steps:**

1. **Prepare Input** - Define protein sequence and SMILES list for ligands
2. **Run Boltz-2 Prediction** - Calculate binding affinity probability for each ligand
3. **Analyze Results** - Extract affinity scores and structure files

**Implementation:**

```python
## Initialize client
client = DrugSDAClient(
    "https://scp.intern-ai.org.cn/api/v1/mcp/3/DrugSDA-Model",
    "<your-api-key>"
)

if not await client.connect():
    print("connection failed")
    exit()

## Input: Protein sequence and ligand SMILES
sequence = 'PIVQNLQGQMVHQCISPRTLNAWVKVVEEKAFSPEVIPMFSALSCGATPQDLNTMLNTVGGHQAAMQMLKETINEEAAEWDRLHPVHAGPIAPGQMREPRGSDIAGTTSTLQEQIGWMTHNPPIPVGEIYKRWIILGLNKIVRMYSPTSILDIRQGPKEPFRDYVDRFYKTLRAEQASQEVKNAATETLLVQNANPDCKTILKALGPGATLEEMMTACQG'
protein = [{'chain': 'A', 'sequence': sequence}]
smiles_list = ['N[C@@H](Cc1ccc(O)cc1)C(=O)O', "CC(C)C1=CC=CC=C1"]

## Execute Boltz-2 binding affinity prediction
result = await client.session.call_tool(
    "boltz_binding_affinity",
    arguments={
        "protein": protein,
        "smiles_list": smiles_list
    }
)

result_data = client.parse_result(result)
boltz_res = result_data["boltz_res"]

## Display results
for i, item in enumerate(boltz_res, 1):
    print(f"{i}. SMILES: {item['smiles']}")
    print(f"   Affinity Probability: {item['affinity_probability']:.4f}")
    print(f"   Structure File: {item['cif_file']}\n")

await client.disconnect()
```

### Tool Descriptions

**DrugSDA-Model Server:**
- `boltz_binding_affinity`: Predict protein-ligand binding affinity using Boltz-2
  - Args:
    - `protein` (list): List of protein chains with sequence information
      - Each chain: `{'chain': str, 'sequence': str}`
    - `smiles_list` (list): List of ligand SMILES strings
  - Returns:
    - `boltz_res` (list): List of binding predictions
      - `smiles` (str): Ligand SMILES string
      - `affinity_probability` (float): Binding affinity probability (0-1)
      - `cif_file` (str): Path to predicted complex structure

### Input/Output

**Input:**
- `protein`: List of protein chains
  - `chain`: Chain identifier (e.g., 'A', 'B')
  - `sequence`: Amino acid sequence in single-letter code
- `smiles_list`: List of SMILES strings for ligand molecules

**Output:**
- List of binding predictions, each containing:
  - `smiles`: Ligand SMILES string
  - `affinity_probability`: Binding probability (0-1, higher is better)
  - `cif_file`: Path to predicted protein-ligand complex structure in CIF format

### Affinity Interpretation

- **Probability > 0.5**: Strong binding likelihood
- **Probability 0.3-0.5**: Moderate binding potential
- **Probability < 0.3**: Weak or no binding expected

### Use Cases

- Virtual screening of compound libraries
- Lead optimization in drug discovery
- Protein-ligand binding mode prediction
- Structure-based drug design
- Comparative binding analysis across ligands

### Performance Notes

- **Execution time**: 30-120 seconds per ligand depending on protein size
- **Protein length**: Best for proteins <1000 amino acids
- **Multiple ligands**: Processes sequentially, allow sufficient time
- **Structure output**: CIF files can be visualized in PyMOL, ChimeraX, or similar tools

Related Skills

binding_site_characterization

370
from SpectrAI-Initiative/InnoClaw

Binding Site Characterization - Characterize binding sites: predict pockets with fpocket and P2Rank, get binding site info from ChEMBL, and visualize. Use this skill for structural biology tasks involving run fpocket pred pocket prank get binding site by id visualize protein. Combines 4 tools from 3 SCP server(s).

affinity_maturation

370
from SpectrAI-Initiative/InnoClaw

Affinity Maturation Pipeline - Affinity maturation: compute binding affinity, predict mutations, compute hydrophilicity, and predict drug-target interaction. Use this skill for antibody engineering tasks involving ComputeAffinityCalculator zero shot sequence prediction ComputeHydrophilicity PredictDrugTargetInteraction. Combines 4 tools from 3 SCP server(s).

wind-site-assessment

370
from SpectrAI-Initiative/InnoClaw

Assess wind energy potential and perform site analysis using atmospheric science calculations.

web_literature_mining

370
from SpectrAI-Initiative/InnoClaw

Scientific Literature Mining - Mine scientific literature: PubMed search, arXiv search, web search, and Tavily deep search. Use this skill for scientific informatics tasks involving pubmed search search literature search web tavily search. Combines 4 tools from 2 SCP server(s).

virus_genomics

370
from SpectrAI-Initiative/InnoClaw

Virus Genomics Analysis - Analyze virus genomics: NCBI virus dataset, annotation, taxonomy, and literature search. Use this skill for virology tasks involving get virus dataset report get virus annotation report get taxonomy search literature. Combines 4 tools from 2 SCP server(s).

virtual_screening

370
from SpectrAI-Initiative/InnoClaw

Virtual Screening Pipeline - Virtual screening: search PubChem by substructure, compute similarity, filter by drug-likeness, and predict binding affinity. Use this skill for drug discovery tasks involving search pubchem by smiles calculate smiles similarity calculate mol drug chemistry boltz binding affinity. Combines 4 tools from 3 SCP server(s).

variant_pathogenicity

370
from SpectrAI-Initiative/InnoClaw

Variant Pathogenicity Assessment - Assess variant pathogenicity: Ensembl VEP prediction, ClinVar lookup, variation details, and gene phenotype associations. Use this skill for clinical genetics tasks involving get vep hgvs clinvar search get variation get phenotype gene. Combines 4 tools from 2 SCP server(s).

variant-population-frequency

370
from SpectrAI-Initiative/InnoClaw

Query gnomAD for variant allele frequency across populations. Uses FAVOR to convert rsID→variant_id first, then queries gnomAD.

variant-pharmacogenomics

370
from SpectrAI-Initiative/InnoClaw

Query PharmGKB (clinPGx) for pharmacogenomic clinical annotations — how a variant affects drug response, dosing, and adverse reactions.

variant-gwas-associations

370
from SpectrAI-Initiative/InnoClaw

Query EBI GWAS Catalog for GWAS statistical associations (p-value, effect size, risk allele) between a variant and traits/diseases.

variant-genomic-location

370
from SpectrAI-Initiative/InnoClaw

Query dbSNP + NCBI Gene to get variant genomic position (chromosome, coordinates, ref/alt alleles, mutation type) and associated gene coordinates.

variant-functional-prediction

370
from SpectrAI-Initiative/InnoClaw

Query FAVOR API for variant functional prediction scores (CADD, SIFT, PolyPhen, REVEL, etc.) and gene annotation.