freshcrate
Skin:/
Home > RAG & Memory > RAGElo

RAGElo

RAGElo is a set of tools that helps you selecting the best RAG-based LLM agents by using an Elo ranker

Why this rank:Strong adoptionRelease freshnessHealthy release cadence

Description

RAGElo is a set of tools that helps you selecting the best RAG-based LLM agents by using an Elo ranker

README

Elo-based RAG Agent evaluator

RAGElo1 is a streamlined toolkit for evaluating Retrieval Augmented Generation (RAG)-powered Large Language Models (LLMs) question answering agents using the Elo rating system.

While it has become easier to prototype and incorporate generative LLMs in production, evaluation is still the most challenging part of the solution. Comparing different outputs from multiple prompt and pipeline variations to a "gold standard" is not easy. Still, we can ask a powerful LLM to judge between pairs of answers and a set of questions.

This led us to develop a simple tool for tournament-style Elo ranking of LLM outputs. By comparing answers from different RAG pipelines and prompts over multiple questions, RAGElo computes a ranking of the different settings, providing a good overview of what works (and what doesn't).

โš™๏ธ Installation

For using RAGElo as a Python library or as CLI, install it using pip:

pip install ragelo

When working from source we recommend an isolated environment (e.g., uv venv && uv pip install -e '.[dev]'). The project's Python lives at .venv/bin/python.

Environment variables and providers:

  • OpenAI requires OPENAI_API_KEY. Set it in your shell or load it via dotenv before invoking the CLI.
  • Ollama is supported for local models (--llm-provider-name ollama).
  • The Instructor provider enables multi-provider support (Anthropic, Mistral, Cohere, and more) via the instructor library. Install the extra and the relevant SDK:
    pip install 'ragelo[instructor]' anthropic   # for Anthropic/Claude
    pip install 'ragelo[instructor]' mistralai   # for Mistral
    pip install 'ragelo[instructor]' cohere      # for Cohere
    Then set the matching API key environment variable (e.g. ANTHROPIC_API_KEY).

๐Ÿš€ Library Quickstart

To use RAGElo as a library, all you need to do is import RAGElo, initialize an Evaluator and call either evaluate() for evaluating a retrieved document or an LLM answer, or evaluate_experiment() to evaluate a full experiment. For example, using the RDNAM retrieval evaluator from the Thomas et al. (2023) paper on using GPT-4 for annotating retrieval results:

from ragelo import get_retrieval_evaluator

evaluator = get_retrieval_evaluator("RDNAM", llm_provider="openai")
result = evaluator.evaluate(query="What is the capital of France?", document='Lyon is the second largest city in France.')
print(result.answer)
# Output: RDNAMEvaluationAnswer(reasoning='...', score=1.0, intent_match=None, trustworthiness=None)
print(result.answer.score)
# Output: 1.0
print(result.answer.model_dump_json())
# Output: '{"reasoning": "...", "score": 1.0, "intent_match": null, "trustworthiness": null}'

In most cases result.answer contains a BaseModel from Pydantic with the parsed judge response. For more details, check the answer_formats.py file.

๐Ÿ”„ Evaluating a single query incrementally

If queries arrive one at a time (e.g., in an online or streaming workflow), you can evaluate all evaluables for a single query without constructing a full experiment:

from ragelo import get_retrieval_evaluator, get_answer_evaluator
from ragelo.types.query import Query
from ragelo.types.evaluables import Document, AgentAnswer

query = Query(qid="q0", query="What is the capital of Brazil?")
query.add_retrieved_doc(Document(qid="q0", did="d0", text="Brasรญlia is the capital of Brazil."))
query.add_agent_answer(AgentAnswer(qid="q0", agent="agent1", text="Brasรญlia."))

retrieval_evaluator = get_retrieval_evaluator("reasoner", llm_provider="openai")
retrieval_evaluator.evaluate_all_evaluables(query)

# Each document now has an evaluation attached
for doc in query.retrieved_docs.values():
    print(doc.did, doc.evaluations)

This calls the same evaluation logic as evaluate_experiment but scoped to one query, making it suitable for incremental pipelines.

๐Ÿ“œ Evaluating multiple documents or answers

RAGElo supports Experiments to keep track of which documents and answers were already evaluated and to compute overall scores for each Agent:

from ragelo import Experiment, get_retrieval_evaluator, get_answer_evaluator, get_agent_ranker, get_llm_provider

experiment = Experiment(experiment_name="A_really_cool_RAGElo_experiment")
# Add two user queries. Alternatively, we can load them from a csv file with .add_queries_from_csv()
experiment.add_query("What is the capital of Brazil?", query_id="q0")
experiment.add_query("What is the capital of France?", query_id="q1")

# Add four documents retrieved for these queries. Alternatively, we can load them from a csv file with .add_documents_from_csv()
experiment.add_retrieved_doc("Brasรญlia is the capital of Brazil", query_id="q0", doc_id="d0")
experiment.add_retrieved_doc("Rio de Janeiro used to be the capital of Brazil.", query_id="q0", doc_id="d1")
experiment.add_retrieved_doc("Paris is the capital of France.", query_id="q1", doc_id="d2")
experiment.add_retrieved_doc("Lyon is the second largest city in France.", query_id="q1", doc_id="d3")

# Add the answers generated by agents
experiment.add_agent_answer("Brasรญlia is the capital of Brazil, according to [0].", agent="agent1", query_id="q0")
experiment.add_agent_answer("According to [1], Rio de Janeiro used to be the capital of Brazil, until the 60s.", agent="agent2", query_id="q0")
experiment.add_agent_answer("Paris is the capital of France, according to [2].", agent="agent1", query_id="q1")
experiment.add_agent_answer("According to [3], Lyon is the second largest city in France. Meanwhile, Paris is its capital [2].", agent="agent2", query_id="q1")

llm_provider = get_llm_provider("openai", model="gpt-4.1-nano")

# Or use the Instructor provider to run evaluations against Anthropic Claude (requires pip install 'ragelo[instructor]' anthropic):
# llm_provider = get_llm_provider("instructor", model="anthropic/claude-sonnet-4-20250514")

retrieval_evaluator = get_retrieval_evaluator("reasoner", llm_provider, rich_print=True)
answer_evaluator = get_answer_evaluator("pairwise", llm_provider, rich_print=True)

elo_ranker = get_agent_ranker("elo", show_results=True)

# Evaluate the retrieval results.
retrieval_evaluator.evaluate_experiment(experiment)

# With the retrieved documents evaluated, evaluate the quality of the answers. using the pairwise evaluator
answer_evaluator.evaluate_experiment(experiment)

# Run the ELO ranker to score the agents
elo_ranker.run(experiment)
# Output:
    ------- Agents Elo Ratings -------
    agent1         : 1035.7(ยฑ2.9)
    agent2         : 961.3(ยฑ2.9)

The experiment is save as a JSON in ragelo_cache/experiment_name.json.

๐Ÿ› ๏ธ Using a custom prompt and injecting metadata

For a more complete example, we can evaluate with a custom prompt, and inject metadata into our evaluation prompt:

from pydantic import BaseModel, Field
from ragelo import get_retrieval_evaluator

system_prompt = """You are a helpful assistant for evaluating the relevance of a retrieved document to a user query.
You should pay extra attention to how **recent** a document is. A document older than 5 years is considered outdated.

The answer should be evaluated according to its recency, truthfulness, and relevance to the user query.
"""

user_prompt = """
User query: {{ query.query }}

Retrieved document: {{ document.text }}

The document has a date of {{ document.metadata.date }}.
Today is {{ query.metadata.today_date }}.
"""
class ResponseSchema(BaseModel):
    relevance: int = Field(description="An integer, either 0 or 1. 0 if the document is irrelevant, 1 if it is relevant.")
    recency: int = Field(description="An integer, either 0 or 1. 0 if the document is outdated, 1 if it is recent.")
    truthfulness: int = Field(description="An integer, either 0 or 1. 0 if the document is false, 1 if it is true.")
    reasoning: str = Field(description="A short explanation of why you think the document is relevant or irrelevant.")



evaluator = get_retrieval_evaluator(
    "custom_prompt", # name of the retrieval evaluator
    llm_provider="openai", # Which LLM provider to use
    system_prompt=system_prompt, # your custom prompt
    user_prompt=user_prompt, # your custom prompt
    result_type=ResponseSchema, # The response schema for the LLM. 
)

result = evaluator.evaluate(
    query="What is the capital of Brazil?", # The user query
    document="Rio de Janeiro is the capital of Brazil.", # The retrieved document
    query_metadata={"today_date": "08-04-2024"}, # Some metadata for the query
    doc_metadata={"date": "04-03-1950"}, # Some metadata for the document
)

result.answer.model_dump_json(indent=2)
# Output: 
    '{
        "relevance": 0,
        "recency": 0,
        "truthfulness": 0,
        "reasoning": "The document is outdated and incorrect. Rio de Janeiro was the capital of Brazil until 1960 when it was changed to Brasรญlia."
    }'

Note that, in this example, we passed to the evaluate method two dictionaries with metadata for the query and the document. This metadata is injected into the prompt by matching their keys into the placeholders in the prompt (note the document.metadata.date and query.metadata.today_date templates.)

For a comprehensive example of how to use RAGElo, see the docs/examples/notebooks/rag_eval.ipynb notebook.

๐Ÿš€ CLI Quickstart

After installing RAGElo as a CLI app (and exporting the appropriate LLM provider credentials, e.g., OPENAI_API_KEY), you can run it with the following command:

ragelo run-all \
  queries.csv documents.csv answers.csv \
  --data-dir tests/data/ \
  --experiment-name tutorial \
  --output-file tutorial.json \
  --show-results

With --show-results enabled you will see outputs such as:

Loaded 2 queries from .../tests/data/queries.csv
Loaded 4 new documents from .../tests/data/documents.csv
Loaded 4 answers from .../tests/data/answers.csv
Evaluating Retrieved documents โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ” 4/4
โœ… Done!
๐Ÿ”Ž Query ID: 0
๐Ÿ“œ Document ID: 0
Parsed Answer: Very relevant: The document directly answers the user question by stating that Brasรญlia is the capital of Brazil.

๐Ÿ”Ž Query ID: 0
๐Ÿ“œ Document ID: 1
Parsed Answer: Somewhat relevant: The document mentions a former capital of Brazil but does not provide the current capital.

๐Ÿ”Ž Query ID: 1
๐Ÿ“œ Document ID: 2
Parsed Answer: Very relevant: The document clearly states that Paris is the capital of France, directly answering the user question.

๐Ÿ”Ž Query ID: 1
๐Ÿ“œ Document ID: 3
Parsed Answer: Not relevant: The document does not provide information about the capital of France.

Evaluating Retrieved documents 100% โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ” 4/4  [ 0:00:02 < 0:00:00 , 2 it/s ]
โœ… Done!
Total evaluations: 4
๐Ÿ”Ž Query ID: 0
 agent1              ๐Ÿ†š   agent2
Parsed Answer: A

๐Ÿ”Ž Query ID: 1
 agent1              ๐Ÿ†š   agent2
Parsed Answer: A

Evaluating Agent Answers 100% โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ”โ” 2/2  [ 0:00:09 < 0:00:00 , 0 it/s ]
โœ… Done!
Total evaluations: 2
------- Agents Elo Ratings -------
agent1         : 1033.0(ยฑ0.0)
agent2         : 966.0(ยฑ0.0)

By default, evaluations are persisted to ragelo_cache/<experiment>.json alongside incremental results in ragelo_cache/<experiment>_results.jsonl. Passing --output-file writes the experiment JSON (without evaluator traces) to a custom location.

In this example, the output file is a JSON file with the experiment definition and tournament summary. It can be loaded directly as a new Experiment object:

experiment = Experiment.load("experiment", "experiment.json")

When running as a CLI, RAGElo expects the input files as CSV files. Specifically, it expects a csv file with the user queries, one with the documents retrieved by the retrieval system and one of the answers each agent produced. These files can be passed with the parameters --queries_csv_file, --documents_csv_file and --answers_csv_file, respectively, or directly as positional arguments.

CSV columns and inference:

  • Queries: qid, query (infers qid if missing)
  • Documents: qid, did, document (infers qid/did if missing)
  • Answers: qid, agent, answer Extra columns are captured as metadata and available to prompts.

Here are some examples of their expected formats: queries.csv:

qid,query
0, What is the capital of Brazil?
1, What is the capital of France?

documents.csv:

qid,did,document
0,0, Brasรญlia is the capital of Brazil.
0,1, Rio de Janeiro used to be the capital of Brazil.
1,2, Paris is the capital of France.
1,3, Lyon is the second largest city in France.

answers.csv:

qid,agent,answer
0, agent1,"Brasรญlia is the capital of Brazil, according to [0]."
0, agent2,"According to [1], Rio de Janeiro used to be the capital of Brazil, until the 60s."
1, agent1,"Paris is the capital of France, according to [2]."
1, agent2,"According to [3], Lyon is the second largest city in France. Meanwhile, Paris is its capital [2]."

๐Ÿงฉ Components

While RAGElo can be used end-to-end (run-all), you can also drive individual CLI components.

๐Ÿ“œ retrieval-evaluator

The retrieval-evaluator tool annotates retrieved documents based on their relevance to the user query. This is done regardless of the answers provided by any Agent. As an example, for calling the Reasoner retrieval evaluator (reasoner only outputs the reasoning why a document is relevant or not) we can use:

ragelo retrieval-evaluator reasoner \
  queries.csv documents.csv \
  --data-dir tests/data/ \
  --experiment-name experiment \
  --output-file experiment-docs.json \
  --show-results

Each run updates the experiment cache and appends evaluation traces to <experiment>_results.jsonl. If all documents already have evaluations you will see an informational message unless --force is provided.

Domain expert example:

ragelo retrieval-evaluator domain-expert \
  queries.csv documents.csv \
  --data-dir tests/data/ \
  --experiment-name experiment \
  --expert-in "Chemical Engineering" \
  --company "ChemCorp" \
  --output-file experiment-docs.json \
  --show-results

RDNAM example:

ragelo retrieval-evaluator rdnam \
  queries.csv documents.csv \
  --data-dir tests/data/ \
  --experiment-name experiment \
  --output-file experiment-docs.json \
  --show-results

๐Ÿ’ฌ answer-evaluator

The answer-evaluator subcommands annotate agent answers. The default pairwise mode compares answers two at a time and can optionally inject reasoning annotations:

ragelo answer-evaluator pairwise \
  queries.csv documents.csv answers.csv \
  --data-dir tests/data/ \
  --experiment-name experiment \
  --output-file experiment-answers.json \
  --add-reasoning \
  --show-results

If --add-reasoning is supplied the CLI will run the reasoner retrieval evaluator first, include the relevance scores in the prompts, and then proceed with pairwise games. Newly created games are tracked inside the experiment and re-used by the Elo ranker.

Domain expert pairwise example:

ragelo answer-evaluator expert-pairwise \
  queries.csv documents.csv answers.csv \
  --data-dir tests/data/ \
  --experiment-name experiment \
  --expert-in "Healthcare" \
  --add-reasoning \
  --output-file experiment-answers.json \
  --show-results

Concurrency and Rich output:

  • Use --n-processes to control parallel LLM calls.
  • Use --no-rich-print in CI to avoid live display issues.

Reproducibility tips:

  • Pairwise sampling (n_games_per_query) is randomized; persist experiment JSON/JSONL to stabilize comparisons.

Evaluating retrieval metrics (optional):

from ragelo import Experiment
exp = Experiment(experiment_name="my_exp", save_on_disk=False)
# load queries/docs/answers and evaluations...
exp.evaluate_retrieval(metrics=["Precision@10", "nDCG@10"], relevance_threshold=1)

๐Ÿ™‹ Contributing

To install the development dependencies, download the repository and run the following:

git clone https://github.com/zeta-alpha/ragelo && cd ragelo
uv pip install -e '.[dev]'

This will install the requirement dependencies in an editable mode (i.e., any changes to the code don't need to be rebuilt.) For building a new version, use the build command:

python -m build

โœ… TODO

  • Add full documentation of all implemented Evaluators
  • Add CI/CD for publishing
  • Add option to few-shot examples (Undocumented, yet)
  • Testing!
  • Publish on PyPi
  • Add more document evaluators
  • Split Elo evaluator
  • Install as standalone CLI

Footnotes

  1. The RAGElo logo was created using Dall-E 3 and GPT-4 with the following prompt: "Vector logo design for a toolkit named 'RAGElo'. The logo should have bold, modern typography with emphasis on 'RAG' in a contrasting color. Include a minimalist icon symbolizing retrieval or ranking." โ†ฉ

Release History

VersionChangesUrgencyDate
0.5.0## RAGElo v0.5.0 - The Rubrics release. The main change in this release is the addition of RubricEvaluators. It allows the evaluator to ground its selection of best Agent in a multiple-criteria rubric that can be either directly given to the Evaluator or automatically created based on the retrieved documents. Other new features include: - Added support for multi-turn conversations in all answer evaluators. - Stronger typing for evaluators, rankers, results, and evaluables. Less mypy errorHigh5/4/2026
0.4.0## What's Changed ### New Features - External LLM adapter support (#76): BaseLLMProvider can now be used without LLMProviderConfig, making it easy to integrate third-party or custom LLM clients into RAGElo without subclassing the full provider stack. This paves to way to better integration with Zeta Alpha's [agents-sdk](https://github.com/zetaalphavector/platform). ### Improvements - Improved experiment loading (#74): Major overhaul of Experiment state management and loading logiLow3/2/2026
0.3.1- Dropped required Tenacity version to <9 - Fixed issue with GPT-5 and Openai O-models and temperature - Fixed bug introduced in 0.3 with document filtering ## What's Changed * Tenacity 8 by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/69 **Full Changelog**: https://github.com/zetaalphavector/RAGElo/compare/0.3...0.3.1Low9/6/2025
0.3This new release adds a bunch of quality-of-life improvements. Mainly, all evaluators now use Jinja Templates instead of plain strings, which were a pain to format. We also changed how most of the evaluators return their answers, relying more on Pydantic BaseModels, and less on finicky strings and JSONs. Finally, we moved all the codebase to Pydantic-V2, and updated the OpenAI provider to use the responses API instead of the old and deprecated chat_responses. ## What's Changed * Merge cLow9/5/2025
0.2.1## What's Changed * Small fixes and notebook update by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/61 **Full Changelog**: https://github.com/zetaalphavector/RAGElo/compare/0.2.0...0.2.1Low6/24/2025
0.2.0## What's Changed * Example fixes by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/54 **Full Changelog**: https://github.com/zetaalphavector/RAGElo/compare/0.1.9...0.2.0Low4/9/2025
0.1.9## What's Changed * add chat pairwise evaluation by @pavlosZakkas in https://github.com/zetaalphavector/RAGElo/pull/42 * Ollama and OpenAI updates by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/43 * Big overhaul: Added Experiments, JSON and Structuted LLM outputs, more evaluatoers and more by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/45 * Add StrEnum to RAGElo types by @din0s in https://github.com/zetaalphavector/RAGElo/pull/47 * Add seed to base llLow4/8/2025
0.1.8## New features: The `Query` object now supports two new methods for easier evaluation of your retrieval pipeline: - `query.get_runs()` returns a dictionary of TREC-style runs for all the agents that retrieved documents for that query. (the mapping is agent_id -> query_id->document_id->retrieval_score). - `query.get_qrels()` returns a TREC-style qrels dictionary with the judgement scores assigned by an Evaluator. The mapping is query_id->document_id->relevance). You can explore how these tLow8/29/2024
0.1.7## What's Changed * Python3.8 fixes by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/37 **Full Changelog**: https://github.com/zetaalphavector/RAGElo/compare/0.1.6...0.1.7Low8/23/2024
0.1.6## What's Changed * Fix issue with RDNAM parsing of answer by @matprst in https://github.com/zetaalphavector/RAGElo/pull/32 * docs: update README.md by @eltociear in https://github.com/zetaalphavector/RAGElo/pull/33 * Elo Ranker returns dictionary with agents scores by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/34 ## New Contributors * @matprst made their first contribution in https://github.com/zetaalphavector/RAGElo/pull/32 * @eltociear made their first contributioLow7/2/2024
0.1.5Adds support to Python >= 3.8 ## What's Changed * Support Python 3.8 by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/29 **Full Changelog**: https://github.com/zetaalphavector/RAGElo/compare/0.1.3...0.1.5Low5/31/2024
0.1.4Hotfix for Python3.10Low5/31/2024
0.1.2Main changes: - OpenAI calls are much faster now and can be done in parallel. - The pairwise answer evaluations are easier to use and more configurable. - A new PairwiseExpertAnswerEvaluator evaluator was added. - Added a notebook with examples of using RAGElo as a library. ## What's Changed * Added parallel calls to OpenAI with asyncio by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/21 * Change from aiohttp sessions to using OpenAI's Async clients. by @ArthurCamaraLow5/31/2024
0.1.1## RAGElo goes 0.1! In this release, RAGElo as a library was completely revamped, with a much easier to use unified interface, simpler to use commands (`evaluate` and `batch_evaluate`). Now using an Evaluator is a simple as calling `evaluator.evaluate("query", "document")`. ### Custom Evaluators and metadata support Not a fan of the existing evaluators? Now both Retrieval and Answer evaluators support fully custom promptings using the `RetrievalEvaluator.CustomPromptEvaluator` and `AnswerEvLow4/16/2024
0.0.5## What's Changed Major overhaul to the code! - More modular - Tests - Simpler and more Coherent class interface - Simpler iterators - Update OpenAI version by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/7 **Full Changelog**: https://github.com/zetaalphavector/RAGElo/compare/0.0.3...0.0.5Low2/15/2024
0.0.3Added a new document evaluator (domain_expert) and a bunch of bugfixes. ## What's Changed * Adding Domain Expert Evaluator by @ArthurCamara in https://github.com/zetaalphavector/RAGElo/pull/5 **Full Changelog**: https://github.com/zetaalphavector/RAGElo/compare/0.0.2...0.0.3Low10/25/2023
0.0.2First public release of RAGElo, an LLM powered annotator for RAG Agents using an Elo-style tournamentLow10/23/2023

Dependencies & License Audit

Loading dependencies...

Similar Packages

Mini-o3๐Ÿง  Enhance visual search with Mini-o3, providing state-of-the-art multi-turn reasoning and easy-to-use training code for advanced AI applications.main@2026-06-06
awesome-opensource-aiCurated list of the best truly open-source AI projects, models, tools, and infrastructure.main@2026-06-06
vllmA high-throughput and memory-efficient inference and serving engine for LLMsv0.22.1
cyllamaA thin cython wrapper around llama.cpp, whisper.cpp and stable-diffusion.cpp0.3.1
Medical-ResearchSearch and analyze medical literature across PubMed, ClinicalTrials.gov, and Europe PMC using AI to support clinical and research decisions.main@2026-06-04

More in RAG & Memory

edgequakeEdegQuake ๐ŸŒ‹ High-performance GraphRAG inspired from LightRag written in Rust; Transform documents into intelligent knowledge graphs for superior retrieval and generation
vllmA high-throughput and memory-efficient inference and serving engine for LLMs
nltkNatural Language Toolkit
spiceaiA portable accelerated SQL query, search, and LLM-inference engine, written in Rust, for data-grounded AI apps and agents.