news 2026/4/22 1:22:06

回答准确率测试

作者头像

张小明

前端开发工程师

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/18 0:25:10

RK3399开发效率革命:快马平台VS传统开发模式对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个RK3399视频监控项目对比测试:1) 传统手动开发方式 2) 使用快马平台AI生成。要求实现:RTSP视频流采集、移动侦测、异常报警、云端存储功能。需要生成…

作者头像 李华
网站建设 2026/4/22 1:03:35

Java字符串分割:传统写法与AI生成代码效率对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 请分别用传统手动编写和AI辅助两种方式实现以下Java字符串分割功能:1)处理日志文件行;2)解析URL参数;3)分割多语言文本。然后对比两者的代码行数…

作者头像 李华
网站建设 2026/4/20 0:39:27

AI如何自动生成console线驱动代码?快马平台实战

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 使用快马平台生成一个USB转console线的驱动程序,要求支持常见的CH340/PL2303等芯片,实现基本的串口通信功能。代码需要包含设备检测、波特率设置、数据收发等…

作者头像 李华
网站建设 2026/4/18 23:20:02

用AI快速开发wx.request应用

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个wx.request应用,利用快马平台的AI辅助功能,展示智能代码生成和优化。点击项目生成按钮,等待项目生成完整后预览效果 最近在开发一个小程…

作者头像 李华
网站建设 2026/4/18 2:27:28

传统开发vs神速Down:效率对比实测

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 实现一个功能完整的下载管理器,要求:1) 支持HTTP/HTTPS/FTP协议 2) 多任务并行下载 3) 下载队列管理 4) 速度限制 5) 代理设置。分别用传统手动编码和快马平…

作者头像 李华
网站建设 2026/4/21 10:22:04

如何用AI自动修复‘failed to create session‘错误

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个AI辅助调试工具,能够自动分析failed to create session. an unknown server-side error occurred while processing错误。工具应能:1. 解析错误日志…

作者头像 李华