跳到主要内容

开放式问答模式的快速路由

上一篇讲完了时间敏感性识别,接下来 prepare 方法要做的第一个路由判断就是:这个问题是不是开放式问答?

为什么要单独处理开放式问答?

在 super-agent 系统中,聊天模式分为两大类:

模式说明是否需要文档检索
OPEN_CHAT开放式问答,类似 ChatGPT 的自由对话❌ 不需要
DOCUMENT / KNOWLEDGE文档问答 / 知识库问答✅ 需要 RAG 检索

开放式问答不需要去检索文档,也不需要改写问题、拆分子问题这些复杂操作,直接把问题扔给 ReactAgent 就行了。所以系统在这里做了一个"快速通道",让开放式问答直接跳过后面的文档检索编排流程。

开放式问答的快速路由代码

if (chatMode == ChatQueryMode.OPEN_CHAT) {
// 开放式问答直接走 ReactAgent 路径,不做文档检索编排。
ConversationExecutionPlan plan = basePlan(question, chatMode, memoryContext, historyPlanningContext, historySummary, answerHistoryContext, currentDate, currentDateText,
requiresCurrentDateAnchoring, requiresFreshSearch)
.mode(ExecutionMode.REACT_AGENT)
.build();
if (traceRecorder != null) {
// 对开放式模式单独打 route 轨迹,方便调试时看出为什么没有进入文档链路。
ConversationTraceRecorder.StageHandle routeStage = traceRecorder.startStage(ConversationTraceStageCode.ROUTE, ExecutionMode.REACT_AGENT.name(), "路由到开放式 Agent。", null);
traceRecorder.completeStage(routeStage, "已判定走开放式 Agent 路径。", java.util.Map.of(
"chatMode", chatMode.name(),
"executionMode", ExecutionMode.REACT_AGENT.name(),
"requiresFreshSearch", requiresFreshSearch,
"requiresCurrentDateAnchoring", requiresCurrentDateAnchoring
));
}
return plan;
}

整个逻辑很简单,就三步:

  1. 构建基础执行计划 - 调用 basePlan 方法
  2. 设置执行模式为 ReactAgent - 通过 .mode(ExecutionMode.REACT_AGENT) 指定
  3. 记录路由追踪 - 把路由决策记录到 traceRecorder 里,方便后续调试

basePlan 方法:构建基础执行计划

basePlan 是一个私有方法,它的作用是把前面准备好的各种上下文信息打包成一个 ConversationExecutionPlan.Builder 对象。这个方法接收的参数非常多,因为它要把所有必要的信息都装进执行计划里:

private ConversationExecutionPlan.ConversationExecutionPlanBuilder basePlan(String question,
ChatQueryMode chatMode,
ConversationMemoryContext memoryContext,
HistoryPlanningContext historyPlanningContext,
String historySummary,
AnswerHistoryContext answerHistoryContext,
LocalDate currentDate,
String currentDateText,
boolean requiresCurrentDateAnchoring,
boolean requiresFreshSearch) {
return ConversationExecutionPlan.builder()
.chatMode(chatMode)
.originalQuestion(question)
.agentQuestion(question)
.rewriteQuestion(question)
.rewriteSubQuestions(List.of(question))
.retrievalQuestion(question)
.retrievalSubQuestions(List.of(question))
.historySummary(historySummary)
.longTermSummary(memoryContext.getLongTermSummary())
.historyPlanningContext(historyPlanningContext)
.recentHistoryTranscript(memoryContext.getRecentTranscript())
.answerRecentTranscript(memoryContext.getAnswerRecentTranscript())
.answerHistoryContext(answerHistoryContext)
.historyCompressionApplied(memoryContext.isCompressionApplied())
.historyCoveredExchangeId(memoryContext.getCoveredExchangeId())
.historyCoveredExchangeCount(memoryContext.getCoveredExchangeCount())
.historyCompressionCount(memoryContext.getCompressionCount())
.currentDate(currentDate)
.currentDateText(currentDateText)
// ... 还有更多字段
}

这个方法返回的是一个 Builder 对象,所以调用方可以继续链式调用 .mode() 等方法来补充更多信息。

basePlan 里装了哪些信息?

从代码可以看到,basePlan 把前面几个步骤准备好的所有上下文都打包进去了:

付费内容提示

该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放

加入星球后,你可以获得:

  • 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
  • 讲解文档:超级AI智能体、黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的详细文档
  • 讲解视频:超级AI智能体、黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
  • 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
  • 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
  • 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
  • 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
  • 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
  • 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
知识星球二维码

1. 打开微信 -> 扫描左侧二维码 -> 加入「JavaUp项目实战&技术讲解」知识星球

2. 查看星球使用指导,获取完整项目讲解资料索引

👉 点击解锁全部付费内容
🎁优惠