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]

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.4.0.tar.gz (5.9 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.4.0.tar.gz.

File metadata

  • Download URL: vision_agents_plugins_turbopuffer-0.4.0.tar.gz
  • Upload date:
  • Size: 5.9 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.4.0.tar.gz
Algorithm Hash digest
SHA256 b39bdfabceb1fef9c1c263a08a88fd5af7f143c53b278b01696b6bd146900459
MD5 12beb6aabaaf6904b2e32bf566994e5e
BLAKE2b-256 750df644ff4e3b35a201ad3c544f8778524dad2bb6f4c247bb6b4dcbba9835e3

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vision_agents_plugins_turbopuffer-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 10.6 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.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f9614d41ddf847ad50cfafc94a3802f80a4f5eca3c39c2782a416e5741f87e2c
MD5 bf526c16d8f29556387b15c802ee02c9
BLAKE2b-256 61f4d17a5b1b2c9405a475bbcf8a6b073f0066634f9bb273ceef3097c9ee8c95

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