Building blocks for rapid development of GenAI applications
Project description
Features
🔨 Build Reliable & Scalable GenAI Apps
- Swap LLMs anytime – Switch between 100+ LLMs via LiteLLM or run local models.
- Type-safe LLM calls – Use Python generics to enforce strict type safety in model interactions.
- Bring your own vector store – Connect to Qdrant, PgVector, and more with built-in support.
- Developer tools included – Manage vector stores, query pipelines, and test prompts from your terminal.
- Modular installation – Install only what you need, reducing dependencies and improving performance.
📚 Fast & Flexible RAG Processing
- Ingest 20+ formats – Process PDFs, HTML, spreadsheets, presentations, and more. Process data using unstructured or create a custom provider.
- Handle complex data – Extract tables, images, and structured content with built-in VLMs support.
- Connect to any data source – Use prebuilt connectors for S3, GCS, Azure, or implement your own.
- Scale ingestion – Process large datasets quickly with Ray-based parallel processing.
🚀 Deploy & Monitor with Confidence
- Real-time observability – Track performance with OpenTelemetry and CLI insights.
- Built-in testing – Validate prompts with promptfoo before deployment.
- Auto-optimization – Continuously evaluate and refine model performance.
- Visual testing UI (Coming Soon) – Test and optimize applications with a visual interface.
What's Included?
- Core - Fundamental tools for working with prompts and LLMs.
- Document Search - Handles vector search to retrieve relevant documents.
- CLI - The
ragbitsshell command, enabling tools such as GUI prompt management. - Guardrails - Ensures response safety and relevance.
- Evaluation - Unified evaluation framework for Ragbits components.
- Flow Controls - Manages multi-stage chat flows for performing advanced actions (coming soon).
- Structured Querying - Queries structured data sources in a predictable manner (coming soon).
- Caching - Adds a caching layer to reduce costs and response times (coming soon).
Installation
To use the complete Ragbits stack, install the ragbits package:
pip install ragbits
Alternatively, you can use individual components of the stack by installing their respective packages: ragbits-core, ragbits-document-search, ragbits-cli.
Quickstart
First, create a prompt and a model for the data used in the prompt:
from pydantic import BaseModel
from ragbits.core.prompt import Prompt
class Dog(BaseModel):
breed: str
age: int
temperament: str
class DogNamePrompt(Prompt[Dog, str]):
system_prompt = """
You are a dog name generator. You come up with funny names for dogs given the dog details.
"""
user_prompt = """
The dog is a {breed} breed, {age} years old, and has a {temperament} temperament.
"""
Next, create an instance of the LLM and the prompt:
from ragbits.core.llms.litellm import LiteLLM
llm = LiteLLM("gpt-4o")
example_dog = Dog(breed="Golden Retriever", age=3, temperament="friendly")
prompt = DogNamePrompt(example_dog)
Finally, generate a response from the LLM using the prompt:
response = await llm.generate(prompt)
print(f"Generated dog name: {response}")
How Ragbits documentation is organized
- Quickstart - Get started with Ragbits in a few minutes
- How-to guides - Learn how to use Ragbits in your projects
- CLI - Learn how to run Ragbits in your terminal
- API reference - Explore the underlying API of Ragbits
License
Ragbits is licensed under the MIT License.
Contributing
We welcome contributions! Please read CONTRIBUTING.md for more information.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ragbits-0.19.1.tar.gz.
File metadata
- Download URL: ragbits-0.19.1.tar.gz
- Upload date:
- Size: 8.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
41d7ca3e0b4191b2c40d1e6b3f7f6dd44e8f4ecef35268cb532dd0d81f590044
|
|
| MD5 |
20fbe0ec66a439e092d09c54c643d45e
|
|
| BLAKE2b-256 |
0f30a368fd4bd3a067beab70d7291a1fc355752655439dad53765596c081904c
|
File details
Details for the file ragbits-0.19.1-py3-none-any.whl.
File metadata
- Download URL: ragbits-0.19.1-py3-none-any.whl
- Upload date:
- Size: 4.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9d160f5d3aa66a4e9fe8bebc63358a46db20ca9d26c7aeccbeff0b5a3546a684
|
|
| MD5 |
9906aa89fecbeeed5e10aaa5ca59866e
|
|
| BLAKE2b-256 |
5ca83a5e940ff859c533e6f59a9afd5f3757ebdc318bd2be5f3775e058bf3492
|