DSPy: Compiling Declarative Language Model Calls into Self-Improving Pipelines
Abstract
DSPy is a programming model for developing and optimizing language model pipelines by abstracting them as text transformation graphs with parameterized modules that learn through demonstrations.
The ML community is rapidly exploring techniques for prompting language models (LMs) and for stacking them into pipelines that solve complex tasks. Unfortunately, existing LM pipelines are typically implemented using hard-coded "prompt templates", i.e. lengthy strings discovered via trial and error. Toward a more systematic approach for developing and optimizing LM pipelines, we introduce DSPy, a programming model that abstracts LM pipelines as text transformation graphs, i.e. imperative computational graphs where LMs are invoked through declarative modules. DSPy modules are parameterized, meaning they can learn (by creating and collecting demonstrations) how to apply compositions of prompting, finetuning, augmentation, and reasoning techniques. We design a compiler that will optimize any DSPy pipeline to maximize a given metric. We conduct two case studies, showing that succinct DSPy programs can express and optimize sophisticated LM pipelines that reason about math word problems, tackle multi-hop retrieval, answer complex questions, and control agent loops. Within minutes of compiling, a few lines of DSPy allow GPT-3.5 and llama2-13b-chat to self-bootstrap pipelines that outperform standard few-shot prompting (generally by over 25% and 65%, respectively) and pipelines with expert-created demonstrations (by up to 5-46% and 16-40%, respectively). On top of that, DSPy programs compiled to open and relatively small LMs like 770M-parameter T5 and llama2-13b-chat are competitive with approaches that rely on expert-written prompt chains for proprietary GPT-3.5. DSPy is available at https://github.com/stanfordnlp/dspy
Community
This is an automated message from the Librarian Bot. I found the following papers similar to this paper.
The following papers were recommended by the Semantic Scholar API
- CodeCoT and Beyond: Learning to Program and Test like a Developer (2023)
- AskIt: Unified Programming Interface for Programming with Large Language Models (2023)
- Prompt2Model: Generating Deployable Models from Natural Language Instructions (2023)
- LLM Guided Inductive Inference for Solving Compositional Problems (2023)
- Natural Language Embedded Programs for Hybrid Language Symbolic Reasoning (2023)
Please give a thumbs up to this comment if you found it helpful!
If you want recommendations for any Paper on Hugging Face checkout this Space
which model does this paper use
Models citing this paper 0
No model linking this paper
Datasets citing this paper 0
No dataset linking this paper
 AK
							AK 
					 
					 
						
 
						
 
						 
						 
					