当前位置: 首页 > article >正文

Pharma Agent:从文档 QA 到智能监管合规助手

一、起因去年秋天,我们的 RA(法规事务)团队在准备一个 IND 申请,涉及某小分子靶向药的临床前安全性综述。团队里有个同事叫小林,她需要在 FDA 的 2000 多页 guidance document 里找到关于"杂质阈值"的具体条款,同时对比 ICH Q3A 和 Q3B 的差异。她给我发消息:“我在 CTRL+F,但不知道该搜什么关键词。”那一刻我意识到,问题不是"文档太多",而是人类语言和文档语言之间存在一道鸿沟。她不知道 FDA 用的是 “threshold of toxicological concern (TTC)”,而不是"杂质阈值"。这就是我们开始做 Pharma Agent 的原点。二、为什么不直接用 ChatGPT?这是每个甲方第一个问题,也是我被问烂了的问题。简单说三个字:不可信赖。医药行业的文档 QA 有几个硬约束:约束项通用 LLMPharma Agent答案溯源无法精确定位必须附 chunk 来源 + 页码幻觉风险高(训练数据截止)低(锚定本地文档)数据合规企业数据上传第三方私有部署 / VPC 隔离版本管控无guidance 版本必须对应多语言监管文本混淆中英日分库更关键的是:RA 的同事如果用 ChatGPT 给出了错误的合规建议,那这不是"AI 错了",是她的职业责任。所以我们做的系统,每一个答案必须有来源,来源必须可点击跳转,原文必须可复核。这不是好不好的问题,是能不能用的问题。三、系统架构:先看整体架构图:图注:整体分为三层——文档摄入层(Ingestion Pipeline)、检索增强层(RAG Core)、Agent 决策层(Agentic Loop)。生产环境部署在私有云,LLM 走 Azure OpenAI 的 VPC Endpoint。核心设计决策有几个,我逐一拆开说:3.1 文档分层策略(这是最容易被忽视的地方)医药文档不是普通 PDF。FDA guidance、ICH 指南、SOP、CTD 模块、临床方案——它们的结构完全不同,不能用同一套 chunking 策略。我们最终采用的是语义感知的层级分块:文档类型 Chunk 策略 Chunk Size ───────────────────────────────────────────────────────────── FDA Guidance 按 Section 标题分块 + overlap 800 tokens ICH Guidelines 按条款编号分块(如 Q3A 3.1) 600 tokens 内部 SOP 按步骤编号分块 400 tokens 临床方案 (CSP) 按章节 + 表格独立提取 1000 tokens这个配置是跑了 200+ 次 RAGAS 评估才稳定下来的,不是拍脑袋的。3.2 向量化:用什么 Embedding 模型我们测试过三种方案:OpenAItext-embedding-3-large:效果最好,但数据出境,Pass。BAAI/bge-m3(本地):多语言强,中英日混合文档表现稳定,最终选用。sentence-transformers/all-MiniLM-L6-v2:速度快,但专业术语召回差,淘汰。选 bge-m3 的关键原因:我们有大量中文注册申报文件和日本 PMDA 提交文本,多语言支持是刚需。3.3 检索策略:Hybrid Search + Reranker单纯的向量检索在专业术语上表现很差。比如"ICH Q3A"这个查询,向量相似度把它当成普通词,但它是一个精确的文档编号,BM25 关键词检索更准。所以我们用的是Hybrid Search(向量 + BM25)+ BGE-Reranker 精排:用户 Query │ ├──→ 向量检索(Top-20)──┐ │ ├──→ RRF Fusion(Top-40)──→ BGE-Reranker──→ Top-5 └──→ BM25 检索(Top-20)─┘RRF(Reciprocal Rank Fusion)是个简单但有效的融合算法,不需要学习参数。四、核心代码4.1 文档摄入 Pipeline# pharma_ingestion.py# 医药文档摄入 Pipeline(脱敏版)# 依赖:langchain, pymupdf, sentence-transformers, qdrant-clientimportfitz# PyMuPDFimportrefromdataclassesimportdataclassfromtypingimportList,Optionalfromlangchain.text_splitterimportRecursiveCharacterTextSplitter@dataclassclassPharmaChunk:"""结构化 chunk,带有监管文档专属元数据"""content:strsource_file:strdoc_type:str# "FDA_GUIDANCE" / "ICH" / "SOP" / "CSP"section_id:str# 如 "3.1.2" 或 "Section IV.B"page_num:intchunk_index:intlanguage:str# "en" / "zh" / "ja"classPharmaDocumentProcessor:""" 医药文档处理器 核心设计:不同文档类型用不同策略,而非一刀切 """# 按文档类型配置 chunk 参数CHUNK_CONFIG={"FDA_GUIDANCE":{"chunk_size":800,"chunk_overlap":150},"ICH":{"chunk_size":600,"chunk_overlap":100},"SOP":{"chunk_size":400,"chunk_overlap":80},"CSP":{"chunk_size":1000,"chunk_overlap":200},"DEFAULT":{"chunk_size":700,"chunk_overlap":120},}# ICH 文档的条款编号正则(如 Q3A, Q7, E6 等)ICH_SECTION_PATTERN=re.compile(r'^(\d+\.[\d\.]*|[A-Z]\.|Appendix\s+[A-Z\d]+)',re.MULTILINE)def__init__(self,embedding_model_path:str="BAAI/bge-m3"):self.embedding_model_path=embedding_model_path# 实际项目中在这里初始化 embedding model# self.embedder = FlagModel(embedding_model_path, ...)defdetect_doc_type(self,filename:str,first_page_text:str)-str:""" 自动识别文档类型 实际项目中还会结合文件路径命名规范(如 /sop/ 目录) """filename_upper=filename.upper()ifany(kwinfilename_upperforkwin["FDA","GUIDANCE","DRAFT_GUIDANCE"]):return"FDA_GUIDANCE"ifre.search(r'\bICH\s+[EQS]\d+',first_page_text,re.IGNORECASE):return"ICH"if"SOP"infilename_upperor"STANDARD_OPERATING"infilename_upper:return"SOP"ifany(kwinfilename_upperforkwin["PROTOCOL","CSP","CLINICAL_STUDY"]):return"CSP"return"DEFAULT"defextract_section_id(self,text_block:str,doc_type:str)-str:"""从文本块开头提取章节编号"""ifdoc_type=="ICH":m=self.ICH_SECTION_PATTERN.match(text_block.strip())returnm.group(0).strip()ifmelse"N/A"# 通用:提取开头数字编号m=re.match(r'^(\d+(\.\d+)*)\s',text_block.strip())returnm.group(1)ifmelse"N/A"defprocess_pdf(self,pdf_path:str)-List[PharmaChunk]:""" 处理单个 PDF,返

相关文章:

Pharma Agent:从文档 QA 到智能监管合规助手

一、起因 去年秋天,我们的 RA(法规事务)团队在准备一个 IND 申请,涉及某小分子靶向药的临床前安全性综述。团队里有个同事叫小林,她需要在 FDA 的 2000 多页 guidance document 里找到关于"杂质阈值"的具体条款,同时对比 ICH Q3A 和 Q3B 的差异。 她给我发消…...

CompressO终极压缩神器:免费开源的一键瘦身工具,释放95%存储空间

CompressO终极压缩神器:免费开源的一键瘦身工具,释放95%存储空间 【免费下载链接】compressO Convert any video/image into a tiny size. 100% free & open-source. Available for Mac, Windows & Linux. 项目地址: https://gitcode.com/gh_m…...

ETCD Keeper终极指南:3分钟掌握可视化etcd管理工具

ETCD Keeper终极指南:3分钟掌握可视化etcd管理工具 【免费下载链接】etcdkeeper web ui client for etcd 项目地址: https://gitcode.com/gh_mirrors/et/etcdkeeper ETCD Keeper是一款专为etcd设计的轻量级Web UI客户端工具,它通过直观的图形界面…...

DDD难落地?就让AI干吧! - cleanddd-skills介绍恐

AI训练存储选型的演进路线 第一阶段:单机直连时代 早期的深度学习数据集较小,模型训练通常在单台服务器或单张GPU卡上完成。此时直接将数据存储在训练机器的本地NVMe SSD/HDD上。 其优势在于IO延迟最低,吞吐量极高,也就是“数据离…...

基于File-Based App开发MVP项目汤

Issue 概述 先来看看提交这个 Issue 的作者是为什么想到这个点子的,以及他初步的核心设计概念。?? 本 PR 实现了 Apache Gravitino 与 SeaTunnel 的集成,将其作为非关系型连接器的外部元数据服务。通过 Gravitino 的 REST API 自动获取表结构和元数据&…...

FastAPI项目半夜报警吵醒你?聊聊告警这事儿怎么搞!翱

Issue 概述 先来看看提交这个 Issue 的作者是为什么想到这个点子的,以及他初步的核心设计概念。?? 本 PR 实现了 Apache Gravitino 与 SeaTunnel 的集成,将其作为非关系型连接器的外部元数据服务。通过 Gravitino 的 REST API 自动获取表结构和元数据&…...

解锁毕业论文新姿势:书匠策AI,你的学术超级英雄![特殊字符]

在学术的征途中,毕业论文就像是一座巍峨的山峰,让无数英雄好汉望而却步。选题迷茫、资料难寻、结构混乱、写作卡壳……这些问题像是一道道难关,考验着每一位学子的智慧和毅力。但别怕,今天我要给大家介绍一位学术界的超级英雄——…...

【技术解析】llama.cpp中的量化计算与RVV加速实现

1. llama.cpp中的量化计算机制剖析 在边缘计算设备上运行大语言模型时,量化技术就像给模型"瘦身"的魔法。llama.cpp作为轻量级推理框架,其量化实现堪称教科书级别的优化案例。我曾在树莓派上实测过量化效果,Q4_0模型体积只有原版的…...

ARM 架构 JuiceFS 性能优化:基于 MLPerf 的实践与调优愿

Qt是一个跨平台C图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本笔记将重点介绍QSpinBox数值微调组件的常用方法及灵活应用。…...

SQL如何优化频繁的数据分页操作_ROW_NUMBER索引技巧

OFFSET FETCH 越翻越慢是因为OFFSET必须顺序扫描并跳过前N行,无法直接定位,导致大数据量时性能骤降;仅适用于前端下拉加载前几页或极小分页场景。为什么 OFFSET FETCH 越翻越慢?因为 OFFSET 会强制数据库跳过前面所有行&#xff0…...

Serverless+WebAssembly:构建下一代高性能后端接口实战

随着云原生技术的普及,Serverless架构凭借按需计费、弹性伸缩的特性,成为后端接口开发的主流选择之一,但传统Serverless平台依赖Node.js、Python等预置语言环境,冷启动延迟高、资源隔离性弱的问题始终制约着其在高性能场景的应用。…...

QModMaster:如何用开源Qt框架构建专业级Modbus工业通信解决方案

QModMaster:如何用开源Qt框架构建专业级Modbus工业通信解决方案 【免费下载链接】qModbusMaster Fork of QModMaster (https://sourceforge.net/p/qmodmaster/code/ci/default/tree/) 项目地址: https://gitcode.com/gh_mirrors/qm/qModbusMaster QModMaster…...

3步轻松备份你的QQ空间:GetQzonehistory完整导出指南

3步轻松备份你的QQ空间:GetQzonehistory完整导出指南 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否还记得十年前在QQ空间写下的第一条说说?那些青涩的文…...

蓝牙耳机天线匹配调试实战:从仪器校准到阻抗调整的完整流程

蓝牙耳机天线匹配调试实战:从仪器校准到阻抗调整的完整流程 在无线音频设备领域,蓝牙耳机的射频性能直接决定了用户体验。天线作为信号收发的门户,其匹配调试是产品开发中最关键的环节之一。本文将深入剖析从仪器准备到参数优化的全流程操作要…...

从BERT到Qwen-MoE:SITS2026揭示多语言参数共享的5个致命假设(附2024-2026演进时间轴)

第一章:SITS2026演讲:大模型多语言支持 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026主会场,来自全球12个国家的37个研究团队联合发布了《大模型多语言能力基准v2.1》,首次将低资源语言(如斯瓦希里语、伊…...

从数学原理到Python实现:最小公倍数算法的前世今生

从数学原理到Python实现:最小公倍数算法的前世今生 在数字的海洋中,两个看似毫不相关的整数之间,往往隐藏着精妙的数学联系。最小公倍数(LCM)作为连接这些数字的桥梁,不仅在现代编程中扮演着重要角色&#…...

Rust错误处理实战

Rust错误处理实战后端转 Rust 的萌新,ID "第一程序员"——名字大,人很菜(暂时)。正在跟所有权和生命周期死磕,日常记录 Rust 学习路上的踩坑经验和"啊哈时刻",代码片段保证能跑。保持学…...

【视觉理解奇点临界点】:2026奇点大会公布的7项VLM关键指标中,已有4项突破人类标注一致性阈值

第一章:【视觉理解奇点临界点】:2026奇点大会公布的7项VLM关键指标中,已有4项突破人类标注一致性阈值 2026奇点智能技术大会(https://ml-summit.org) 视觉语言模型(VLM)正经历一场静默却决定性的范式迁移——其核心判…...

Rust构建系统实战

Rust构建系统实战后端转 Rust 的萌新,ID "第一程序员"——名字大,人很菜(暂时)。正在跟所有权和生命周期死磕,日常记录 Rust 学习路上的踩坑经验和"啊哈时刻",代码片段保证能跑。保持学…...

HagiCode Desktop 混合分发架构解析:如何用 PP 加速大文件下载闻

一、Actor 模型:不是并发技巧,而是领域单元 Actor 模型的本质是: Actor 是独立运行的实体 Actor 之间只通过消息交互 Actor 内部状态不可被外部直接访问 Actor 自行决定如何处理收到的消息 Actor 模型真正解决的是: 如何在不共享状…...

NLopt实战避坑:C++调用时那些官方文档没细说的坑(附完整代码示例)

NLopt实战避坑:C调用时那些官方文档没细说的坑(附完整代码示例) 在工程实践中,非线性优化问题无处不在。从机器人路径规划到金融衍生品定价,从计算机视觉中的相机标定到工业设计中的参数优化,NLopt作为一款…...

NewPing超声波测距库:嵌入式实时测距的非阻塞实现

1. NewPing超声波传感器驱动库深度解析:面向嵌入式系统的高性能测距实现1.1 库定位与工程价值NewPing 是一款专为嵌入式平台(尤其是Arduino生态)设计的超声波传感器驱动库,其核心目标并非简单封装硬件时序,而是系统性解…...

UniApp分包避坑指南:pages.json配置常见错误与各平台大小限制详解

UniApp分包实战手册:从配置陷阱到多平台适配策略 第一次在UniApp项目里尝试分包时,我盯着微信开发者工具里那个刺眼的"主包超限"警告整整十分钟。这就像玩俄罗斯方块——明明每个模块都精心设计,却在最后关头因为几KB的差距功亏一篑…...

免费查AI率平台横评:知网、维普、万方检测结果到底差多少

免费查AI率平台横评:知网、维普、万方检测结果到底差多少 这两天帮学妹查论文的AI率,同一篇文章分别在知网、维普、万方上检测了一遍,结果把我整懵了——三个平台给出的AI率差了将近20个百分点。 这不是个例。我后来又拿了四五篇不同专业的论…...

Python的__getattr__动态代理

Python魔法方法__getattr__的奇妙世界 在Python中,__getattr__是一个特殊方法,它允许开发者动态拦截未定义属性的访问,为对象行为注入无限可能。无论是实现懒加载、动态API调用,还是构建灵活代理模式,__getattr__都能…...

技术方案深度解析:Cursor-Free-VIP实现AI编程工具功能解锁

技术方案深度解析:Cursor-Free-VIP实现AI编程工具功能解锁 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your…...

小红背单词【牛客tracker 每日一题】

小红背单词 时间限制:1秒 空间限制:256M 知识点:小红书 哈希模拟 网页链接 牛客tracker 牛客tracker & 每日一题,完成每日打卡,即可获得牛币。获得相应数量的牛币,能在【牛币兑换中心】&#xff0…...

3分钟解锁Illustrator批量替换魔法:告别重复劳动的终极指南

3分钟解锁Illustrator批量替换魔法:告别重复劳动的终极指南 【免费下载链接】illustrator-scripts Adobe Illustrator scripts 项目地址: https://gitcode.com/gh_mirrors/il/illustrator-scripts 你是否曾经面对过这样的场景?客户要求将设计稿中…...

React/Vue项目部署后,刷新页面就404?一个Nginx配置帮你搞定

React/Vue项目部署后刷新页面404?Nginx配置终极解决方案 刚部署完React/Vue项目时,很多开发者都会遇到一个诡异现象:首页访问正常,但点击内部路由后再刷新页面,浏览器突然弹出404错误。这就像魔术师的手帕突然消失一样…...

大麦网智能抢票助手终极教程:一键配置快速抢票指南

大麦网智能抢票助手终极教程:一键配置快速抢票指南 【免费下载链接】Automatic_ticket_purchase 大麦网抢票脚本 项目地址: https://gitcode.com/GitHub_Trending/au/Automatic_ticket_purchase 大麦网智能抢票助手是一款高效的大麦网抢票脚本,能…...