Share your thoughts, 1 month free Claude Pro on usSee more
WorkDL logo mark

NaviRAG: Towards Active Knowledge Navigation for Retrieval-Augmented Generation

About

Retrieval-augmented generation (RAG) typically relies on a flat retrieval paradigm that maps queries directly to static, isolated text segments. This approach struggles with more complex tasks that require the conditional retrieval and dynamic synthesis of information across different levels of granularity (e.g., from broad concepts to specific evidence). To bridge this gap, we introduce NaviRAG, a novel framework that shifts from passive segment retrieval to active knowledge navigation. NaviRAG first structures the knowledge documents into a hierarchical form, preserving semantic relationships from coarse-grained topics to fine-grained details. Leveraging this reorganized knowledge records, a large language model (LLM) agent actively navigates the records, iteratively identifying information gaps and retrieving relevant content from the most appropriate granularity level. Extensive experiments on long-document QA benchmarks show that NaviRAG consistently improves both retrieval recall and end-to-end answer performance over conventional RAG baselines. Ablation studies confirm performance gains stem from our method's capacity for multi-granular evidence localization and dynamic retrieval planning. We further discuss efficiency, applicable scenario, and future directions of our method, hoping to make RAG systems more intelligent and autonomous.

Jihao Dai, Dingjun Wu, Yuxuan Chen, Zheni Zeng, Yukun Yan, Zhenghao Liu, Maosong Sun (1) __INSTITUTION_7__ Tsinghua University, (2) Nanjing University, (3) Northeastern University)• 2026

Related benchmarks

TaskDatasetResultRank
Question AnsweringNarrativeQA
F1 Score32.6
92
Question AnsweringNarrativeQA
F1 Score32.6
5
Question AnsweringLongBench v2
Accuracy42.72
5
Knowledge Base ConstructionNarrativeQA
KB Construction Time51.28
5
Question AnsweringLooGLE
Short QA Score79.04
5
Showing 5 of 5 rows

Other info

Follow for update