news 2026/5/1 11:46:48

回答准确率测试

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
回答准确率测试

day26 回答准确率测试

回答准确率测试

1️⃣ 定义(通俗版)

回答准确率测试,就是:

给模型一批「有标准答案的问题」,看它给出的回答有多少是“对的”

本质是一个 评测(Evaluation)问题。


2️⃣ 数学定义(简单版)

假设你有:

  • N 个问题

  • 模型答对了 K 个

那么:

Accuracy = K / N

例如:

  • 100 个问题

  • 答对 83 个

    • 👉 准确率 = 83%

3️⃣ 在 LLM 领域的特殊性

和传统分类不同,LLM 的回答是 自然语言:

❌ 不是 “A / B / C” ✅ 而是 “一段文本”

因此 “什么叫答对” 就成了核心难点。


二、回答准确率测试的关键概念(LLM 视角)

1️⃣ 三种常见“准确”的定义

✅ 1. Exact Match(严格匹配)

模型回答 == 标准答案

✔ 简单
❌ 对 LLM 非常不友好


✅ 2. 语义等价(Semantic Match)

含义一致即可

例如:

  • 标准答案:

    “巴黎是法国的首都”

  • 模型回答:

    “法国的首都是巴黎”

✔ 更符合人类判断
❌ 需要额外模型判断


✅ 3. LLM-as-a-Judge(主流方案)

用 另一个 LLM 来判断:

“模型回答是否正确?”

这是目前工业界、论文里最常见的方法。


2️⃣ 回答准确率 ≠ 检索准确率

如果你用了 RAG(检索增强生成),要分清:

指标衡量什么
检索准确率找到的文档对不对
回答准确率最终回答对不对

三、整体 Demo 架构

┌────────────┐ │ Questions │ └─────┬──────┘ │ ┌─────────▼─────────┐ │ Chroma 向量数据库 │ ← 知识库 └─────────┬─────────┘ │ ┌─────────▼─────────┐ │ Qwen-Plus │ ← 生成回答 └─────────┬─────────┘ │ ┌─────────▼─────────┐ │ Accuracy Judge │ ← 再用 Qwen-Plus └─────────┬─────────┘ │ Accuracy

四、 Demo(可运行)

Step 0:准备 requirements.txt

openai>=1.0.0 chromadb>=0.4.22 tqdm python-dotenv

安装:

pipinstall-r requirements.txt

Step 1:配置 Qwen-Plus

⚠️ Qwen 使用 阿里云 DashScope(OpenAI 兼容接口)

importosfromopenaiimportOpenAI client=OpenAI(api_key=os.getenv("DASHSCOPE_API_KEY"),base_url="https://dashscope.aliyuncs.com/compatible-mode/v1")

Step 2:构建一个最小知识库(Chroma)

importchromadb chroma_client=chromadb.Client()collection=chroma_client.create_collection(name="demo_kb")docs=["巴黎是法国的首都。","东京是日本的首都。","北京是中国的首都。"]collection.add(documents=docs,ids=[f"doc{i}"foriinrange(len(docs))])

Step 3:定义测试问题(带标准答案)

eval_set=[{"question":"法国的首都是哪里?","answer":"巴黎"},{"question":"日本的首都是哪里?","answer":"东京"},]

Step 4:RAG + Qwen-Plus 生成回答

defanswer_question(question):# 1. 检索results=collection.query(query_texts=[question],n_results=1)context=results["documents"][0][0]# 2. 生成prompt=f""" 已知信息:{context}问题:{question}请给出简洁准确的回答。 """resp=client.chat.completions.create(model="qwen-plus",messages=[{"role":"user","content":prompt}])returnresp.choices[0].message.content.strip()

Step 5:用 LLM 判断“是否正确”(核心)

defjudge_answer(question,gt_answer,model_answer):judge_prompt=f""" 你是一个严格的评测员。 问题:{question}标准答案:{gt_answer}模型回答:{model_answer}请判断模型回答是否正确。 只回答 YES 或 NO。 """resp=client.chat.completions.create(model="qwen-plus",messages=[{"role":"user","content":judge_prompt}])returnresp.choices[0].message.content.strip().upper()=="YES"

Step 6:计算准确率

correct=0foritemineval_set:model_ans=answer_question(item["question"])is_correct=judge_answer(item["question"],item["answer"],model_ans)print(item["question"],model_ans,is_correct)ifis_correct:correct+=1accuracy=correct/len(eval_set)print(f"Accuracy:{accuracy:.2%}")
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/28 7:27:02

零基础理解VS Code的launch.json文件

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 请创建一个面向完全新手的launch.json教程,从VS Code的调试面板开始讲解,逐步解释:1) 如何创建文件 2) 最基本的配置结构 3) 如何添加第一个调试…

作者头像 李华
网站建设 2026/5/1 5:52:12

零基础学Pigx:AI带你完成第一个微服务项目

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 为编程新手创建一个Pigx框架学习项目,要求:1. 构建一个最简单的用户管理微服务 2. 每个代码文件添加详细中文注释 3. 包含图文并茂的部署指南 4. 提供常见错…

作者头像 李华
网站建设 2026/4/30 12:58:03

零基础30分钟搭建个人zlib镜像站

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个最简单的个人用zlib镜像网站,要求:1. 单页面应用设计 2. 内置20本示例电子书 3. 基础搜索框 4. 无需用户系统 5. 一键导出静态网站文件。使用纯HTML…

作者头像 李华
网站建设 2026/4/30 20:50:54

零基础理解‘session创建失败‘错误及简单修复

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个新手友好的session错误学习应用,包含:1. 动画演示session工作原理 2. 交互式错误诊断向导 3. 简单代码编辑器可实时测试修复方案 4. 常见问题FAQ。使…

作者头像 李华
网站建设 2026/5/1 5:48:09

企业内网zlib镜像部署实战指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个适合企业内网部署的zlib镜像系统,要求:1. 支持LDAP/AD域认证 2. 实现IP白名单访问控制 3. 内置书籍批量导入工具 4. 支持多级部门权限管理 5. 集成日…

作者头像 李华
网站建设 2026/4/30 20:15:15

wx.request实战应用案例分享

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个wx.request实战项目,包含完整的功能实现和部署方案。点击项目生成按钮,等待项目生成完整后预览效果 最近在做一个需要调用后端API的小程序项目&…

作者头像 李华