Files
ailine/backend/rag_core/retriever_factory.py

71 lines
2.6 KiB
Python
Raw Normal View History

2026-04-21 19:06:34 +08:00
# rag_core/retriever_factory.py
2026-04-21 11:02:16 +08:00
from langchain_core.embeddings import Embeddings
from langchain_classic.retrievers import ParentDocumentRetriever
from langchain_text_splitters import RecursiveCharacterTextSplitter, TextSplitter
2026-04-21 19:06:34 +08:00
from langchain_core.stores import BaseStore
2026-04-21 11:02:16 +08:00
from rag_core import LlamaCppEmbedder, QdrantVectorStore, create_docstore
2026-04-21 19:06:34 +08:00
2026-04-21 11:02:16 +08:00
def create_parent_retriever(
collection_name: str = "rag_documents",
2026-04-21 19:06:34 +08:00
parent_splitter: TextSplitter | None = None,
child_splitter: TextSplitter | None = None,
docstore: BaseStore | None = None,
2026-04-21 11:02:16 +08:00
search_k: int = 5,
parent_chunk_size: int = 1000,
parent_chunk_overlap: int = 100,
child_chunk_size: int = 200,
child_chunk_overlap: int = 20,
embeddings: Embeddings | None = None,
2026-04-21 11:02:16 +08:00
) -> ParentDocumentRetriever:
2026-04-21 19:06:34 +08:00
"""
创建 ParentDocumentRetriever 实例
2026-04-21 19:06:34 +08:00
Args:
collection_name: Qdrant 集合名称默认 "rag_documents"
parent_splitter: 父文档切分器默认 None使用默认参数创建
child_splitter: 子文档切分器默认 None使用默认参数创建
docstore: 文档存储实例默认 None使用默认参数创建
search_k: 检索时返回的结果数默认 5
parent_chunk_size: 父文档块大小默认 1000
parent_chunk_overlap: 父文档块重叠大小默认 100
child_chunk_size: 子文档块大小默认 200
child_chunk_overlap: 子文档块重叠大小默认 20
embeddings: 嵌入模型实例默认 None使用内部默认的 LocalLlamaCppEmbedder
2026-04-21 19:06:34 +08:00
Returns:
ParentDocumentRetriever 实例
"""
2026-04-21 11:02:16 +08:00
# 嵌入模型
if embeddings is None:
embedder = LlamaCppEmbedder()
embeddings = embedder.as_langchain_embeddings()
2026-04-21 11:02:16 +08:00
# 向量存储(只读)
vector_store = QdrantVectorStore(collection_name=collection_name, embeddings=embeddings)
2026-04-21 11:02:16 +08:00
# 切分器(若未提供则创建默认)
if parent_splitter is None:
parent_splitter = RecursiveCharacterTextSplitter(
chunk_size=parent_chunk_size,
chunk_overlap=parent_chunk_overlap,
)
if child_splitter is None:
child_splitter = RecursiveCharacterTextSplitter(
chunk_size=child_chunk_size,
chunk_overlap=child_chunk_overlap,
)
# 文档存储
if docstore is None:
2026-04-21 19:06:34 +08:00
docstore, _ = create_docstore()
2026-04-21 11:02:16 +08:00
return ParentDocumentRetriever(
vectorstore=vector_store.get_langchain_vectorstore(),
docstore=docstore,
child_splitter=child_splitter,
parent_splitter=parent_splitter,
search_kwargs={"k": search_k},
2026-04-21 19:06:34 +08:00
)