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.2.8.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.2.8.tar.gz.

File metadata

  • Download URL: vision_agents_plugins_turbopuffer-0.2.8.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.22 {"installer":{"name":"uv","version":"0.9.22","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for vision_agents_plugins_turbopuffer-0.2.8.tar.gz
Algorithm Hash digest
SHA256 42ba0d4e474458a733ddd7ab47b57d992f13a322f609b394b416afbaa1ed7cf3
MD5 cd2b622e8c3772164115d765c209629f
BLAKE2b-256 85b59262d28b5d7276c981e56a7a97a058fe7a70972da49c9791eb11063bcc2c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: vision_agents_plugins_turbopuffer-0.2.8-py3-none-any.whl
  • Upload date:
  • Size: 10.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.22 {"installer":{"name":"uv","version":"0.9.22","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for vision_agents_plugins_turbopuffer-0.2.8-py3-none-any.whl
Algorithm Hash digest
SHA256 9dde03102e4389c5cc5f68d501d24fc1be649ae9c9ec0165e00816e5a438e59b
MD5 35b5bdd1996436c46b47da8ca770c211
BLAKE2b-256 3fb3489ac2e5e2f465e1ce3381f385e991e8b4e16e446b8ec6360340dd8adad3

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