scvi-tools-mcp 0.1.0__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- scvi_tools_mcp-0.1.0/.gitignore +18 -0
- scvi_tools_mcp-0.1.0/LICENSE +30 -0
- scvi_tools_mcp-0.1.0/PKG-INFO +151 -0
- scvi_tools_mcp-0.1.0/README.md +126 -0
- scvi_tools_mcp-0.1.0/docs/conf.py +19 -0
- scvi_tools_mcp-0.1.0/docs/faq.md +42 -0
- scvi_tools_mcp-0.1.0/docs/index.md +12 -0
- scvi_tools_mcp-0.1.0/docs/installation.md +67 -0
- scvi_tools_mcp-0.1.0/docs/references.bib +379 -0
- scvi_tools_mcp-0.1.0/docs/references.md +69 -0
- scvi_tools_mcp-0.1.0/docs/superpowers/plans/2026-06-09-scvi-tools-mcp.md +2849 -0
- scvi_tools_mcp-0.1.0/docs/superpowers/specs/2026-06-09-scvi-tools-mcp-design.md +310 -0
- scvi_tools_mcp-0.1.0/pyproject.toml +56 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/__init__.py +1 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/.last_synced_version +1 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/.gitkeep +0 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/cellassign.md +132 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/contrastivevi.md +127 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/gimvi.md +112 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/linearscvi.md +155 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/mrvi.md +71 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/multivi.md +190 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/peakvi.md +151 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/scanvi.md +172 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/scbasset.md +128 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/scvi.md +182 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/solo.md +124 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/stereoscope.md +95 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/sysvi.md +101 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/totalvi.md +188 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/api/velovi.md +106 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/background/counterfactual_prediction.md +42 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/background/differential_abundance.md +52 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/background/differential_expression.md +65 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/background/transfer_learning.md +60 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/background/variational_inference.md +57 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/faq/.gitkeep +0 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/faq/discourse_threads.md +93 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/faq/github_issues.md +178 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/.gitkeep +0 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/amortizedlda.md +76 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/autozi.md +62 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/cellassign.md +296 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/contrastivevi.md +158 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/cytovi.md +133 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/decipher.md +24 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/destvi.md +86 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/diagvi.md +141 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/gimvi.md +138 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/linearscvi.md +193 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/methylanvi.md +65 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/methylvi.md +87 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/mrvi.md +225 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/multivi.md +418 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/peakvi.md +311 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/poissonvi.md +24 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/resolvi.md +108 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/scanvi.md +494 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/scar.md +48 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/scbasset.md +163 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/scvi.md +385 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/scviva.md +82 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/solo.md +186 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/stereoscope.md +287 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/sysvi.md +260 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/tangram.md +30 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/totalanvi.md +52 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/totalvi.md +413 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/models/velovi.md +132 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/cellassign-annotation.md +354 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/destvi-deconvolution.md +291 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/mrvi-multisample.md +296 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/multivi-multimodal-analysis.md +539 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/peakvi-accessibility-analysis.md +540 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/perturbseq-contrastive-analysis.md +416 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/poissonvi-fragment-analysis.md +628 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_atac_peakvi.md +372 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_batch_correction_sysvi.md +402 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_citeseq_totalvi.md +420 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_data_preparation.md +276 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_environment_setup.md +264 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_label_transfer.md +358 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_multiome_multivi.md +359 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_rna_velocity_velovi.md +368 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_scarches_mapping.md +388 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_scrna_integration.md +397 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_spatial_deconvolution.md +410 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/ref_troubleshooting.md +426 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/resolvi-spatial-denoising.md +261 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/scanvi-label-transfer.md +333 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/scanvi-seed-labeling.md +347 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/scbasset-batch-correction.md +715 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/scbasset-sequence-analysis.md +729 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/scvi-dataloader.md +403 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/scvi-integration.md +256 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/scvi-tools-plugin.md +157 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/scviva-environment-modeling.md +289 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/spatial-transcriptomics-scvi.md +352 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/stereoscope-deconvolution.md +314 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/tangram-spatial-mapping.md +279 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/totalvi-citeseq-analysis.md +588 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/skills/totalvi-reference-mapping.md +480 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/.gitkeep +0 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/atac/PeakVI.md +188 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/atac/PoissonVI.md +229 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/atac/scbasset.md +220 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/atac/scbasset_batch.md +215 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/custom_dl/Tahoe100_mrVI_lamin.md +393 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/custom_dl/ann_collection.md +360 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/custom_dl/lamin.md +518 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/custom_dl/tiledb.md +645 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/cytometry/CytoVI_advanced_tutorial.md +328 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/cytometry/CytoVI_batch_correction_tutorial.md +306 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/dev/data_tutorial.md +456 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/dev/model_user_guide.md +506 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/dev/module_user_guide.md +381 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/hub/Tahoe100.md +431 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/hub/cellxgene_census_model.md +381 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/hub/query_hlca_knn.md +314 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/hub/scvi_hub_intro_and_download.md +216 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/hub/scvi_hub_upload_and_large_files.md +153 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/multimodal/DiagVI_spatial_proteomics.md +602 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/multimodal/DiagVI_spatial_transcriptomics.md +627 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/multimodal/MultiVI_tutorial.md +267 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/multimodal/cite_scrna_integration_w_totalVI.md +226 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/multimodal/scarches_scvi_tools.md +597 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/multimodal/totalVI.md +355 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/multimodal/totalVI_reference_mapping.md +360 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/quick_start/api_overview.md +439 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/quick_start/api_overview_jax.md +383 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/quick_start/api_overview_mlx.md +378 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/quick_start/data_loading.md +229 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/r/DestVI_in_R.md +222 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/r/api_overview_in_R.md +275 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/r/peakvi_in_R.md +370 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/r/python_in_R.md +144 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/r/scvi_in_R.md +232 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/r/totalvi_in_R.md +157 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scbs/MethylVI_batch.md +167 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/AutoZI_tutorial.md +169 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/MrVI_tutorial.md +344 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/Tahoe100_mrVI.md +373 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/amortized_lda.md +175 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/cellassign_tutorial.md +262 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/contrastiveVI_tutorial.md +149 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/decipher_tutorial.md +126 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/harmonization.md +202 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/linear_decoder.md +195 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/scVI_DE_worm.md +349 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/scanvi_fix.md +362 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/seed_labeling.md +269 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/sysVI.md +479 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/tabula_muris.md +305 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/scrna/velovi.md +161 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/spatial/DestVI_tutorial.md +349 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/spatial/cell2location_lymph_node_spatial_tutorial.md +423 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/spatial/gimvi_tutorial.md +213 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/spatial/resolVI_tutorial.md +294 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/spatial/scVIVA_tutorial.md +420 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/spatial/stereoscope_heart_LV_tutorial.md +240 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/spatial/tangram_scvi_tools.md +210 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/use_cases/Tahoe100_standalone.md +144 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/use_cases/autotune_scvi.md +300 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/use_cases/interpretability.md +409 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/use_cases/minification.md +265 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/use_cases/multiGPU.md +206 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/tutorials/use_cases/preprocessing.md +524 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/.gitkeep +0 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/custom_dataloaders.md +170 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/downstream_analysis_tasks.md +60 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/hyper_parameters_tuning.md +75 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/index.md +252 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/llm_assisted_analysis.md +146 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/multi_gpu_training.md +76 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/saving_and_loading_models.md +16 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/scvi_criticism.md +32 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/training_configuration.md +58 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/knowledge/user_guide/using_callbacks.md +80 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/main.py +9 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/mcp.py +21 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/tools/__init__.py +0 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/tools/_api_reference.py +93 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/tools/_constants.py +35 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/tools/_data_prep.py +174 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/tools/_model_guidance.py +158 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/tools/_troubleshooting.py +220 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/tools/_tutorials.py +159 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/tools/_workflows.py +287 -0
- scvi_tools_mcp-0.1.0/src/scvi_tools_mcp/tools/utils.py +57 -0
- scvi_tools_mcp-0.1.0/tests/__init__.py +0 -0
- scvi_tools_mcp-0.1.0/tests/conftest.py +55 -0
- scvi_tools_mcp-0.1.0/tests/fixtures/knowledge/faq/github_issues.md +5 -0
- scvi_tools_mcp-0.1.0/tests/fixtures/knowledge/models/scvi.md +3 -0
- scvi_tools_mcp-0.1.0/tests/fixtures/sample_notebook.ipynb +55 -0
- scvi_tools_mcp-0.1.0/tests/test_scripts.py +42 -0
- scvi_tools_mcp-0.1.0/tests/test_tools.py +233 -0
- scvi_tools_mcp-0.1.0/tests/test_utils.py +90 -0
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
BSD 3-Clause License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2026, Yosef Lab, Weizmann Institute of Science
|
|
4
|
+
|
|
5
|
+
All rights reserved.
|
|
6
|
+
|
|
7
|
+
Redistribution and use in source and binary forms, with or without
|
|
8
|
+
modification, are permitted provided that the following conditions are met:
|
|
9
|
+
|
|
10
|
+
1. Redistributions of source code must retain the above copyright notice, this
|
|
11
|
+
list of conditions and the following disclaimer.
|
|
12
|
+
|
|
13
|
+
2. Redistributions in binary form must reproduce the above copyright notice,
|
|
14
|
+
this list of conditions and the following disclaimer in the documentation
|
|
15
|
+
and/or other materials provided with the distribution.
|
|
16
|
+
|
|
17
|
+
3. Neither the name of the copyright holder nor the names of its
|
|
18
|
+
contributors may be used to endorse or promote products derived from
|
|
19
|
+
this software without specific prior written permission.
|
|
20
|
+
|
|
21
|
+
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
22
|
+
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
23
|
+
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
24
|
+
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
|
25
|
+
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
26
|
+
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
27
|
+
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
28
|
+
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
29
|
+
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
30
|
+
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
|
+
Name: scvi-tools-mcp
|
|
3
|
+
Version: 0.1.0
|
|
4
|
+
Summary: MCP server for scvi-tools - deep probabilistic analysis of single-cell omics data
|
|
5
|
+
License: MIT
|
|
6
|
+
License-File: LICENSE
|
|
7
|
+
Requires-Python: >=3.11
|
|
8
|
+
Requires-Dist: fastmcp>=3.0
|
|
9
|
+
Requires-Dist: pydantic>=2.0
|
|
10
|
+
Provides-Extra: dev
|
|
11
|
+
Requires-Dist: jupyter; extra == 'dev'
|
|
12
|
+
Requires-Dist: nbconvert>=7.0; extra == 'dev'
|
|
13
|
+
Requires-Dist: pre-commit; extra == 'dev'
|
|
14
|
+
Requires-Dist: pytest-asyncio>=0.21; extra == 'dev'
|
|
15
|
+
Requires-Dist: pytest>=7.0; extra == 'dev'
|
|
16
|
+
Requires-Dist: requests>=2.28; extra == 'dev'
|
|
17
|
+
Requires-Dist: ruff>=0.1; extra == 'dev'
|
|
18
|
+
Provides-Extra: docs
|
|
19
|
+
Requires-Dist: furo>=2023.0; extra == 'docs'
|
|
20
|
+
Requires-Dist: myst-parser>=2.0; extra == 'docs'
|
|
21
|
+
Requires-Dist: sphinx>=7.0; extra == 'docs'
|
|
22
|
+
Provides-Extra: scvi
|
|
23
|
+
Requires-Dist: scvi-tools>=1.0; extra == 'scvi'
|
|
24
|
+
Description-Content-Type: text/markdown
|
|
25
|
+
|
|
26
|
+
# scvi-tools-mcp
|
|
27
|
+
|
|
28
|
+
An MCP (Model Context Protocol) server that gives LLMs structured access to [scvi-tools](https://scvi-tools.org)
|
|
29
|
+
knowledge: model documentation, tutorials, API reference, workflow templates, and community FAQ.
|
|
30
|
+
|
|
31
|
+
No runtime model execution — pure knowledge layer. Works with Claude Desktop, Cursor, and any MCP-compatible client.
|
|
32
|
+
|
|
33
|
+
______________________________________________________________________
|
|
34
|
+
|
|
35
|
+
## Quick Start
|
|
36
|
+
|
|
37
|
+
### Claude Desktop
|
|
38
|
+
|
|
39
|
+
Add to `~/Library/Application Support/Claude/claude_desktop_config.json`:
|
|
40
|
+
|
|
41
|
+
```json
|
|
42
|
+
{
|
|
43
|
+
"mcpServers": {
|
|
44
|
+
"scvi-tools": {
|
|
45
|
+
"command": "uvx",
|
|
46
|
+
"args": ["scvi-tools-mcp"]
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
### Cursor / other clients
|
|
53
|
+
|
|
54
|
+
```json
|
|
55
|
+
{ "command": "uvx", "args": ["scvi-tools-mcp"] }
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
### Local install
|
|
59
|
+
|
|
60
|
+
```bash
|
|
61
|
+
pip install scvi-tools-mcp
|
|
62
|
+
scvi-tools-mcp
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
______________________________________________________________________
|
|
66
|
+
|
|
67
|
+
## Tools
|
|
68
|
+
|
|
69
|
+
| Tool | Description |
|
|
70
|
+
| ---------------------------- | ------------------------------------------------------ |
|
|
71
|
+
| `recommend_model` | Rank models by task and data type — start here |
|
|
72
|
+
| `get_model_overview` | Full model description, use cases, inputs, outputs |
|
|
73
|
+
| `get_model_parameters` | Key `__init__` and `train()` parameters with defaults |
|
|
74
|
+
| `get_setup_anndata_guide` | Exact `setup_anndata()` call + required obs/var fields |
|
|
75
|
+
| `validate_data_requirements` | Pass/fail checklist for your AnnData against a model |
|
|
76
|
+
| `list_tutorials` | Browse tutorials by category |
|
|
77
|
+
| `get_tutorial` | Paginated tutorial content (code + prose, no outputs) |
|
|
78
|
+
| `search_tutorials` | Keyword search across all tutorials |
|
|
79
|
+
| `get_api_reference` | Signature + docstring for any public class or function |
|
|
80
|
+
| `search_api` | Search public symbols by keyword |
|
|
81
|
+
| `get_workflow_template` | Step-by-step code template for an analysis task |
|
|
82
|
+
| `get_downstream_guide` | Guide for DE, clustering, embedding, label transfer |
|
|
83
|
+
| `get_faq` | Curated FAQ from docs, GitHub issues, and Discourse |
|
|
84
|
+
| `search_knowledge` | Cross-search all knowledge (catch-all) |
|
|
85
|
+
|
|
86
|
+
______________________________________________________________________
|
|
87
|
+
|
|
88
|
+
## Knowledge Sources
|
|
89
|
+
|
|
90
|
+
All knowledge is baked into the package as Markdown files at build time. No network calls at tool-call time.
|
|
91
|
+
|
|
92
|
+
| Directory | Content |
|
|
93
|
+
| ------------------------------------ | --------------------------------------------------------- |
|
|
94
|
+
| `knowledge/models/` | One `.md` per model — description, use case, parameters |
|
|
95
|
+
| `knowledge/tutorials/` | 60+ tutorials converted from `.ipynb` (code + prose only) |
|
|
96
|
+
| `knowledge/api/` | Extracted class signatures and docstrings |
|
|
97
|
+
| `knowledge/user_guide/` | Narrative documentation from the scvi-tools user guide |
|
|
98
|
+
| `knowledge/faq/github_issues.md` | Top GitHub issues snapshot |
|
|
99
|
+
| `knowledge/faq/discourse_threads.md` | Discourse forum thread snapshot |
|
|
100
|
+
|
|
101
|
+
______________________________________________________________________
|
|
102
|
+
|
|
103
|
+
## Knowledge Refresh (CI)
|
|
104
|
+
|
|
105
|
+
Three monthly GitHub Actions jobs keep knowledge current — each opens a PR if a diff is found:
|
|
106
|
+
|
|
107
|
+
| Workflow | Schedule | What it does |
|
|
108
|
+
| --------------------------- | ------------ | ----------------------------------------------------------- |
|
|
109
|
+
| `refresh_knowledge.yaml` | 1st of month | Re-scrapes GitHub issues + Discourse threads |
|
|
110
|
+
| `sync_tutorials.yaml` | 1st of month | Fetches new `.ipynb` from scvi-tools, converts to `.md` |
|
|
111
|
+
| `sync_model_knowledge.yaml` | 1st of month | Checks CHANGELOG, regenerates model docs for changed models |
|
|
112
|
+
|
|
113
|
+
All workflows also support `workflow_dispatch` for manual runs.
|
|
114
|
+
|
|
115
|
+
______________________________________________________________________
|
|
116
|
+
|
|
117
|
+
## Development
|
|
118
|
+
|
|
119
|
+
```bash
|
|
120
|
+
git clone https://github.com/ori-kron-wis/scvi-tools-mcp
|
|
121
|
+
cd scvi-tools-mcp
|
|
122
|
+
pip install -e ".[dev]"
|
|
123
|
+
pytest
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
### Rebuild knowledge manually
|
|
127
|
+
|
|
128
|
+
```bash
|
|
129
|
+
# Convert tutorials from a local scvi-tools checkout
|
|
130
|
+
python scripts/convert_notebooks.py /path/to/scvi-tools/docs/tutorials/notebooks \
|
|
131
|
+
src/scvi_tools_mcp/knowledge/tutorials
|
|
132
|
+
|
|
133
|
+
# Extract API docs (requires scvi-tools installed)
|
|
134
|
+
pip install -e ".[scvi]"
|
|
135
|
+
python scripts/extract_api_docs.py
|
|
136
|
+
|
|
137
|
+
# Re-scrape external knowledge
|
|
138
|
+
python scripts/scrape_external.py
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
### Adding a new model
|
|
142
|
+
|
|
143
|
+
1. Run `scripts/extract_api_docs.py` after updating scvi-tools.
|
|
144
|
+
1. Add the model name to `MODEL_NAMES` in `src/scvi_tools_mcp/tools/_constants.py`.
|
|
145
|
+
1. Add requirements to `MODEL_REQUIREMENTS` in `_data_prep.py` if needed.
|
|
146
|
+
|
|
147
|
+
______________________________________________________________________
|
|
148
|
+
|
|
149
|
+
## License
|
|
150
|
+
|
|
151
|
+
MIT
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
# scvi-tools-mcp
|
|
2
|
+
|
|
3
|
+
An MCP (Model Context Protocol) server that gives LLMs structured access to [scvi-tools](https://scvi-tools.org)
|
|
4
|
+
knowledge: model documentation, tutorials, API reference, workflow templates, and community FAQ.
|
|
5
|
+
|
|
6
|
+
No runtime model execution — pure knowledge layer. Works with Claude Desktop, Cursor, and any MCP-compatible client.
|
|
7
|
+
|
|
8
|
+
______________________________________________________________________
|
|
9
|
+
|
|
10
|
+
## Quick Start
|
|
11
|
+
|
|
12
|
+
### Claude Desktop
|
|
13
|
+
|
|
14
|
+
Add to `~/Library/Application Support/Claude/claude_desktop_config.json`:
|
|
15
|
+
|
|
16
|
+
```json
|
|
17
|
+
{
|
|
18
|
+
"mcpServers": {
|
|
19
|
+
"scvi-tools": {
|
|
20
|
+
"command": "uvx",
|
|
21
|
+
"args": ["scvi-tools-mcp"]
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
### Cursor / other clients
|
|
28
|
+
|
|
29
|
+
```json
|
|
30
|
+
{ "command": "uvx", "args": ["scvi-tools-mcp"] }
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
### Local install
|
|
34
|
+
|
|
35
|
+
```bash
|
|
36
|
+
pip install scvi-tools-mcp
|
|
37
|
+
scvi-tools-mcp
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
______________________________________________________________________
|
|
41
|
+
|
|
42
|
+
## Tools
|
|
43
|
+
|
|
44
|
+
| Tool | Description |
|
|
45
|
+
| ---------------------------- | ------------------------------------------------------ |
|
|
46
|
+
| `recommend_model` | Rank models by task and data type — start here |
|
|
47
|
+
| `get_model_overview` | Full model description, use cases, inputs, outputs |
|
|
48
|
+
| `get_model_parameters` | Key `__init__` and `train()` parameters with defaults |
|
|
49
|
+
| `get_setup_anndata_guide` | Exact `setup_anndata()` call + required obs/var fields |
|
|
50
|
+
| `validate_data_requirements` | Pass/fail checklist for your AnnData against a model |
|
|
51
|
+
| `list_tutorials` | Browse tutorials by category |
|
|
52
|
+
| `get_tutorial` | Paginated tutorial content (code + prose, no outputs) |
|
|
53
|
+
| `search_tutorials` | Keyword search across all tutorials |
|
|
54
|
+
| `get_api_reference` | Signature + docstring for any public class or function |
|
|
55
|
+
| `search_api` | Search public symbols by keyword |
|
|
56
|
+
| `get_workflow_template` | Step-by-step code template for an analysis task |
|
|
57
|
+
| `get_downstream_guide` | Guide for DE, clustering, embedding, label transfer |
|
|
58
|
+
| `get_faq` | Curated FAQ from docs, GitHub issues, and Discourse |
|
|
59
|
+
| `search_knowledge` | Cross-search all knowledge (catch-all) |
|
|
60
|
+
|
|
61
|
+
______________________________________________________________________
|
|
62
|
+
|
|
63
|
+
## Knowledge Sources
|
|
64
|
+
|
|
65
|
+
All knowledge is baked into the package as Markdown files at build time. No network calls at tool-call time.
|
|
66
|
+
|
|
67
|
+
| Directory | Content |
|
|
68
|
+
| ------------------------------------ | --------------------------------------------------------- |
|
|
69
|
+
| `knowledge/models/` | One `.md` per model — description, use case, parameters |
|
|
70
|
+
| `knowledge/tutorials/` | 60+ tutorials converted from `.ipynb` (code + prose only) |
|
|
71
|
+
| `knowledge/api/` | Extracted class signatures and docstrings |
|
|
72
|
+
| `knowledge/user_guide/` | Narrative documentation from the scvi-tools user guide |
|
|
73
|
+
| `knowledge/faq/github_issues.md` | Top GitHub issues snapshot |
|
|
74
|
+
| `knowledge/faq/discourse_threads.md` | Discourse forum thread snapshot |
|
|
75
|
+
|
|
76
|
+
______________________________________________________________________
|
|
77
|
+
|
|
78
|
+
## Knowledge Refresh (CI)
|
|
79
|
+
|
|
80
|
+
Three monthly GitHub Actions jobs keep knowledge current — each opens a PR if a diff is found:
|
|
81
|
+
|
|
82
|
+
| Workflow | Schedule | What it does |
|
|
83
|
+
| --------------------------- | ------------ | ----------------------------------------------------------- |
|
|
84
|
+
| `refresh_knowledge.yaml` | 1st of month | Re-scrapes GitHub issues + Discourse threads |
|
|
85
|
+
| `sync_tutorials.yaml` | 1st of month | Fetches new `.ipynb` from scvi-tools, converts to `.md` |
|
|
86
|
+
| `sync_model_knowledge.yaml` | 1st of month | Checks CHANGELOG, regenerates model docs for changed models |
|
|
87
|
+
|
|
88
|
+
All workflows also support `workflow_dispatch` for manual runs.
|
|
89
|
+
|
|
90
|
+
______________________________________________________________________
|
|
91
|
+
|
|
92
|
+
## Development
|
|
93
|
+
|
|
94
|
+
```bash
|
|
95
|
+
git clone https://github.com/ori-kron-wis/scvi-tools-mcp
|
|
96
|
+
cd scvi-tools-mcp
|
|
97
|
+
pip install -e ".[dev]"
|
|
98
|
+
pytest
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
### Rebuild knowledge manually
|
|
102
|
+
|
|
103
|
+
```bash
|
|
104
|
+
# Convert tutorials from a local scvi-tools checkout
|
|
105
|
+
python scripts/convert_notebooks.py /path/to/scvi-tools/docs/tutorials/notebooks \
|
|
106
|
+
src/scvi_tools_mcp/knowledge/tutorials
|
|
107
|
+
|
|
108
|
+
# Extract API docs (requires scvi-tools installed)
|
|
109
|
+
pip install -e ".[scvi]"
|
|
110
|
+
python scripts/extract_api_docs.py
|
|
111
|
+
|
|
112
|
+
# Re-scrape external knowledge
|
|
113
|
+
python scripts/scrape_external.py
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
### Adding a new model
|
|
117
|
+
|
|
118
|
+
1. Run `scripts/extract_api_docs.py` after updating scvi-tools.
|
|
119
|
+
1. Add the model name to `MODEL_NAMES` in `src/scvi_tools_mcp/tools/_constants.py`.
|
|
120
|
+
1. Add requirements to `MODEL_REQUIREMENTS` in `_data_prep.py` if needed.
|
|
121
|
+
|
|
122
|
+
______________________________________________________________________
|
|
123
|
+
|
|
124
|
+
## License
|
|
125
|
+
|
|
126
|
+
MIT
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
project = "scvi-tools-mcp"
|
|
2
|
+
author = "YosefLab"
|
|
3
|
+
copyright = "2024, YosefLab"
|
|
4
|
+
|
|
5
|
+
extensions = [
|
|
6
|
+
"myst_parser",
|
|
7
|
+
"sphinx.ext.autodoc",
|
|
8
|
+
"sphinx.ext.napoleon",
|
|
9
|
+
]
|
|
10
|
+
|
|
11
|
+
source_suffix = {
|
|
12
|
+
".rst": "restructuredtext",
|
|
13
|
+
".md": "markdown",
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
html_theme = "furo"
|
|
17
|
+
html_title = "scvi-tools MCP"
|
|
18
|
+
|
|
19
|
+
exclude_patterns = ["superpowers"]
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
# Frequently asked questions
|
|
2
|
+
|
|
3
|
+
Don't see what you're looking for here? Check the
|
|
4
|
+
[Discourse](https://discourse.scverse.org/c/help/scvi-tools/) or use `search_knowledge` in the MCP server.
|
|
5
|
+
|
|
6
|
+
## Why doesn't the MCP server run my model?
|
|
7
|
+
|
|
8
|
+
By design — this is a **knowledge-only** server. It returns documentation, code templates, and
|
|
9
|
+
guidance. To actually train a model, install scvi-tools and run the code that the server provides.
|
|
10
|
+
|
|
11
|
+
## How do I keep the knowledge base up to date?
|
|
12
|
+
|
|
13
|
+
Three monthly GitHub Actions jobs handle this automatically and open PRs when diffs are found:
|
|
14
|
+
|
|
15
|
+
- `refresh_knowledge.yaml` — re-scrapes GitHub issues + Discourse
|
|
16
|
+
- `sync_tutorials.yaml` — syncs tutorial notebooks from scvi-tools
|
|
17
|
+
- `sync_model_knowledge.yaml` — updates model docs from the scvi-tools CHANGELOG
|
|
18
|
+
|
|
19
|
+
You can also trigger them manually via `workflow_dispatch` or run the scripts locally:
|
|
20
|
+
|
|
21
|
+
```bash
|
|
22
|
+
python scripts/scrape_external.py
|
|
23
|
+
python scripts/convert_notebooks.py --src /path/to/scvi-tutorials --dst src/scvi_tools_mcp/knowledge/tutorials
|
|
24
|
+
python scripts/extract_api_docs.py
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
## Which models are covered?
|
|
28
|
+
|
|
29
|
+
Run `get_model_overview` or `list_tutorials` in the MCP server. The knowledge base currently covers
|
|
30
|
+
scVI, scANVI, TotalVI, MultiVI, PeakVI, LinearSCVI, MrVI, Stereoscope, CellAssign, SOLO, GIMVI,
|
|
31
|
+
veloVI, ContrastiveVI, SCBASSET, SysVI, DiagVI, and more.
|
|
32
|
+
|
|
33
|
+
## What is the `uvx` command?
|
|
34
|
+
|
|
35
|
+
`uvx` runs a package from PyPI without installing it permanently — provided by
|
|
36
|
+
[uv](https://github.com/astral-sh/uv). It is the recommended way to run MCP servers because it
|
|
37
|
+
always fetches the latest published version.
|
|
38
|
+
|
|
39
|
+
## Can I use this server from R?
|
|
40
|
+
|
|
41
|
+
Yes — any MCP-compatible client works. Configure your client to run `uvx scvi-tools-mcp` and use
|
|
42
|
+
the tools from whatever language your client supports. The server itself is language-agnostic.
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
# scvi-tools MCP
|
|
2
|
+
|
|
3
|
+
An MCP (Model Context Protocol) server that gives LLMs structured access to [scvi-tools](https://scvi-tools.org) — a Python library for deep probabilistic analysis of single-cell omics data.
|
|
4
|
+
|
|
5
|
+
```{toctree}
|
|
6
|
+
:maxdepth: 2
|
|
7
|
+
:caption: Contents
|
|
8
|
+
|
|
9
|
+
installation
|
|
10
|
+
faq
|
|
11
|
+
references
|
|
12
|
+
```
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
# Installation
|
|
2
|
+
|
|
3
|
+
## Quick install
|
|
4
|
+
|
|
5
|
+
```bash
|
|
6
|
+
pip install scvi-tools-mcp
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
or with `uvx` (no install needed, runs directly):
|
|
10
|
+
|
|
11
|
+
```bash
|
|
12
|
+
uvx scvi-tools-mcp
|
|
13
|
+
```
|
|
14
|
+
|
|
15
|
+
## MCP client configuration
|
|
16
|
+
|
|
17
|
+
### Claude Desktop
|
|
18
|
+
|
|
19
|
+
Add to `~/Library/Application Support/Claude/claude_desktop_config.json`:
|
|
20
|
+
|
|
21
|
+
```json
|
|
22
|
+
{
|
|
23
|
+
"mcpServers": {
|
|
24
|
+
"scvi-tools": {
|
|
25
|
+
"command": "uvx",
|
|
26
|
+
"args": ["scvi-tools-mcp"]
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
### Claude Code (CLI)
|
|
33
|
+
|
|
34
|
+
```bash
|
|
35
|
+
claude mcp add scvi-tools-mcp uvx scvi-tools-mcp -s user
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
### Cursor / other MCP clients
|
|
39
|
+
|
|
40
|
+
```json
|
|
41
|
+
{ "command": "uvx", "args": ["scvi-tools-mcp"] }
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
## Optional: scvi-tools runtime
|
|
45
|
+
|
|
46
|
+
The server itself does not require `scvi-tools`. Install it only if you want to run the
|
|
47
|
+
knowledge refresh scripts locally:
|
|
48
|
+
|
|
49
|
+
```bash
|
|
50
|
+
pip install "scvi-tools-mcp[scvi]"
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
## Development install
|
|
54
|
+
|
|
55
|
+
```bash
|
|
56
|
+
git clone https://github.com/ori-kron-wis/scvi-tools-mcp
|
|
57
|
+
cd scvi-tools-mcp
|
|
58
|
+
pip install -e ".[dev]"
|
|
59
|
+
pre-commit install
|
|
60
|
+
pytest
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
## Requirements
|
|
64
|
+
|
|
65
|
+
- Python ≥ 3.11
|
|
66
|
+
- fastmcp ≥ 3.0
|
|
67
|
+
- pydantic ≥ 2.0
|