feat(aia): Complete AIA V2.0 with universal streaming capabilities

Major Changes:
- Add StreamingService with OpenAI Compatible format
- Upgrade Chat component V2 with Ant Design X integration
- Implement AIA module with 12 intelligent agents
- Update API routes to unified /api/v1 prefix
- Update system documentation

Backend (~1300 lines):
- common/streaming: OpenAI Compatible adapter
- modules/aia: 12 agents, conversation service, streaming integration
- Update route versions (RVW, PKB to v1)

Frontend (~3500 lines):
- modules/aia: AgentHub + ChatWorkspace (100% prototype restoration)
- shared/Chat: AIStreamChat, ThinkingBlock, useAIStream Hook
- Update API endpoints to v1

Documentation:
- AIA module status guide
- Universal capabilities catalog
- System overview updates
- All module documentation sync

Tested: Stream response verified, authentication working
Status: AIA V2.0 core completed (85%)
This commit is contained in:
2026-01-14 19:15:01 +08:00
parent 3d35e9c58b
commit 1b53ab9d52
386 changed files with 52096 additions and 65238 deletions

View File

@@ -1,31 +1,31 @@
# IIT Manager Agent 鎶€鏈<E282AC>€哄姟娓呭崟
**鏂囨。鐗堟湰**: v1.0
**最后更新**: 2026-01-04
**鏈€鍚庢洿鏂?*: 2026-01-04
**褰撳墠闃舵<E99783>**: Phase 1.5 瀹屾垚
---
## 馃搵 鏂囨。璇存槑
本文档记录IIT Manager Agent模块的技术债务,包括当前的临时方案、已知限制、待优化项,以及未来改进计划。
<EFBFBD>枃妗<EFBFBD>褰旾IT Manager Agent妯″潡鐨勬妧鏈<EFBFBD>€哄姟锛屽寘鎷<EFBFBD>綋鍓嶇殑涓存椂鏂规<EFBFBD>銆佸凡鐭ラ檺鍒躲€佸緟浼樺寲椤癸紝浠ュ強鏈<EFBFBD>潵鏀硅繘璁″垝銆?
---
## 🎯 技术债务优先级定义
## 馃幆 鎶€鏈<E282AC>€哄姟浼樺厛绾у畾涔?
| 优先级 | 说明 | 处理时机 |
| 浼樺厛绾?| 璇存槑 | 澶勭悊鏃舵満 |
|-------|------|---------|
| **P0 - 阻塞性** | 影响核心功能,必须立即处理 | 立即 |
| **P1 - 高优先级** | 影响用户体验或性能建议Phase 2处理 | 1个月内 |
| **P2 - 中优先级** | 功能增强可在Phase 3处理 | 3个月内 |
| **P3 - 低优先级** | 优化项,长期规划 | 6个月内 |
| **P0 - 闃诲<EFBFBD>鎬?* | 褰卞搷鏍稿績鍔熻兘锛屽繀椤荤珛鍗冲<E98D97>鐞?| 绔嬪嵆 |
| **P1 - 楂樹紭鍏堢骇** | 褰卞搷鐢ㄦ埛浣撻獙鎴栨€ц兘锛屽缓璁甈hase 2澶勭悊 | 1<EFBFBD>湀鍐?|
| **P2 - <EFBFBD>紭鍏堢骇** | 鍔熻兘澧炲己锛屽彲鍦≒hase 3澶勭悊 | 3<EFBFBD>湀鍐?|
| **P3 - 浣庝紭鍏堢骇** | 浼樺寲椤癸紝闀挎湡瑙勫垝 | 6涓<36>湀鍐?|
---
## 馃敶 P0 - 闃诲<E99783>у€哄姟
**当前状态**: ✅ 无P0级债务
**褰撳墠鐘舵€?*: 鉁?鏃燩0绾у€哄姟
---
@@ -42,7 +42,7 @@
**褰卞搷**:
- 褰撶敤鎴蜂娇鐢ㄩ潪鏍囧噯琛ㄨ揪鏃讹紝鍙<E7B49D>兘鏃犳硶姝璇嗗埆鎰忓浘
- 例如:"帮我看一下那个7号的数据" 可能无法识别为`query_record`
- 渚嬪<EFBFBD>锛?甯<>垜鐪嬩竴涓嬮偅涓?鍙风殑鏁版嵁" 鍙<>兘鏃犳硶璇嗗埆涓篳query_record`
**鏀硅繘鏂规<E98F82>**:
@@ -51,12 +51,12 @@
// 浣跨敤LLM杩涜<E69DA9>鎰忓浘鍒嗙被
const intentPrompt = `浣犳槸鎰忓浘璇嗗埆涓撳<EFBFBD>銆傜敤鎴锋秷鎭<EFBFBD>${userMessage}
请判断用户意图,从以下选项中选择:
1. query_record - 查询特定患者记录
2. count_records - 统计患者数量
璇峰垽鏂<EFBFBD>敤鎴锋剰鍥撅紝浠庝互涓嬮€夐」涓<EFBFBD>€夋嫨锛?
1. query_record - 鏌ヨ<EFBFBD>鐗瑰畾鎮€呰<EFBFBD>褰?
2. count_records - 缁熻<EFBFBD>€呮暟閲?
3. query_protocol - 鏌ヨ<E98F8C>鐮旂┒鏂规<E98F82>鏂囨。
4. project_info - 鏌ヨ<E98F8C>椤圭洰淇℃伅
5. general_chat - 普通对话
5. general_chat - <EFBFBD>€氬<EFBFBD>璇?
<EFBFBD>繑鍥濲SON: {"intent": "xxx", "params": {...}}
`;
@@ -65,13 +65,13 @@ const intentResult = await llm.chat([{ role: 'user', content: intentPrompt }]);
```
**浼樺娍**:
- ✅ 理解能力强,支持复杂表达
- ✅ 无需维护关键词
- ✅ 适应性好
- 鉁?鐞嗚В鑳藉姏寮猴紝鏀<E7B49D>寔澶嶆潅琛ㄨ揪
- 鉁?鏃犻渶缁存姢鍏抽敭璇?
- 鉁?閫傚簲鎬уソ
**鍔e娍**:
- ❌ 增加一次LLM调用~1秒0.0001成本)
- ❌ 总响应时间增加到~6秒
- 鉂?澧炲姞涓€娆<E282AC>LM璋冪敤锛垀1绉掞紝+楼0.0001鎴愭湰锛?
- 鉂?鎬诲搷搴旀椂闂村<E99782>鍔犲埌~6绉?
**鏂规<E98F82>B: BERT鍒嗙被妯″瀷**
```python
@@ -83,36 +83,36 @@ model = BertForSequenceClassification.from_pretrained(
num_labels=5
)
# 训练数据100-200个标注样本
# 推理速度:<100ms
# <EFBFBD>粌鏁版嵁锛?00-200涓<30>爣娉ㄦ牱鏈?
# 鎺ㄧ悊閫熷害锛?100ms
```
**浼樺娍**:
- ✅ 速度快(<100ms
- ✅ 理解能力强
- ✅ 成本低
- 鉁?閫熷害蹇<E5AEB3><100ms锛?
- 鉁?鐞嗚В鑳藉姏寮?
- 鉁?鎴愭湰浣?
**鍔e娍**:
- ❌ 需要标注训练数据
- ❌ 需要部署模型服务
- ❌ 需要持续迭代
- 鉂?闇€瑕佹爣娉ㄨ<E5A889>缁冩暟鎹?
- 鉂?闇€瑕侀儴缃叉ā鍨嬫湇鍔?
- 鉂?闇€瑕佹寔缁<E5AF94>凯浠?
**寤鸿<E5AFA4>**:
- Phase 2: 先使用方案ALLM判断快速验证效果
- Phase 3: 如果量大再切换到方案BBERT模型
- Phase 2: 鍏堜娇鐢ㄦ柟妗圓锛圠LM鍒ゆ柇锛夛紝蹇<EFBFBD>€熼獙璇佹晥鏋?
- Phase 3: 濡傛灉閲忓ぇ锛屽啀鍒囨崲鍒版柟妗圔锛圔ERT妯″瀷锛?
**预计工作量**: 2-3
**棰勮<EFBFBD>宸ヤ綔閲?*: 2-3澶?
---
### 2. 涓婁笅鏂囧瓨鍌ㄨ縼绉诲埌Redis
**当前方案**: 内存缓存Node.js Map
**褰撳墠鏂规<EFBFBD>**: 鍐呭瓨缂撳瓨锛圢ode.js Map锛?
**闂<><E99782>**:
- ⚠️ 单机内存,不支持分布式部署
- 鈿狅笍 鍗曟満鍐呭瓨锛屼笉鏀<E7AC89>寔鍒嗗竷寮忛儴缃?
- 鈿狅笍 鏈嶅姟閲嶅惎鍚庝笂涓嬫枃涓㈠け
- ⚠️ 内存占用无限制(虽有自动清理,但仍有风险)
- 鈿狅笍 鍐呭瓨鍗犵敤鏃犻檺鍒讹紙铏芥湁鑷<E6B981>姩娓呯悊锛屼絾浠嶆湁椋庨櫓锛?
**褰卞搷**:
- 褰撳悗绔<E68297>湇鍔¢噸鍚<E599B8>椂锛屾墍鏈夌敤鎴风殑瀵硅瘽涓婁笅鏂囦細涓㈠け
@@ -144,12 +144,12 @@ export class SessionMemory {
// 2. 娣诲姞娑堟伅
session.messages.push(message);
// 3. 保持最近3轮
// 3. 淇濇寔鏈€杩?杞?
if (session.messages.length > 6) {
session.messages = session.messages.slice(-6);
}
// 4. 存回Redis30分钟过期
// 4. 瀛樺洖Redis锛?0鍒嗛挓杩囨湡锛?
await this.redis.setex(key, this.EXPIRE_TIME, JSON.stringify(session));
}
@@ -168,54 +168,54 @@ export class SessionMemory {
```
**浼樺娍**:
- ✅ 支持分布式部署
- ✅ 服务重启不丢失上下文
- ✅ 内存占用可控
- 鉁?鏀<>寔鍒嗗竷寮忛儴缃?
- 鉁?鏈嶅姟閲嶅惎涓嶄涪澶变笂涓嬫枃
- 鉁?鍐呭瓨鍗犵敤鍙<E695A4>
**鍔e娍**:
- ❌ 增加Redis依赖
- ❌ 每次读写需要网络IO~1-2ms
- 鉂?澧炲姞Redis渚濊禆
- 鉂?姣忔<E5A7A3>璇诲啓闇€瑕佺綉缁淚O锛垀1-2ms锛?
**寤鸿<E5AFA4>**: Phase 2瀹炴柦锛屼紭鍏堢骇涓<E9AA87>
**预计工作量**: 1
**棰勮<EFBFBD>宸ヤ綔閲?*: 1澶?
---
### 3. Dify检索结果缓存
### 3. Dify妫€绱㈢粨鏋滅紦瀛?
**当前方案**: 每次都调用Dify API检索
**褰撳墠鏂规<EFBFBD>**: 姣忔<EFBFBD>閮借皟鐢―ify API妫€绱?
**闂<><E99782>**:
- 鈿狅笍 鐩稿悓闂<E68293><E99782>閲嶅<E996B2>妫€绱<E282AC>紝娴<E7B49D>垂鏃堕棿
- ⚠️ Dify API响应时间占30%1.5-1.7秒)
- 鈿狅笍 Dify API鍝嶅簲鏃堕棿鍗?0%锛?.5-1.7绉掞級
**褰卞搷**:
- 响应速度有提升空间
- 相同问题第二次询问仍需1.5
- 鍝嶅簲閫熷害鏈夋彁鍗囩┖闂?
- 鐩稿悓闂<EFBFBD><EFBFBD><EFBFBD>簩娆¤<EFBFBD><EFBFBD>粛闇€1.5绉?
**鏀硅繘鏂规<E98F82>**:
```typescript
// 使用Redis缓存Dify检索结果
// 浣跨敤Redis缂撳瓨Dify妫€绱㈢粨鏋?
private async queryDifyKnowledge(query: string): Promise<string> {
// 1. 生成缓存keyquery的hash
// 1. 鐢熸垚缂撳瓨key锛坬uery鐨刪ash锛?
const cacheKey = `dify:${md5(query)}`;
// 2. 尝试从缓存获取
// 2. 灏濊瘯浠庣紦瀛樿幏鍙?
const cached = await redis.get(cacheKey);
if (cached) {
logger.info('Dify检索命中缓存', { query });
logger.info('Dify妫<EFBFBD>?, { query });
return cached;
}
// 3. 璋冪敤Dify API
const result = await difyClient.retrieveKnowledge(...);
// 4. 格式化结果
// 4. 鏍煎紡鍖栫粨鏋?
const formattedKnowledge = this.formatDifyResult(result);
// 5. 缓存结果1小时
// 5. 缂撳瓨缁撴灉锛?灏忔椂锛?
await redis.setex(cacheKey, 3600, formattedKnowledge);
return formattedKnowledge;
@@ -223,21 +223,21 @@ private async queryDifyKnowledge(query: string): Promise<string> {
```
**浼樺娍**:
- ✅ 相同问题响应速度提升1.5秒从4.8秒降到3.3秒)
- ✅ 减少Dify API调用次数
- ✅ 降低Dify服务器负载
- 鉁?鐩稿悓闂<E68293><E99782>鍝嶅簲閫熷害鎻愬崌1.5绉掞紙浠?.8绉掗檷鍒?.3绉掞級
- 鉁?鍑忓皯Dify API璋冪敤娆℃暟
- 鉁?闄嶄綆Dify鏈嶅姟鍣ㄨ礋杞?
**鍔e娍**:
- ❌ 文档更新后需要清除缓存
- ❌ 缓存占用Redis内存
- 鉂?鏂囨。鏇存柊鍚庨渶瑕佹竻闄ょ紦瀛?
- 鉂?缂撳瓨鍗犵敤Redis鍐呭瓨
**缂撳瓨澶辨晥绛栫暐**:
- 文档上传/更新/删除时清除对应Dataset的所有缓存
- 缓存过期时间1小时
- 鏂囨。涓婁紶/鏇存柊/鍒犻櫎鏃讹紝娓呴櫎瀵瑰簲Dataset鐨勬墍鏈夌紦瀛?
- 缂撳瓨杩囨湡鏃堕棿锛?灏忔椂
**建议**: Phase 2实施,优先级中
**寤鸿<EFBFBD>**: Phase 2瀹炴柦锛屼紭鍏堢骇涓?
**预计工作量**: 1
**棰勮<EFBFBD>宸ヤ綔閲?*: 1澶?
---
@@ -246,12 +246,12 @@ private async queryDifyKnowledge(query: string): Promise<string> {
**褰撳墠鏂规<E98F82>**: 姣忔<E5A7A3>閮借皟鐢≧EDCap API鏌ヨ<E98F8C>
**闂<><E99782>**:
- ⚠️ REDCap API响应时间占25%1.2-1.3秒)
- ⚠️ 患者基本信息变化频率低,不需要每次实时查询
- 鈿狅笍 REDCap API鍝嶅簲鏃堕棿鍗?5%锛?.2-1.3绉掞級
- 鈿狅笍 鎮€呭熀鏈<E78680>俊鎭<E4BF8A>彉鍖栭<E98D96>鐜囦綆锛屼笉闇€瑕佹瘡娆″疄鏃舵煡璇?
**褰卞搷**:
- 响应速度有提升空间
- 增加REDCap服务器负载
- 鍝嶅簲閫熷害鏈夋彁鍗囩┖闂?
- 澧炲姞REDCap鏈嶅姟鍣ㄨ礋杞?
**鏀硅繘鏂规<E98F82>**:
@@ -260,7 +260,7 @@ private async queryDifyKnowledge(query: string): Promise<string> {
private async queryRedcapRecord(recordId: string): Promise<any> {
const cacheKey = `redcap:record:${recordId}`;
// 1. 尝试从缓存获取
// 1. 灏濊瘯浠庣紦瀛樿幏鍙?
const cached = await redis.get(cacheKey);
if (cached) {
return JSON.parse(cached);
@@ -269,7 +269,7 @@ private async queryRedcapRecord(recordId: string): Promise<any> {
// 2. 璋冪敤REDCap API
const records = await redcap.exportRecords({ records: [recordId] });
// 3. 缓存结果5分钟
// 3. 缂撳瓨缁撴灉锛?鍒嗛挓锛?
await redis.setex(cacheKey, 300, JSON.stringify(records[0]));
return records[0];
@@ -280,37 +280,37 @@ private async queryRedcapRecord(recordId: string): Promise<any> {
| 鏁版嵁绫诲瀷 | 缂撳瓨鏃堕棿 | 鍘熷洜 |
|---------|---------|------|
| 患者基本信息 | 5分钟 | 变化频率低 |
| €呭熀鏈<EFBFBD>俊鎭?| 5鍒嗛挓 | 鍙樺寲棰戠巼浣?|
| 缁熻<E7BC81>鏁版嵁 | 1鍒嗛挓 | 闇€瑕佽緝瀹炴椂 |
| 椤圭洰閰嶇疆 | 1灏忔椂 | 鍑犱箮涓嶅彉 |
**浼樺娍**:
- ✅ 响应速度提升1.2
- ✅ 减少REDCap服务器负载
- 鉁?鍝嶅簲閫熷害鎻愬崌1.2绉?
- 鉁?鍑忓皯REDCap鏈嶅姟鍣ㄨ礋杞?
**鍔e娍**:
- ❌ 数据可能有5分钟延迟
- 鉂?鏁版嵁鍙<E5B581>兘鏈?鍒嗛挓寤惰繜
**建议**: Phase 2实施需与用户确认是否接受5分钟延迟
**寤鸿<EFBFBD>**: Phase 2瀹炴柦锛岄渶涓庣敤鎴风‘璁ゆ槸鍚︽帴鍙?鍒嗛挓寤惰繜
**预计工作量**: 1
**棰勮<EFBFBD>宸ヤ綔閲?*: 1澶?
---
## 馃煛 P2 - 涓<>紭鍏堢骇鍊哄姟
### 5. 文档上传API开发
### 5. 鏂囨。涓婁紶API寮€鍙?
**褰撳墠鏂规<E98F82>**: 鎵嬪姩閫氳繃Dify鐣岄潰涓婁紶鏂囨。
**闂<><E99782>**:
- ⚠️ 不支持批量上传
- 鈿狅笍 涓嶆敮鎸佹壒閲忎笂浼?
- 鈿狅笍 闇€瑕佺櫥褰旸ify绯荤粺
- ⚠️ 无法自动化
- 鈿狅笍 鏃犳硶鑷<E7A1B6>姩鍖?
**褰卞搷**:
- PI鏃犳硶鑷<E7A1B6>姪涓婁紶鐮旂┒鏂囨。
- 需要技术人员协助
- 闇€瑕佹妧鏈<EFBFBD>汉鍛樺崗鍔?
**鏀硅繘鏂规<E98F82>**:
@@ -359,24 +359,24 @@ router.get('/projects/:projectId/documents', async (request, reply) => {
**鍓嶇<E98D93>鐣岄潰**锛堝彲閫夛級:
- 鏂囨。涓婁紶琛ㄥ崟
- 鏂囨。鍒楄〃灞曠ず
- 文档状态追踪(uploading indexing completed
- 鏂囨。鐘舵€佽拷韪<EFBFBD>uploading 鈫?indexing 鈫?completed锛?
**建议**: Phase 3实施,优先级中
**寤鸿<EFBFBD>**: Phase 3瀹炴柦锛屼紭鍏堢骇涓?
**预计工作量**: 2-3
**棰勮<EFBFBD>宸ヤ綔閲?*: 2-3澶?
---
### 6. 鐢ㄦ埛缁戝畾榛樿<E6A69B>椤圭洰
**当前方案**: 所有用户共享同一个活跃项目(`status='active'`
**褰撳墠鏂规<EFBFBD>**: 鎵€鏈夌敤鎴峰叡浜<EFBFBD>悓涓€涓<EFBFBD>椿璺冮」鐩<EFBFBD>`status='active'`锛?
**闂<><E99782>**:
- ⚠️ 无法支持多项目
- 鈿狅笍 鏃犳硶鏀<E7A1B6>寔澶氶」鐩?
- 鈿狅笍 涓嶅悓鐢ㄦ埛鍙<E59F9B>兘鍏虫敞涓嶅悓椤圭洰
**褰卞搷**:
- 如果有多个IIT项目无法区分用户属于哪个项目
- 濡傛灉鏈夊<EFBFBD>涓狪IT椤圭洰锛屾棤娉曞尯鍒嗙敤鎴峰睘浜庡摢涓<EFBFBD>」鐩?
**鏀硅繘鏂规<E98F82>**:
@@ -395,7 +395,7 @@ model IitUserMapping {
**ChatService鏇存柊**:
```typescript
async handleMessage(userId: string, userMessage: string): Promise<string> {
// 1. 获取用户的默认项目
// 1. 鑾峰彇鐢ㄦ埛鐨勯粯璁ら」鐩?
const userMapping = await prisma.iitUserMapping.findFirst({
where: { wecomUserId: userId }
});
@@ -413,24 +413,24 @@ async handleMessage(userId: string, userMessage: string): Promise<string> {
**寤鸿<E5AFA4>**: Phase 2鍚庢湡瀹炴柦锛屽綋鏈夊<E98F88><EFBFBD>」鐩<E3808D>
**预计工作量**: 1-2
**棰勮<EFBFBD>宸ヤ綔閲?*: 1-2澶?
---
### 7. Function Calling鍗囩骇
**当前方案**: 关键词意图识别 → 手动调用工具
**褰撳墠鏂规<EFBFBD>**: 鍏抽敭璇嶆剰鍥捐瘑鍒?鈫?鎵嬪姩璋冪敤宸ュ叿
**闂<><E99782>**:
- 鈿狅笍 鏃犳硶鑷<E7A1B6>姩鍐冲畾鏄<E795BE>惁璋冪敤宸ュ叿
- ⚠️ 无法根据上下文自动提取参数
- 鈿狅笍 鏃犳硶鏍规嵁涓婁笅鏂囪嚜鍔ㄦ彁鍙栧弬鏁?
**褰卞搷**:
- 如果用户问"7号患者和8号患者哪个更严重",当前无法自动查询两个患者
- 濡傛灉鐢ㄦ埛闂?7鍙锋偅鑰呭拰8鍙锋偅鑰呭摢涓<E691A2>洿涓ラ噸锛?锛屽綋鍓嶆棤娉曡嚜鍔ㄦ煡璇<E785A1>袱涓<E8A2B1>偅鑰?
**鏀硅繘鏂规<E98F82>**:
使用DeepSeek-V3的**Native Function Calling**:
浣跨敤DeepSeek-V3鐨?*Native Function Calling**:
```typescript
// 瀹氫箟宸ュ叿
@@ -456,7 +456,7 @@ const tools = [
type: 'function',
function: {
name: 'query_dify_knowledge',
description: '检索研究方案、CRF表格等文档',
description: '妫€绱㈢爺绌舵柟妗堛€丆RF琛ㄦ牸绛夋枃妗?,
parameters: {
type: 'object',
properties: {
@@ -487,24 +487,24 @@ if (response.tool_calls) {
```
**浼樺娍**:
- LLM自动决定是否调用工具
- ✅ 自动提取参数(如recordId
- ✅ 支持多工具并行调用
- ✅ 更智能、更灵活
- 鉁?LLM<EFBFBD>姩鍐冲畾鏄<EFBFBD>惁璋冪敤宸ュ叿
- 鉁?鑷<>姩鎻愬彇鍙傛暟锛堝<E9949B>recordId锛?
- 鉁?鏀<>寔澶氬伐鍏峰苟琛岃皟鐢?
- 鉁?鏇存櫤鑳姐€佹洿鐏垫椿
**鍔e娍**:
- ❌ 增加一次LLM调用
- ❌ 总响应时间可能增加到7-8
- 鉂?澧炲姞涓€娆<E282AC>LM璋冪敤
- 鉂?鎬诲搷搴旀椂闂村彲鑳藉<E991B3>鍔犲埌7-8绉?
**建议**: Phase 3实施,作为高级功能
**寤鸿<EFBFBD>**: Phase 3瀹炴柦锛屼綔涓洪珮绾у姛鑳?
**预计工作量**: 3-5
**棰勮<EFBFBD>宸ヤ綔閲?*: 3-5澶?
---
### 8. 鏅鸿兘寮曠敤绯荤粺
**当前方案**: Dify返回的文档片段直接显示
**褰撳墠鏂规<EFBFBD>**: Dify杩斿洖鐨勬枃妗g墖娈电洿鎺ユ樉绀?
**闂<><E99782>**:
- 鈿狅笍 鏃犳硶婧<E7A1B6>簮鍒板叿浣撴枃妗拰浣嶇疆
@@ -527,27 +527,27 @@ interface Citation {
content: string;
}
// 2. AI回答中插入引用标记
// 2. AI鍥炵瓟涓<EFBFBD>彃鍏ュ紩鐢ㄦ爣璁?
const answer = `鏍规嵁鐮旂┒鏂规<EFBFBD>[1]鍜孋RF琛ㄦ牸[2]锛岀撼鍏ユ爣鍑嗗寘鎷<E5AF98>
1. 骞撮緞18-75宀乕1]
2. 绗﹀悎璇婃柇鏍囧噯[1][2]
3. 绛剧讲鐭ユ儏鍚屾剰涔<E589B0>3]
---
📚 **参考文献**
[1] 📄 **研究方案.pdf** - 第3段 (相关度95%)
"纳入标准年龄18-75岁符合诊断标准..."
[2] 📄 **CRF表格.docx** - 第5段 (相关度92%)
"基线评估包括:诊断标准、入组时间..."
馃摎 **鍙傝€冩枃鐚?*
[1] 馃搫 **鐮旂┒鏂规<EFBFBD>.pdf** - 绗?娈?(鐩稿叧搴?5%)
"绾冲叆鏍囧噯锛氬勾榫?8-75宀侊紝绗﹀悎璇婃柇鏍囧噯..."
[2] 馃搫 **CRF琛ㄦ牸.docx** - 绗?娈?(鐩稿叧搴?2%)
"鍩虹嚎璇勪及鍖呮嫭锛氳瘖鏂<EFBFBD>爣鍑嗐€佸叆缁勬椂闂?.."
`;
// 3. 鍓嶇<E98D93>楂樹寒鏄剧ず寮曠敤
// 点击[1]跳转到引用详情
// 鐐瑰嚮[1]璺宠浆鍒板紩鐢ㄨ<E990A2>鎯?
```
**建议**: Phase 3实施,作为体验优化
**寤鸿<EFBFBD>**: Phase 3瀹炴柦锛屼綔涓轰綋楠屼紭鍖?
**预计工作量**: 3-4
**棰勮<EFBFBD>宸ヤ綔閲?*: 3-4澶?
---
@@ -558,7 +558,7 @@ const answer = `根据研究方案[1]和CRF表格[2],纳入标准包括:
**褰撳墠鏂规<E98F82>**: 鍗曟潯璁板綍鏌ヨ<E98F8C>
**闂<><E99782>**:
- ⚠️ 如果用户问"所有患者的入组情况",需要多次查询
- 鈿狅笍 濡傛灉鐢ㄦ埛闂?鎵€鏈夋偅鑰呯殑鍏ョ粍鎯呭喌"锛岄渶瑕佸<E79195>娆℃煡璇?
**鏀硅繘鏂规<E98F82>**:
-<>寔鎵归噺鏌ヨ<E98F8C>
@@ -566,68 +566,68 @@ const answer = `根据研究方案[1]和CRF表格[2],纳入标准包括:
**寤鸿<E5AFA4>**: Phase 4瀹炴柦
**预计工作量**: 2-3
**棰勮<EFBFBD>宸ヤ綔閲?*: 2-3澶?
---
### 10. 澶氳疆瀵硅瘽浼樺寲
**当前方案**: 保留最近3轮对话
**褰撳墠鏂规<EFBFBD>**: 淇濈暀鏈€杩?杞<><E69D9E>璇?
**闂<><E99782>**:
- 鈿狅笍 闀垮<E99780>璇濆彲鑳戒涪澶遍噸瑕佷笂涓嬫枃
**鏀硅繘鏂规<E98F82>**:
- 智能上下文压缩(提取关键信息)
- 鏅鸿兘涓婁笅鏂囧帇缂╋紙鎻愬彇鍏抽敭淇℃伅锛?
- 闀挎湡璁板繂锛堝瓨鍌ㄩ噸瑕佷俊鎭<E4BF8A>埌鏁版嵁搴擄級
**寤鸿<E5AFA4>**: Phase 4瀹炴柦
**预计工作量**: 5-7
**棰勮<EFBFBD>宸ヤ綔閲?*: 5-7澶?
---
## 馃搳 鍊哄姟浼樺厛绾ф€昏<E282AC>
| 债务项 | 优先级 | 影响 | 工作量 | 建议时间 |
| 鍊哄姟椤?| 浼樺厛绾?| 褰卞搷 | 宸ヤ綔閲?| 寤鸿<E5AFA4>鏃堕棿 |
|-------|--------|------|--------|----------|
| 意图识别升级 | P1 | 准确率 | 2-3| Phase 2 |
| 上下文迁移Redis | P1 | 可用性 | 1| Phase 2 |
| Dify结果缓存 | P1 | 性能 | 1| Phase 2 |
| REDCap数据缓存 | P1 | 性能 | 1| Phase 2 |
| 文档上传API | P2 | 功能 | 2-3| Phase 3 |
| 用户绑定项目 | P2 | 功能 | 1-2| Phase 2后期 |
| Function Calling | P2 | 智能化 | 3-5| Phase 3 |
| 智能引用系统 | P2 | 体验 | 3-4| Phase 3 |
| 批量查询优化 | P3 | 功能 | 2-3| Phase 4 |
| 多轮对话优化 | P3 | 体验 | 5-7| Phase 4 |
| 鎰忓浘璇嗗埆鍗囩骇 | P1 | 鍑嗙‘鐜?| 2-3澶?| Phase 2 |
| 涓婁笅鏂囪縼绉籖edis | P1 | <EFBFBD>敤鎬?| 1澶?| Phase 2 |
| Dify缁撴灉缂撳瓨 | P1 | 鎬ц兘 | 1澶?| Phase 2 |
| REDCap鏁版嵁缂撳瓨 | P1 | 鎬ц兘 | 1澶?| Phase 2 |
| 鏂囨。涓婁紶API | P2 | 鍔熻兘 | 2-3澶?| Phase 3 |
| 鐢ㄦ埛缁戝畾椤圭洰 | P2 | 鍔熻兘 | 1-2澶?| Phase 2鍚庢湡 |
| Function Calling | P2 | 鏅鸿兘鍖?| 3-5澶?| Phase 3 |
| 鏅鸿兘寮曠敤绯荤粺 | P2 | 浣撻獙 | 3-4澶?| Phase 3 |
| 鎵归噺鏌ヨ<EFBFBD>浼樺寲 | P3 | 鍔熻兘 | 2-3澶?| Phase 4 |
| 澶氳疆瀵硅瘽浼樺寲 | P3 | 浣撻獙 | 5-7澶?| Phase 4 |
---
## 馃幆 Phase 2 鍊哄姟娓呭伩璁″垝
### Week 1-2: 鎬ц兘浼樺寲
- [ ] 上下文迁移到Redis1天
- [ ] Dify结果缓存1天
- [ ] REDCap数据缓存1天
- [ ] 涓婁笅鏂囪縼绉诲埌Redis锛?澶╋級
- [ ] Dify缁撴灉缂撳瓨锛?澶╋級
- [ ] REDCap鏁版嵁缂撳瓨锛?澶╋級
- [ ] 鎬ц兘娴嬭瘯涓庤皟浼橈紙1澶╋級
**棰勬湡鏁堟灉**:
- 响应时间从4.8秒降到2-3秒
- 支持分布式部署
- 鍝嶅簲鏃堕棿浠?.8绉掗檷鍒?-3绉?
- <EFBFBD>寔鍒嗗竷寮忛儴缃?
- 鏈嶅姟閲嶅惎涓嶄涪澶变笂涓嬫枃
### Week 3-4: 鎰忓浘璇嗗埆鍗囩骇
- [ ] 实现LLM意图判断2天
- [ ] A/B测试对比1天
- [ ] 上线灰度发布1天
- [ ] 瀹炵幇LLM鎰忓浘鍒ゆ柇锛?澶╋級
- [ ] A/B娴嬭瘯瀵规瘮锛?澶╋級
- [ ] 涓婄嚎鐏板害鍙戝竷锛?澶╋級
**棰勬湡鏁堟灉**:
- 意图识别准确率保持100%
- 鎰忓浘璇嗗埆鍑嗙‘鐜囦繚鎸?00%
-<>寔澶嶆潅鑷<E6BD85>劧璇<E58AA7>█琛ㄨ揪
### Week 5: 多项目支持
- [ ] 用户绑定默认项目2天
### Week 5: 澶氶」鐩<EFBFBD>敮鎸?
- [ ] 鐢ㄦ埛缁戝畾榛樿<EFBFBD>椤圭洰锛?澶╋級
**棰勬湡鏁堟灉**:
-<>寔澶氫釜IIT椤圭洰骞惰<E9AA9E>
@@ -638,17 +638,17 @@ const answer = `根据研究方案[1]和CRF表格[2],纳入标准包括:
### 宸叉竻鍋垮€哄姟
| 债务项 | 清偿时间 | 方案 |
| 鍊哄姟椤?| 娓呭伩鏃堕棿 | 鏂规<E98F82> |
|-------|---------|------|
| AI骞昏<E9AA9E><EFBFBD><E99782> | 2026-01-03 | RAG鏁版嵁娉ㄥ叆 + 涓ユ牸System Prompt |
| 上下文丢失 | 2026-01-03 | SessionMemory最近3轮 |
| 响应速度慢 | 2026-01-04 | 优化意图识别 + 异步处理 |
| 涓婁笅鏂囦涪澶?| 2026-01-03 | SessionMemory锛堟渶杩?杞<> |
| 鍝嶅簲閫熷害鎱?| 2026-01-04 | 浼樺寲鎰忓浘璇嗗埆 + 寮傛<E5AFAE>澶勭悊 |
### 杩涜<E69DA9><EFBFBD>€哄姟
| 债务项 | 负责人 | 预计完成 |
| 鍊哄姟椤?| 璐熻矗浜?| 棰勮<E6A3B0>瀹屾垚 |
|-------|--------|----------|
| | - | - |
| 鏃?| - | - |
### 寰呭<E5AFB0>鐞嗗€哄姟
@@ -658,16 +658,17 @@ const answer = `根据研究方案[1]和CRF表格[2],纳入标准包括:
## 馃敆 鐩稿叧鏂囨。
- [IIT Manager Agent 技术路径与架构设计](../02-技术设计/IIT Manager Agent 技术路径与架构设计.md)
- [Phase1.5-AI对话能力开发计划](../04-开发计划/Phase1.5-AI对话能力开发计划.md)
- [MVP开发任务清单](../04-开发计划/MVP开发任务清单.md)
- [IIT Manager Agent 鎶€鏈<EFBFBD>矾寰勪笌鏋舵瀯璁捐<EFBFBD>](../02-鎶€鏈<EFBFBD><EFBFBD>璁?IIT Manager Agent 鎶€鏈<EFBFBD>矾寰勪笌鏋舵瀯璁捐<EFBFBD>.md)
- [Phase1.5-AI瀵硅瘽鑳藉姏寮€鍙戣<EFBFBD>鍒抅(../04-寮€鍙戣<E98D99>鍒?Phase1.5-AI瀵硅瘽鑳藉姏寮€鍙戣<E98D99>鍒?md)
- [MVP寮€鍙戜换鍔℃竻鍗昡(../04-寮€鍙戣<E98D99>鍒?MVP寮€鍙戜换鍔℃竻鍗?md)
---
**文档维护**: 技术团队
**最后更新**: 2026-01-04
**鏂囨。缁存姢**: 鎶€鏈<EFBFBD>洟闃?
**鏈€鍚庢洿鏂?*: 2026-01-04
**鐗堟湰鍘嗗彶**:
- v1.0 (2026-01-04): 初始版本Phase 1.5完成后整理
- v1.0 (2026-01-04): 鍒濆<EFBFBD>鐗堟湰锛孭hase 1.5瀹屾垚鍚庢暣鐞?