|  | 7 months ago | |
|---|---|---|
| .. | ||
| data | 7 months ago | |
| Example_FinancialReport_RAG.ipynb | 7 months ago | |
| README.md | 7 months ago | |
| Tutorial.ipynb | 7 months ago | |
| config.py | 7 months ago | |
| embedding.py | 7 months ago | |
| helper.py | 7 months ago | |
Problem: Independent chunking in traditional RAG systems leads to the loss of contextual information between chunks. This makes it difficult for LLMs to retrieve relevant data when context (e.g., the subject or entity being discussed) is not explicitly repeated within individual chunks.
Solution: Generate keywords for each chunk to fulfill missing contextual information. These keywords (e.g., "BMW, X5, pricing") enrich the chunk with necessary context, ensuring better retrieval accuracy. By embedding this enriched metadata, the system bridges gaps between related chunks, enabling effective query matching and accurate answer generation.
This article explains benefits of contextual chunking.
Note This method does not require calling LLM for each chunk separately, which makes it efficient.
Getting started
In this cookbook, we’ll use DeepInfra for Llama inference services, so be sure to obtain an API key from https://deepinfra.com/.
You'll also need a LlamaParse API key to parse PDF files, which can be obtained from https://www.llamaindex.ai/.
Additionally, we will use the "jinaai/jina-embeddings-v2-base-en" model from HuggingFace to generate text embeddings locally.
Before getting started, update the config.py file as following:
"DEEPINFRA_API_KEY"="<your_api_key>"    
"LLAMAPARSE_API_KEY"="<your_api_key>"