Home

Awesome

<p align="center"> <img alt="OpenInfence" src="https://raw.githubusercontent.com/Arize-ai/phoenix-assets/main/logos/OpenInference/Full%20color/OI-full-horiz.svg" width="40%" height="100%" /> </p> <p align="center"> <a href="https://arize-ai.github.io/openinference/"> <img src="https://img.shields.io/static/v1?message=Spec&logo=&labelColor=grey&color=blue&logoColor=white&label=%20"/> </a> <a target="_blank" href="https://join.slack.com/t/arize-ai/shared_invite/zt-1px8dcmlf-fmThhDFD_V_48oU7ALan4Q"> <img src="https://img.shields.io/static/v1?message=Community&logo=slack&labelColor=grey&color=blue&logoColor=white&label=%20"/> </a> </p>

OpenInference is a set of conventions and plugins that is complimentary to OpenTelemetry to enable tracing of AI applications. OpenInference is natively supported by arize-phoenix, but can be used with any OpenTelemetry-compatible backend as well.

Specification

The OpenInference specification is edited in markdown files found in the spec directory. It's designed to provide insight into the invocation of LLMs and the surrounding application context such as retrieval from vector stores and the usage of external tools such as search engines or APIs. The specification is transport and file-format agnostic, and is intended to be used in conjunction with other specifications such as JSON, ProtoBuf, and DataFrames.

Instrumentation

OpenInference provides a set of instrumentations for popular machine learning SDKs and frameworks in a variety of languages.

Python

Libraries

PackageDescriptionVersion
openinference-semantic-conventionsSemantic conventions for tracing of LLM Apps.PyPI Version
openinference-instrumentation-openaiOpenInference Instrumentation for OpenAI SDK.PyPI Version
openinference-instrumentation-llama-indexOpenInference Instrumentation for LlamaIndex.PyPI Version
openinference-instrumentation-dspyOpenInference Instrumentation for DSPy.PyPI Version
openinference-instrumentation-bedrockOpenInference Instrumentation for AWS Bedrock.PyPI Version
openinference-instrumentation-langchainOpenInference Instrumentation for LangChain.PyPI Version
openinference-instrumentation-mistralaiOpenInference Instrumentation for MistralAI.PyPI Version
openinference-instrumentation-guardrailsOpenInference Instrumentation for Guardrails.PyPI Version
openinference-instrumentation-vertexaiOpenInference Instrumentation for VertexAI.PyPI Version
openinference-instrumentation-crewaiOpenInference Instrumentation for CrewAI.PyPI Version
openinference-instrumentation-haystackOpenInference Instrumentation for Haystack.PyPI Version
openinference-instrumentation-litellmOpenInference Instrumentation for liteLLM.PyPI Version
openinference-instrumentation-groqOpenInference Instrumentation for Groq.PyPI Version
openinference-instrumentation-instructorOpenInference Instrumentation for Instructor.PyPI Version
openinference-instrumentation-anthropicOpenInference Instrumentation for Anthropic.PyPI Version

Examples

NameDescriptionComplexity Level
OpenAI SDKOpenAI Python SDK, including chat completions and embeddingsBeginner
MistralAI SDKMistralAI Python SDKBeginner
VertexAI SDKVertexAI Python SDKBeginner
LlamaIndexLlamaIndex query enginesBeginner
DSPyDSPy primitives and custom RAG modulesBeginner
Boto3 Bedrock ClientBoto3 Bedrock clientBeginner
LangChainLangChain primitives and simple chainsBeginner
LiteLLMA lightweight LiteLLM frameworkBeginner
LiteLLM ProxyLiteLLM Proxy to log OpenAI, Azure, Vertex, BedrockBeginner
GroqGroq and AsyncGroq chat completionsBeginner
AnthropicAnthropic Messages clientBeginner
LlamaIndex + Next.js ChatbotA fully functional chatbot using Next.js and a LlamaIndex FastAPI backendIntermediate
LangServeA LangChain application deployed with LangServe using custom metadata on a per-request basisIntermediate
DSPyA DSPy RAG application using FastAPI, Weaviate, and CohereIntermediate
HaystackA Haystack QA RAG applicationIntermediate

JavaScript

Libraries

PackageDescriptionVersion
@arizeai/openinference-semantic-conventionsSemantic conventions for tracing of LLM Apps.NPM Version
@arizeai/openinference-coreCore utility functions for instrumentationNPM Version
@arizeai/openinference-instrumentation-openaiOpenInference Instrumentation for OpenAI SDK.NPM Version
@arizeai/openinference-instrumentation-langchainOpenInference Instrumentation for LangChain.js.NPM Version
@arizeai/openinference-vercelOpenInference Support for Vercel AI SDKNPM Version

Examples

NameDescriptionComplexity Level
OpenAI SDKOpenAI Node.js clientBeginner
LlamaIndex Express AppA fully functional LlamaIndex chatbot with a Next.js frontend and a LlamaIndex Express backend, instrumented using openinference-instrumentation-openaiIntermediate
LangChain OpenAIA simple script to call OpenAI via LangChain, instrumented using openinference-instrumentation-langchainBeginner
LangChain RAG Express AppA fully functional LangChain chatbot that uses RAG to answer user questions. It has a Next.js frontend and a LangChain Express backend, instrumented using openinference-instrumentation-langchainIntermediate
Next.js + OpenAIA Next.js 13 project bootstrapped with create-next-app that uses OpenAI to generate textBeginner

Supported Destinations

OpenInference supports the following destinations as span collectors.

Community

Join our community to connect with thousands of machine learning practitioners and LLM observability enthusiasts!