SpringAI RAG 检索增强生成

SpringAI RAG 检索增强生成

  • [1. 文档](#1. 文档)
  • [2. 实现](#2. 实现)

1. 文档

https://docs.spring.io/spring-ai/reference/api/retrieval-augmented-generation.html

2. 实现

java 复制代码
//4.RAG
//1.用户提示词压缩,多轮对话中捕捉用户真实意图(大模型温度要低)
//2.用户提示词重写,澄清用户意图(大模型温度要低)
//3.用户提示词扩展,从多个角度捕捉用户意图
//4.文档检索(可以多源检索、元数据过滤、稠密&稀疏检索)
//5.文档合并,将多个文档源的文档合并
//6.重排序并移除低相关文档,压缩文档,满足大模型上下文窗口
//7.上下文生成
//8.允许大模型使用工具继续检索
FilterExpressionBuilder filterExpressionBuilder = new FilterExpressionBuilder();
RetrievalAugmentationAdvisor retrievalAugmentationAdvisor = RetrievalAugmentationAdvisor.builder()
    .queryTransformers(
        List.of(
            // 1. 提示词压缩
            CompressionQueryTransformer.builder().chatClientBuilder(ragChatClient.mutate()).build(),
            // 2. 提示词重写
            RewriteQueryTransformer.builder().chatClientBuilder(ragChatClient.mutate()).build()
        )
    )
    // 3. 提示词扩展
    .queryExpander(
        MultiQueryExpander.builder().chatClientBuilder(ragChatClient.mutate()).numberOfQueries(3).includeOriginal(true).build()
    )
    // 4. 文档检索
    .documentRetriever(
        VectorStoreDocumentRetriever.builder()
            .similarityThreshold(0.5)
            .topK(10)
            .filterExpression(
                filterExpressionBuilder.and(
                    filterExpressionBuilder.eq("tenantId", tenantId),
                    filterExpressionBuilder.eq("orgId", PBSContext.getUserContext().getUserModel().getCoId())
                ).build()
            )
            .vectorStore(vectorStore)
            .build()
    )
    // 5. 文档合并
    .documentJoiner(new ConcatenationDocumentJoiner())
    // 6. 重排序并移除低相关文档
    .documentPostProcessors(
        RerankerDocumentPostProcessor.builder().rerankModel(rerankModel).build()
    )
    // 7. 上下文生成
    .queryAugmenter(ContextualQueryAugmenter.builder()
        // 默认情况下,ContextualQueryAugmenter 不允许检索到的上下文为空。当发生这种情况时,它会指示模型不要回答用户查询。
        // 若启用 allowEmptyContext 选项,则允许模型在检索到的上下文为空时生成响应
        .allowEmptyContext(Boolean.TRUE)
        .build())
    .build();
相关推荐
一乐小哥13 小时前
坚持迭代一个 Chrome 插件半年后,我的同事问我:"这不是 Chrome 自带的功能吗?"
chrome·github·ai编程
donecoding13 小时前
Playwright MCP 页面捕获:Snapshot、截图、HTML 到底选哪个?
前端·ai编程·前端工程化
木昆子13 小时前
用一个业务案例,摸透Code Buddy的Skill原理
ai编程
小虎AI生活16 小时前
2026 年 AI 搞钱的八个方向,第五个被严重低估
ai编程
sunneo17 小时前
专栏C-产品战略与竞争-05-产品组合
人工智能·产品运营·产品经理·ai编程·ai-native
GISer_Jing17 小时前
从入门到落地:前端开发者的AI Agent全栈学习路线
前端·人工智能·ai编程
lifewange18 小时前
GitHubCopilot 安装教程
ai编程
名不经传的养虾人18 小时前
从0到1:企业级AI项目迭代日记 Vol.14|正式版上线第一周:一个403、一次重构、一个新方向
人工智能·ai编程·ai创业·企业ai·多agent协作
guslegend19 小时前
第2节:规范驱动开发SDD,让AI永远在轨道上
人工智能·ai编程
常威正在打来福20 小时前
【入门】OpenClaw 是什么?怎么装?以及你一定要知道的风险点
aigc·ai编程