Skip to main content

TurboPuffer RAG integration for Vision Agents with hybrid search

Project description

TurboPuffer RAG Plugin

Hybrid search RAG (Retrieval Augmented Generation) implementation using TurboPuffer for vector + BM25 full-text search, with Gemini for embeddings.

Features

  • Hybrid Search: Combines vector (semantic) and BM25 (keyword) search for better retrieval quality
  • Reciprocal Rank Fusion: Merges results from multiple search strategies
  • Gemini Embeddings: Uses Google's Gemini embedding model for high-quality vectors
  • Low-latency Queries: Supports cache warming for fast query responses
  • Implements RAG Interface: Compatible with Vision Agents RAG base class

Installation

uv add "vision-agents[turbopuffer]"
# or directly
uv add vision-agents-plugins-turbopuffer

Usage

from vision_agents.plugins import turbopuffer

# Initialize RAG
rag = turbopuffer.TurboPufferRAG(namespace="my-knowledge")
await rag.add_directory("./knowledge")

# Hybrid search (default)
results = await rag.search("How does the chat API work?")

# Vector-only search
results = await rag.search("How does the chat API work?", mode="vector")

# BM25-only search
results = await rag.search("chat API pricing", mode="bm25")

# Or use convenience function
rag = await turbopuffer.create_rag(
    namespace="product-knowledge",
    knowledge_dir="./knowledge"
)

Configuration

Parameter Description Default
namespace TurboPuffer namespace for storing vectors Required
embedding_model Gemini embedding model models/gemini-embedding-001
chunk_size Size of text chunks for splitting documents 10000
chunk_overlap Overlap between chunks for context continuity 200
region TurboPuffer region gcp-us-central1

Environment Variables

  • TURBO_PUFFER_KEY: TurboPuffer API key
  • GOOGLE_API_KEY: Google API key (for Gemini embeddings)

Dependencies

  • turbopuffer: TurboPuffer vector database client
  • langchain-google-genai: Gemini embeddings
  • langchain-text-splitters: Text chunking utilities

References

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vision_agents_plugins_turbopuffer-0.5.1.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file vision_agents_plugins_turbopuffer-0.5.1.tar.gz.

File metadata

  • Download URL: vision_agents_plugins_turbopuffer-0.5.1.tar.gz
  • Upload date:
  • Size: 6.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for vision_agents_plugins_turbopuffer-0.5.1.tar.gz
Algorithm Hash digest
SHA256 b9cc4f1020fce6f3f879d56685de2a8ef0aebc13c18c178aa894a031437f0d9a
MD5 4d138f366ae13b47d98677687655e53b
BLAKE2b-256 bd582641b085bddb086632f55b64473290a3926c3deb46f5c53fd0e89e054ce6

See more details on using hashes here.

File details

Details for the file vision_agents_plugins_turbopuffer-0.5.1-py3-none-any.whl.

File metadata

  • Download URL: vision_agents_plugins_turbopuffer-0.5.1-py3-none-any.whl
  • Upload date:
  • Size: 10.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for vision_agents_plugins_turbopuffer-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ec1e59ceee25bc0f37d4b4915e79dbe0ea6884bc7ce026cd7ad3edaea8dea52d
MD5 8654ecafd6b03319c9232f3b238bfe04
BLAKE2b-256 1012098650af23c003d88ffee370de4d7b026a84496cd5db92928a19c84153fc

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page