Skip to content

Building RAG from Scratch (Lower-Level)#

This doc is a hub for showing how you can build RAG and agent-based apps using only lower-level abstractions (e.g. LLMs, prompts, embedding models), and without using more "packaged" out of the box abstractions.

Out of the box abstractions include:

  • High-level ingestion code e.g. VectorStoreIndex.from_documents
  • High-level query and retriever code e.g. VectorStoreIndex.as_retriever() and VectorStoreIndex.as_query_engine()
  • High-level agent abstractions e.g. OpenAIAgent

Instead of using these, the goal here is to educate users on what's going on under the hood. By showing you the underlying algorithms for constructing RAG and agent workflows, you can then be empowered to create your own custom LLM workflows (while still using LlamaIndex abstractions at any level of granularity that makes sense).

We show how to build an app from scratch, component by component. For the sake of focus, each tutorial will show how to build a specific component from scratch while using out-of-the-box abstractions for other components. NOTE: This is a WIP document, we're in the process of fleshing this out!

Building Ingestion from Scratch#

This tutorial shows how you can define an ingestion pipeline into a vector store.

Building Vector Retrieval from Scratch#

This tutorial shows you how to build a retriever to query a vector store.

Building Ingestion/Retrieval from Scratch (Open-Source/Local Components)#

This tutoral shows you how to build an ingestion/retrieval pipeline using only open-source components.

Building a (Very Simple) Vector Store from Scratch#

If you want to learn more about how vector stores work, here's a tutorial showing you how to build a very simple vector store capable of dense search + metadata filtering.

Obviously not a replacement for production databases.

Building Response Synthesis from Scratch#

This tutorial shows you how to use the LLM to synthesize results given a set of retrieved context. Deals with context overflows, async calls, and source citations!

Building Evaluation from Scratch#

Learn how to build common LLM-based eval modules (correctness, faithfulness) using LLMs and prompt modules; this will help you define your own custom evals!

Building Advanced RAG from Scratch#

These tutorials will show you how to build advanced functionality beyond the basic RAG workflow. Especially helpful for advanced users with custom workflows / production needs.

Building Hybrid Search from Scratch#

Hybrid search is an advanced retrieval feature supported by many vector databases. It allows you to combine dense retrieval with sparse retrieval with matching keywords.

Building a Router from Scratch#

Beyond the standard RAG workflow, this takes you one step towards automated decision making with LLMs by showing you how to build a router module from scratch.

Building RAG Fusion Retriever from Scratch#

Here we show you how to build an advanced retriever capable of query-rewriting, ensembling, dynamic retrieval.

Building QA over Structured Data from Scratch#

RAG as a framework is primarily focused on unstructured data. LlamaIndex also has out of the box support for structured data and semi-structured data as well.

Take a look at our guides below to see how to build text-to-SQL and text-to-Pandas from scratch (using our Query Pipeline syntax).

Hi, how can I help you?

🦙