Kevin Riedl

8 分钟 阅读 · 2026年6月1日

什么时候值得构建一套 LLM 评测?成本、ROI 与信任裁判

当风险、调用量以及你改动 prompt 的频率三者加起来都高于这套测试框架的成本时,构建 LLM 评测才值得。对于一个调用量低、风险低、prompt 很少变动的功能来说,一套沉重的评测流水线就是浪费钱。对于任何在规模上触及金钱、客户或你声誉的东西,它在第一次抓住一个静默回归时就值回了成本。昂贵的部分很少是模型账单;而是构建并维护一个你能信任的数据集,以及一个你能信任的裁判。这篇文章是成本与 ROI 的拆解,不是又一篇"最佳框架"清单文。

在交付 LLM 功能?

 预约免费咨询

LLM 评测到底是什么(又不是什么)

评测是一个可重复的测试,回答一个问题:这次改动让输出变好了还是变差了。它不是排行榜分数,也不是聊天窗口里的一次性凭感觉检查。在生产中,我们按三层来跑评测,最便宜的先来。

  • 确定性检查。断言、JSON-schema 校验、正则、与已知答案的精确匹配。这些在每个 pull request 上于 CI 中免费运行。它们抓住格式错误的输出、缺失的字段、损坏的工具调用以及明显的回归。如果你的模型返回结构化数据,仅这一层就能抓住大部分会出问题的东西。
  • LLM 当裁判。第二个模型给主观质量打分:摘要是否忠实,语气是否合适,是否回答了问题。当确定性检查无法表达"好"意味着什么时,你才跑这一层。它每次运行都花真金白银,所以你要有意识地跑,而不是每敲一次键就跑。
  • 人工标注的校准集。一小组由人手工评分的案例。你不用它来测试每次改动。你用它来检查你的裁判是否与人一致。没有它,LLM 裁判只是一个带 API key 的意见。

我们最常见的错误是:团队直接跳到 LLM 裁判这一层,跳过了免费的确定性层。大多数回归都能以零边际成本抓住。把模型预算花在真正需要判断的事情上。

什么时候评测值这个成本?

按三个维度来缩放你的评测深度:风险(输出错误时会发生什么)、调用量(功能运行多少次)和变更频率(prompt、模型或上下文多久变一次)。三者都高,意味着一套认真的框架值回成本。三者都低,意味着一套沉重的框架是做戏。这张表就是我们实际使用的决策规则。

风险调用量变更频率建议的评测深度
很少手工抽查。无框架。改动时手工重测。
任意仅 CI 中的确定性检查。schema 和正则能抓住在规模上重要的失败。
频繁确定性检查,加上一个小型 golden set,每次 prompt 改动时由 LLM 裁判打分。
任意完整流水线:CI 中的确定性闸门,在版本化的 golden set 上跑 LLM 裁判,模型升级时重新检查人工校准集。

诚实的解读:大多数功能都落在上面两行,需要的远比一场供应商演示所暗示的要少。昂贵的框架由静默回归的成本来证明其合理,而不是由最佳实践。如果一个错误输出让你付出一笔退款、一次合规违规或一个流失的客户,并且在有人注意到之前发生了几千次,那评测就是廉价的保险。如果一个错误输出只是一份稍差一点、反正有人会审阅的博客草稿,那它就不是。

你能信任一个 LLM 当裁判吗?

有条件地能,而且只有在你校准它时。LLM 裁判是一台测量仪器,而一台未校准的仪器会自信地撒谎。在你信任一个裁判分数之前,先检查它在校准集上与你的人工标注一致的频率有多高。如果在你在意的案例上一致性高,那这个裁判对那个任务就有用。如果不高,那这个裁判就是噪声。

需要在设计中规避的已知偏差,在 LLM 当裁判的研究中都有记录(例如 Zheng 等人,MT-Bench 和 Chatbot Arena 的工作,2023):

  • 位置偏差。在比较两个答案时,裁判倾向于偏好先展示的那个。通过交换顺序并对两次运行取平均来缓解。
  • 啰嗦偏差。即使一个简短答案既正确又完整,裁判也会过度奖励更长、更繁复的答案。在你的评分标准里明确盯着它。
  • 自我偏好。裁判倾向于偏好来自自己模型家族的输出。用一个与你正在评测的模型不同的模型来当裁判能减少这一点。

还有团队会忘记的那一条:裁判会在模型升级时漂移。当裁判模型升级后,它的分数会移动,所以上个季度的分数与今天的分数不可比。把裁判模型版本固定下来,每次更换它时都对你的人工集重新校准。一个你校准过一次、再也没检查过的裁判,是一个你已经不再理解的裁判。

一套评测流水线运行起来要花多少钱?

一次 LLM 裁判运行的成本是简单的算术:案例数乘以每个案例的 token 数,再乘以模型的每 token 价格。这里有一个算好的例子。把每个数字都当作带有声明假设的示意性估算,而不是报价。

假设。一套 200 个案例的测试集。每个案例向裁判发送大约 2,000 个输入 token(prompt、候选输出和评分标准),并收回大约 500 个输出 token(一个分数加推理)。这样每次完整运行就是 400,000 个输入 token 和 100,000 个输出 token。

  • 前沿裁判模型。假设一个示意性的混合价格,大约每百万输入 token 5 美元、每百万输出 token 15 美元。输入:0.4M x 5 美元 = 2.00 美元。输出:0.1M x 15 美元 = 1.50 美元。每次完整运行大约 3.50 美元。在每次 prompt 改动时运行,比如每月 20 次,你就在每月大约 70 美元。
  • 小型或便宜的裁判模型。假设一个示意性的混合价格大约低 10 到 20 倍。同样这套 200 个案例的运行落在 0.20 美元到 0.40 美元区间,月成本降到几美元。

所以一套合理测试集的模型账单是每次运行几美元,而不是几百美元。昂贵的项目在别处:构建这套框架的工程时间,以及为数据集打标签并让它增长的持续人力时间。这才是真正的 ROI 问题。每次运行几美元的算力几乎从来都不是决定一套评测是否值得的因素。至于每 token 价格本身的走向,参见我们的 2026 年 LLM API 成本分析

构建 golden 数据集而不把海煮干

不要试图提前覆盖每一个案例。你会花几周去猜输入,却仍然漏掉那些在生产中崩掉的案例。从小处开始,从现实中生长。

  • 从 50 到 100 个真实案例开始。从真实使用中提取,而不是编造的例子。一百个有代表性的案例告诉你的,比一千个合成案例还多。
  • 让它从生产故障中生长。每次生产中有东西崩掉,就把那个案例连同正确的预期行为加进集合里。你的数据集会变成一份你拒绝重复的每一个错误的记录。这是整个实践中 ROI 最高的单一习惯。
  • 给它做版本管理。数据集就是代码。它住在仓库里,有历史,而一个分数只在对同一个数据集版本时才可比。
  • 手工标注那些困难案例。决定你是否信任裁判的那个校准子集必须由人评分。这里没有捷径,但它很小。

这与你究竟如何构建这个功能这一更大的架构决策相连。你走的是 RAG、微调还是长上下文 会改变你的评测需要衡量什么,所以先定架构,再让它来塑造评测。

问答:小团队真的需要这个吗?

大多只需要便宜的那一层,很少需要全部。一个交付低风险功能的小团队需要 CI 中的确定性检查和发布前的一次手工抽查。那是几小时的工作,零边际成本。带 LLM 裁判和人工校准集的完整流水线,只有在功能的风险或调用量高到一个静默回归会带来伤害时才合理。便宜的那一层永远要构建。当上面那张表告诉你时再加上昂贵的层,而不是提前。

问答:RAGAS、DeepEval、promptfoo 还是自己手搓?

框架帮你省下管道工作,省不了思考。promptfoo 擅长用配置驱动的测试案例来对比 prompt 和模型。RAGAS 是为检索增强系统打造的,衡量忠实度和上下文相关性之类的东西。DeepEval 给你一套 pytest 风格的框架,内置裁判指标。它们中任何一个都胜过手搓 runner。但它们没有一个会构建你的数据集、定义"好"对你的产品意味着什么,或者把你的裁判对人校准。无论用什么工具,那份工作都是你的。挑一个框架来跳过样板代码;别指望它跳过判断。

问答:我们该多久跑一次评测?

确定性检查在每个 pull request 上跑,因为它们免费。LLM 裁判在每次有意义的 prompt、模型或上下文改动时跑,因为那是质量可能移动的时刻。人工校准检查在你每次更换裁判模型时跑,因为那是你的测量仪器可能漂移的时刻。在每次 commit 上跑一套昂贵的裁判测试集,只是在烧钱买安心。

问答:评测归谁负责?

交付功能的团队负责评测,就像他们负责测试一样。一套由独立质量团队负责的评测会腐烂,因为改 prompt 的人不是维护数据集的人。编辑 prompt 的那位产品工程师,就是应该把失败案例加进 golden set 的人。漂移到离代码越来越远的评测归属,就是悄悄死掉的评测归属。要更深入地了解这里的术语,参见我们的 术语表,要了解我们如何界定这项工作的范围,参见我们的 AI 工程服务

Kevin Riedl

"一套合理评测测试集的模型账单是每次运行几美元。真正的成本是一个你能信任的数据集,和一个你持续校准的裁判。为这两样做预算,而不是为 token。"

问答:实践中评测因何失败?

三种失败模式,按我们见到的频率排序。第一,数据集从不增长,于是它测的是上个季度的产品,漏掉了今天的故障。第二,裁判从不校准,于是它的分数是没人质疑的自信噪声。第三,评测归属于一个不碰 prompt 的人,于是它过时并被忽视。这些都不是工具问题。三者都是归属与纪律的问题。

最终思考

当风险、调用量和变更频率三者加起来超过这套框架的成本时,构建 LLM 评测才值得。按成本顺序跑这三层:每次改动时在 CI 中免费跑确定性检查,当质量确实需要一个裁决时在版本化的 golden set 上跑 LLM 裁判,再用一个小型人工标注集来让裁判保持诚实。对一套合理的测试集来说,模型账单是每次运行几美元,所以真正的 ROI 问题是构建并维护一个你能信任的数据集和裁判的人力成本,而不是 token 花费。把裁判对人工标注校准,围绕位置偏差、啰嗦偏差和自我偏好偏差来设计,并且每次升级裁判模型时都重新校准,因为裁判会漂移。用 50 到 100 个真实案例开始你的 golden 数据集,让它从生产故障中生长,而不是试图提前覆盖一切。大多数功能需要的评测机器,远比一场供应商演示所暗示的要少;少数需要一套认真的框架,因为静默回归确实昂贵。把这件事做对的团队,会把评测缩放到风险水平。做错的团队,要么在重要的东西上跳过评测,要么围着一个根本不需要它的功能造了座大教堂。

在交付 LLM 功能?

 预约免费咨询
Kevin Riedl

8 分钟 阅读 · 2026年6月1日