OpenInference DSPy Instrumentation
Project description
OpenInference DSPy Instrumentation
Python auto-instrumentation library for DSPy.
These traces are fully OpenTelemetry-compatible and can be sent to an OpenTelemetry collector for viewing, such as arize-phoenix
.
Installation
pip install openinference-instrumentation-dspy
Quickstart
This quickstart shows you how to instrument your DSPy application. It is adapted from the DSPy quickstart.
Install required packages.
pip install openinference-instrumentation-dspy dspy-ai arize-phoenix opentelemetry-sdk opentelemetry-exporter-otlp
Start Phoenix in the background as a collector. By default, it listens on http://localhost:6006
. You can visit the app via a browser at the same address. (Phoenix does not send data over the internet. It only operates locally on your machine.)
python -m phoenix.server.main serve
Set up DSPyInstrumentor
to trace your DSPy application and sends the traces to Phoenix at the endpoint defined below.
from openinference.instrumentation.dspy import DSPyInstrumentor
from opentelemetry import trace as trace_api
from opentelemetry.exporter.otlp.proto.http.trace_exporter import OTLPSpanExporter
from opentelemetry.sdk import trace as trace_sdk
from opentelemetry.sdk.trace.export import SimpleSpanProcessor
endpoint = "http://127.0.0.1:6006/v1/traces"
tracer_provider = trace_sdk.TracerProvider()
trace_api.set_tracer_provider(tracer_provider)
tracer_provider.add_span_processor(SimpleSpanProcessor(OTLPSpanExporter(endpoint)))
DSPyInstrumentor().instrument()
Import dspy
and configure your language model.
import dspy
from dspy.datasets.gsm8k import GSM8K, gsm8k_metric
turbo = dspy.OpenAI(model='gpt-3.5-turbo-instruct', max_tokens=250)
dspy.settings.configure(lm=turbo)
gms8k = GSM8K()
gsm8k_trainset, gsm8k_devset = gms8k.train[:10], gms8k.dev[:10]
Define a custom program that utilizes the ChainOfThought
module to perform step-by-step reasoning to generate answers.
class CoT(dspy.Module):
def __init__(self):
super().__init__()
self.prog = dspy.ChainOfThought("question -> answer")
def forward(self, question):
return self.prog(question=question)
Optimize your program using the BootstrapFewShotWithRandomSearch
teleprompter.
from dspy.teleprompt import BootstrapFewShot
config = dict(max_bootstrapped_demos=4, max_labeled_demos=4)
teleprompter = BootstrapFewShot(metric=gsm8k_metric, **config)
optimized_cot = teleprompter.compile(CoT(), trainset=gsm8k_trainset, valset=gsm8k_devset)
Evaluate performance on the dev dataset.
from dspy.evaluate import Evaluate
evaluate = Evaluate(devset=gsm8k_devset, metric=gsm8k_metric, num_threads=4, display_progress=True, display_table=0)
evaluate(optimized_cot)
Visit the Phoenix app at http://localhost:6006
to see your traces.
More Info
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file openinference_instrumentation_dspy-0.1.11.tar.gz
.
File metadata
- Download URL: openinference_instrumentation_dspy-0.1.11.tar.gz
- Upload date:
- Size: 16.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7e2f2f72631750a111cfb8bd5376beb91e8fa8a2c874987199f5ad1df02cba8e |
|
MD5 | 10b5ea9a6fb7108fab69ed81fddaaad2 |
|
BLAKE2b-256 | 80d7de8f414d9d8bb63e37058720db7288cdb0de6a2ad9d37c37b880319d2f71 |
File details
Details for the file openinference_instrumentation_dspy-0.1.11-py3-none-any.whl
.
File metadata
- Download URL: openinference_instrumentation_dspy-0.1.11-py3-none-any.whl
- Upload date:
- Size: 13.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3425284da523c2b54fd0c2f0437de2694fc0caf7efeeb433c25caee0b470a00b |
|
MD5 | e4543b91f8e993259f3afddc9804accf |
|
BLAKE2b-256 | 8cc3563af1f406f27861f8b22834f8b697faad336c090fe39b5decdd7f88e95d |