MCPcopy
hub / github.com/stanfordnlp/dspy

github.com/stanfordnlp/dspy @3.3.0b1 sqlite

repository ↗ · DeepWiki ↗ · release 3.3.0b1 ↗
3,563 symbols 13,962 edges 261 files 1,121 documented · 31%
README

DSPy: Programming—not prompting—Foundation Models

Documentation: DSPy Docs

PyPI Downloads


DSPy is the framework for programming—rather than prompting—language models. It allows you to iterate fast on building modular AI systems and offers algorithms for optimizing their prompts and weights, whether you're building simple classifiers, sophisticated RAG pipelines, or Agent loops.

DSPy stands for Declarative Self-improving Python. Instead of brittle prompts, you write compositional Python code and use DSPy to teach your LM to deliver high-quality outputs. Learn more via our official documentation site or meet the community, seek help, or start contributing via this GitHub repo and our Discord server.

Documentation: dspy.ai

Please go to the DSPy Docs at dspy.ai

Installation

pip install dspy

To install the very latest from main:

pip install git+https://github.com/stanfordnlp/dspy.git

📜 Citation & Reading More

If you're looking to understand the framework, please go to the DSPy Docs at dspy.ai.

If you're looking to understand the underlying research, this is a set of our papers:

[Jul'25] GEPA: Reflective Prompt Evolution Can Outperform Reinforcement Learning
[Jun'24] Optimizing Instructions and Demonstrations for Multi-Stage Language Model Programs
[Oct'23] DSPy: Compiling Declarative Language Model Calls into Self-Improving Pipelines
[Jul'24] Fine-Tuning and Prompt Optimization: Two Great Steps that Work Better Together
[Jun'24] Prompts as Auto-Optimized Training Hyperparameters
[Feb'24] Assisting in Writing Wikipedia-like Articles From Scratch with Large Language Models
[Jan'24] In-Context Learning for Extreme Multi-Label Classification
[Dec'23] DSPy Assertions: Computational Constraints for Self-Refining Language Model Pipelines
[Dec'22] Demonstrate-Search-Predict: Composing Retrieval & Language Models for Knowledge-Intensive NLP

To stay up to date or learn more, follow @DSPyOSS on Twitter or the DSPy page on LinkedIn.

The DSPy logo is designed by Chuyi Zhang.

If you use DSPy or DSP in a research paper, please cite our work as follows:

@inproceedings{khattab2024dspy,
  title={DSPy: Compiling Declarative Language Model Calls into Self-Improving Pipelines},
  author={Khattab, Omar and Singhvi, Arnav and Maheshwari, Paridhi and Zhang, Zhiyuan and Santhanam, Keshav and Vardhamanan, Sri and Haq, Saiful and Sharma, Ashutosh and Joshi, Thomas T. and Moazam, Hanna and Miller, Heather and Zaharia, Matei and Potts, Christopher},
  journal={The Twelfth International Conference on Learning Representations},
  year={2024}
}
@article{khattab2022demonstrate,
  title={Demonstrate-Search-Predict: Composing Retrieval and Language Models for Knowledge-Intensive {NLP}},
  author={Khattab, Omar and Santhanam, Keshav and Li, Xiang Lisa and Hall, David and Liang, Percy and Potts, Christopher and Zaharia, Matei},
  journal={arXiv preprint arXiv:2212.14024},
  year={2022}
}

Core symbols most depended-on inside this repo

get
called by 393
dspy/clients/cache.py
append
called by 364
dspy/signatures/signature.py
configure
called by 210
dspy/dsp/utils/settings.py
items
called by 193
dspy/primitives/example.py
context
called by 121
dspy/dsp/utils/settings.py
append
called by 96
dspy/primitives/repl_types.py
keys
called by 95
dspy/primitives/example.py
with_inputs
called by 89
dspy/primitives/example.py

Shape

Function 1,643
Method 1,269
Class 639
Route 12

Languages

Python100%
TypeScript1%

Modules by API surface

dspy/core/types.py165 symbols
tests/predict/test_rlm.py154 symbols
tests/adapters/test_chat_adapter.py118 symbols
tests/predict/test_predict.py115 symbols
tests/streaming/test_streaming.py92 symbols
tests/adapters/test_json_adapter.py69 symbols
tests/clients/test_lm.py68 symbols
dspy/clients/openai_format.py61 symbols
tests/adapters/test_tool.py57 symbols
tests/signatures/test_signature.py56 symbols
tests/teleprompt/test_bettertogether.py55 symbols
tests/primitives/test_python_interpreter.py54 symbols

Used by 2 indexed graphs manifest dependencies, hub-wide

Dependencies from manifests, versioned

anyio
cachetools5.5.0 · 1×
cloudpickle3.1.2 · 1×
diskcache5.6.0 · 1×
json-repair0.54.2 · 1×
litellm1.64.0 · 1×
mistune3.2.1 · 1×
mkdocs-llmstxt0.5.0 · 1×
openai0.28.1 · 1×
orjson3.9.0 · 1×
pydantic2.0 · 1×
regex2023.10.3 · 1×

For agents

$ claude mcp add dspy \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact