Skip to main content

No project description provided

Project description

RAQA

Retrieval-Augmented Question-Answering

Retrieval-augmented, pip-installable, CLI-based question answering over arbitrary document collections.

Usage

Installation

pip install raqa

Locally

pip install -e .

Run

BASH via Python interpreter

  1. Build DB

    python cli.py build DATABASE_NAME PATH/TO/FOLDER/WITH/MARKDOWNS

  2. Chat

    python cli.py chat DATABASE_NAME

  3. One-shot retrieval

    python cli.py search "what is retrieval augmented generation?"

  4. Rebuild and chat

    python cli.py rebuild-and-chat DATABASE_NAME PATH/TO/FOLDER/WITH/MARKDOWNS

  5. Get stats

    python cli.py stats

  6. List databases

    python cli.py list

BASH natively

raqa build DATABASE_NAME PATH/TO/FOLDER/WITH/MARKDOWNS
raqa chat DATABASE_NAME
raqa search "what is RAG?"
raqa list
raqa stats (DATABASE_NAME)
raqa rebuild-and-chat DATABASE_NAME PATH/TO/FOLDER/WITH/MARKDOWNS

Python

Build database

from db import VectorDB
from config import MARKDOWN_ROOT

db = VectorDB()
db.build(MARKDOWN_ROOT)

Run

from agent import RAGAgent

agent = RAGAgent()
agent.chat()

Build instructions

  1. If any changes are made, update pyproject.toml.
  2. Building the package before uploading: cd raqa; python -m build.
  3. Upload the package to pypi: python -m twine upload --repository {pypi|testpypi} dist/*

Steps 2 and 3 can be done automatically by running make publish.

Related or comparable projects

  1. PyRAG difference: focuses on SingleStore.
  2. ragger-simple difference: uses Qdrant and requires a Qdrant API key, in addition to an LLM API key. RAQA only requires the latter and uses an open-source tech stack for the rest.

Next steps

Real tool-calling (instead of implicit RAG)

Define OpenAI tool:

{
  "name": "search_docs",
  "description": "...",
  "parameters": { "query": "string" }
}

Hybrid search

Combine BM25 (rank-bm25) + embeddings

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

raqa-1.0.2.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

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

raqa-1.0.2-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

File details

Details for the file raqa-1.0.2.tar.gz.

File metadata

  • Download URL: raqa-1.0.2.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for raqa-1.0.2.tar.gz
Algorithm Hash digest
SHA256 93837d22e6893beac46fb6acfd3eae09a0e0580b95eb076e6f3ca1c7aa2287a8
MD5 48356507dd7b29d0617345db1c719671
BLAKE2b-256 d116dd6e9b6f230b6ce4fb625bee6a0f219174277cc8196d3116afb36ba72d61

See more details on using hashes here.

File details

Details for the file raqa-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: raqa-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for raqa-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d97ab6321b7c642d0d2462ffc68e97f36b99187acdf2c6c37e4e14826d9eae4e
MD5 a527b858b20e623452f19e426678c05b
BLAKE2b-256 904bcd451d213a282ea1ba4a517ddaeeff3bbfb0a772ceae543318d999eb3b08

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