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:
@@ -1,31 +1,31 @@
|
||||
# IIT Manager Agent 鎶€鏈<E282AC>€哄姟娓呭崟
|
||||
|
||||
**鏂囨。鐗堟湰**: v1.0
|
||||
**最后更新**: 2026-01-04
|
||||
**鏈€鍚庢洿鏂?*: 2026-01-04
|
||||
**褰撳墠闃舵<E99783>**: Phase 1.5 瀹屾垚
|
||||
|
||||
---
|
||||
|
||||
## 馃搵 鏂囨。璇存槑
|
||||
|
||||
本文档记录IIT Manager Agent模块的技术债务,包括当前的临时方案、已知限制、待优化项,以及未来改进计划。
|
||||
鏈<EFBFBD>枃妗h<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>兘鏃犳硶姝g‘璇嗗埆鎰忓浘
|
||||
- 例如:"帮我看一下那个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>鐗瑰畾鎮h€呰<EFBFBD>褰?
|
||||
2. count_records - 缁熻<EFBFBD>鎮h€呮暟閲?
|
||||
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: 先使用方案A(LLM判断),快速验证效果
|
||||
- Phase 3: 如果量大,再切换到方案B(BERT模型)
|
||||
- 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. 存回Redis(30分钟过期)
|
||||
// 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. 生成缓存key(query的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绉掞級
|
||||
- 鈿狅笍 鎮h€呭熀鏈<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分钟 | 变化频率低 |
|
||||
| 鎮h€呭熀鏈<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>簮鍒板叿浣撴枃妗e拰浣嶇疆
|
||||
@@ -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: 鎬ц兘浼樺寲
|
||||
- [ ] 上下文迁移到Redis(1天)
|
||||
- [ ] 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瀹屾垚鍚庢暣鐞?
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user