agentic设计模式 第 19章:评估与监控
评估 AI 智能体的「有用性」等主观品质带来了超越标准客观指标的挑战。一个潜在的框架涉及使用 LLM 作为评估者。这种 LLM 作为评判者(LLM-as-a-Judge)的方法基于「有用性」的预定义标准来评估另一个 AI 智能体的输出。利用 LLM 的高级语言能力,这种方法提供细微的、类人的主观品质评估,超越了简单的关键词匹配或基于规则的评估。尽管仍在开发中,但这项技术在自动化和扩展定性评估方面显
评估与监控
本章探讨了使智能体能够系统性地评估自身性能、监控目标进展并检测运行异常的方法论。虽然第 11 章概述了目标设定与监控,第 17 章讨论了推理机制,但本章聚焦于对智能体有效性、效率及需求合规性的持续性外部测量。这包括定义指标、建立反馈循环以及实施报告系统,以确保智能体性能在运行环境中符合预期(见图 1)。
![![[Pasted image 20260119112406.png]]](https://i-blog.csdnimg.cn/direct/6bfee0faa77c42938ee5fbb4b8e97b01.png)
实际应用与用例
最常见的应用与用例:
- 实时系统中的性能跟踪: 持续监控部署在生产环境中的智能体的准确性、延迟和资源消耗(例如,客户服务聊天机器人的解决率、响应时间)
- 智能体改进的 A/B 测试: 系统性地并行比较不同智能体版本或策略的性能,以识别最优方法(例如,为物流智能体尝试两种不同的规划算法)。
- 合规性与安全审计: 生成自动化审计报告,跟踪智能体随时间对道德准则、监管要求和安全协议的遵守情况。这些报告可由人机协同中(Human-in-the-Loop)或另一个智能体进行验证,并可生成 KPI 或在发现问题时触发警报。
- 企业系统: 为了在企业系统中管理具智能体特性的 AI(Agentic AI),需要一种新的控制工具——AI「合约」。这种动态协议将 AI 委托任务的目标、规则和控制进行编码。
- 漂移检测: 随时间监控智能体输出的相关性或准确性,检测其性能何时因输入数据分布变化(概念漂移)或环境变化而下降。
- 智能体行为异常检测: 识别智能体采取的异常或意外行为,这些行为可能表明错误、恶意攻击或涌现的非预期行为。
- 学习进展评估: 对于设计为可学习的智能体,跟踪其学习曲线、特定技能的改进或在不同任务或数据集上的泛化能力。
实战代码示例
为 AI 智能体开发一个全面的评估框架是一项具有挑战性的工作,其复杂性可与一门学术学科或一本实质性出版物相媲美。这种困难源于需要考虑的众多因素,例如模型性能、用户交互、伦理影响和更广泛的社会影响。然而,对于实际实施而言,可以将重点缩小到对 AI 智能体高效有效运作至关重要的关键用例上。
智能体响应评估: 这一核心过程对于评估智能体输出的质量和准确性至关重要。它涉及确定智能体是否针对给定输入提供相关、正确、合乎逻辑、无偏见且准确的信息。评估指标可能包括事实正确性、流畅性、语法精确性以及对用户预期目的的遵循程度。
def evaluate_response_accuracy(agent_output: str, expected_output: str) -> float:
"""计算智能体回复的简单准确率分数。"""
# 这是一种非常基础的精确匹配;实际应用中应使用更复杂的指标
return 1.0 if agent_output.strip().lower() == expected_output.strip().lower() else 0.0
# Example usage
agent_response = "法国的首都是巴黎。"
ground_truth = "巴黎是法国的首都。"
score = evaluate_response_accuracy(agent_response, ground_truth)
print(f"Response accuracy: {score}")
Python 函数 evaluate_response_accuracy 通过在去除前导或尾随空格后,对智能体的输出和预期输出执行精确的不区分大小写比较,来计算 AI 智能体响应的基本准确性分数。对于精确匹配,它返回 1.0 的分数,否则返回 0.0,表示二元的正确或错误评估。这种方法虽然对于简单检查来说很直接,但不考虑释义或语义等价性等变化。
问题在于其比较方法。该函数对两个字符串执行严格的逐字符比较。在提供的示例中:
- agent_response: “法国的首都是巴黎。”
- ground_truth: “巴黎是法国的首都。”
即使在去除空格并转换为小写后,这两个字符串也不相同。因此,该函数将错误地返回 0.0 的准确性分数,尽管两个句子传达的是相同的意思。
直接比较在评估语义相似性方面存在不足,只有当智能体的响应完全匹配预期输出时才会成功。更有效的评估需要先进的自然语言处理(NLP)技术来辨别句子之间的意义。对于现实场景中的 AI 智能体彻底评估,更复杂的指标通常是不可或缺的。这些指标可以包括字符串相似性度量(如 Levenshtein 距离和 Jaccard 相似性)、关键词分析(用于特定关键词的存在或缺失)、使用嵌入模型的余弦相似性进行语义相似性分析、LLM 作为评判者(LLM-as-a-Judge)评估(稍后讨论用于评估细微的正确性和有用性),以及 RAG 特定指标(如忠实度和相关性)。
延迟监控(Latency Monitoring): 智能体操作的延迟监控在 AI 智能体响应或操作速度是关键因素的应用中至关重要。此过程测量智能体处理请求和生成输出所需的持续时间。延迟升高会对用户体验和智能体的整体有效性产生不利影响,特别是在实时或交互式环境中。在实际应用中,仅将延迟数据打印到控制台是不够的。建议将此信息记录到持久化存储系统。选项包括结构化日志文件(如 JSON)、时间序列数据库(如 InfluxDB、Prometheus)、数据仓库(如 Snowflake、BigQuery、PostgreSQL)或可观测性平台(如 Datadog、Splunk、Grafana Cloud)。
跟踪 LLM 交互的 Token 使用: 对于基于 LLM 的智能体,跟踪 token 使用对于管理成本和优化资源分配至关重要。LLM 交互的计费通常取决于处理的 token 数量(输入和输出)。因此,高效的 token 使用直接降低运营费用。此外,监控 token 计数有助于识别提示工程或响应生成过程中潜在的改进领域。
# 这只是概念性示例,实际的 token 计数依赖于所用 LLM 的 API
class LLMInteractionMonitor:
def __init__(self):
self.total_input_tokens = 0
self.total_output_tokens = 0
def record_interaction(self, prompt: str, response: str):
# 实际场景中,应使用 LLM API 提供的 token 计数器或分词器
input_tokens = len(prompt.split()) # Placeholder
output_tokens = len(response.split()) # Placeholder
self.total_input_tokens += input_tokens
self.total_output_tokens += output_tokens
print(f"Recorded interaction: Input tokens={input_tokens}, Output tokens={output_tokens}")
def get_total_tokens(self):
return self.total_input_tokens, self.total_output_tokens
# Example usage
monitor = LLMInteractionMonitor()
monitor.record_interaction("法国的首都是哪里?", "法国的首都是巴黎。")
monitor.record_interaction("给我讲个笑话。", "为什么科学家不信任原子?因为它们编造了一切!")
input_t, output_t = monitor.get_total_tokens()
print(f"Total input tokens: {input_t}, Total output tokens: {output_t}")
本节介绍了一个概念性的 Python 类 LLMInteractionMonitor,用于跟踪大语言模型交互中的 token 使用情况。该类包含输入和输出 token 的计数器。其 record_interaction 方法通过分割提示和响应字符串来模拟 token 计数。在实际实现中,将使用特定的 LLM API 分词器来获得精确的 token 计数。随着交互的发生,监控器累积输入和输出 token 的总数。get_total_tokens 方法提供对这些累积总数的访问,这对于成本管理和 LLM 使用优化至关重要。
使用 LLM 作为评判者的「有用性」自定义指标: 评估 AI 智能体的「有用性」等主观品质带来了超越标准客观指标的挑战。一个潜在的框架涉及使用 LLM 作为评估者。这种 LLM 作为评判者(LLM-as-a-Judge)的方法基于「有用性」的预定义标准来评估另一个 AI 智能体的输出。利用 LLM 的高级语言能力,这种方法提供细微的、类人的主观品质评估,超越了简单的关键词匹配或基于规则的评估。尽管仍在开发中,但这项技术在自动化和扩展定性评估方面显示出前景。
import google.generativeai as genai
import os
import json
import logging
from typing import Optional
# --- Configuration ---
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
# Set your API key as an environment variable to run this script
# For example, in your terminal: export GOOGLE_API_KEY='your_key_here'
try:
genai.configure(api_key=os.environ["GOOGLE_API_KEY"])
except KeyError:
logging.error("Error: GOOGLE_API_KEY environment variable not set.")
exit(1)
# --- LLM-as-a-Judge Rubric for Legal Survey Quality ---
LEGAL_SURVEY_RUBRIC = """
您是一位资深的法律调查方法论专家兼严谨的法律评审员。您的任务是评估给定法律调查问题的质量。
请就整体质量给出 1–5 分的评分,并附上详细理由与具体反馈。
评估维度如下:
1. **清晰度与精确性(1–5 分):**
* 1 分:极其模糊、高度歧义或令人困惑。
* 3 分:基本清晰,但仍有提升精确性的空间。
* 5 分:完全清晰、无歧义,法律术语(如适用)与意图均精确无误。
2. **中立性与偏见(1–5 分):**
* 1 分:高度诱导或带有偏见,明显将受访者推向特定答案。
* 3 分:略有诱导性,或可被解读为引导。
* 5 分:完全中立、客观,无任何诱导性措辞或带有倾向的用词。
3. **相关性与聚焦度(1–5 分):**
* 1 分:与调查主题无关或超出范围。
* 3 分:仅松散相关,聚焦度不足。
* 5 分:与调查目标直接相关,并围绕单一概念充分聚焦。
4. **完整性(1–5 分):**
* 1 分:遗漏回答所需的关键信息,或提供的背景不足。
* 3 分:大体完整,但仍有细节缺失。
* 5 分:为受访者提供回答所需的全部背景与信息。
5. **对目标受众的适宜性(1–5 分):**
* 1 分:使用目标受众无法理解的行话,或对专家而言过于简单。
* 3 分:总体合适,但部分术语可能晦涩或过于简化。
* 5 分:完美契合目标受众的法律知识水平与背景。
**输出格式:**
您的响应必须为一个 JSON 对象,包含以下键:
* `overall_score`:1–5 的整数(各维度平均分,或您的整体判断)。
* `rationale`:简明总结评分原因,突出主要优缺点。
* `detailed_feedback`:按上述维度逐条列出反馈(清晰度、中立性、相关性、完整性、受众适宜性),并给出具体改进建议。
* `concerns`:列出任何具体的法律、伦理或方法论方面的顾虑。
* `recommended_action`:简要建议(例如“修改以保证中立性”“无需修改直接采用”“需澄清范围”)。
"""
class LLMJudgeForLegalSurvey:
"""使用生成式 AI 模型评估法律调查问题的类。"""
def __init__(self, model_name: str = 'gemini-1.5-flash-latest', temperature: float = 0.2):
"""
初始化 LLM 评判器。
参数:
model_name (str): 要使用的 Gemini 模型名称。
推荐使用 'gemini-1.5-flash-latest' 以获得更快的速度和更低的成本。
'gemini-1.5-pro-latest' 提供最高质量。
temperature (float): 生成温度。较低的值更适合确定性评估。
"""
self.model = genai.GenerativeModel(model_name)
self.temperature = temperature
def _generate_prompt(self, survey_question: str) -> str:
"""为 LLM 评判器构建完整提示。"""
return f"{LEGAL_SURVEY_RUBRIC}\n\n---\n**待评估的法律调查问题:**\n{survey_question}\n---"
def judge_survey_question(self, survey_question: str) -> Optional[dict]:
"""
使用 LLM 评估单个法律调查问题的质量。
参数:
survey_question (str): 待评估的法律调查问题。
返回:
Optional[dict]: 包含 LLM 评估结果的字典;若发生错误则返回 None。
"""
full_prompt = self._generate_prompt(survey_question)
try:
logging.info(f"Sending request to '{self.model.model_name}' for judgment...")
response = self.model.generate_content(
full_prompt,
generation_config=genai.types.GenerationConfig(
temperature=self.temperature,
response_mime_type="application/json"
)
)
# 检查是否因内容审核或其他原因导致返回空响应。
if not response.parts:
safety_ratings = response.prompt_feedback.safety_ratings
logging.error(f"LLM 响应为空或被阻止。安全评级:{safety_ratings}")
return None
return json.loads(response.text)
except json.JSONDecodeError:
logging.error(f"无法将 LLM 响应解码为 JSON。原始响应:{response.text}")
return None
except Exception as e:
logging.error(f"LLM 评判过程中发生意外错误:{e}")
return None
# --- Example Usage ---
if __name__ == "__main__":
judge = LLMJudgeForLegalSurvey()
# --- Good Example ---
good_legal_survey_question = """
您是否同意,在满足联邦最高法院所确立的原创性标准的前提下,瑞士现行的知识产权法律足以充分保护新兴的人工智能生成内容?
(请单选:非常不同意、不同意、中立、同意、非常同意)
"""
print("\n--- 评估优质法律调查问题 ---")
judgment_good = judge.judge_survey_question(good_legal_survey_question)
if judgment_good:
print(json.dumps(judgment_good, indent=2))
# --- 有偏见/差示例 ---
biased_legal_survey_question = """
您难道不同意像 FADP 这样过于严格的数据隐私法律正在阻碍瑞士必要的技术创新和经济增长吗?
(单选:是,否)
"""
print("\n--- 评估有偏见的法律调查问题 ---")
judgment_biased = judge.judge_survey_question(biased_legal_survey_question)
if judgment_biased:
print(json.dumps(judgment_biased, indent=2))
# --- 模糊/含糊示例 ---
vague_legal_survey_question = """
您对法律科技有什么看法?
"""
print("\n--- 评估模糊法律调查问题 ---")
judgment_vague = judge.judge_survey_question(vague_legal_survey_question)
if judgment_vague:
print(json.dumps(judgment_vague, indent=2))
该 Python 代码定义了一个类 LLMJudgeForLegalSurvey,旨在使用生成式 AI 模型评估法律调查问题的质量。它利用 google.generativeai 库与 Gemini 模型进行交互。
核心功能涉及将调查问题与详细的评估标准一起发送到模型。该标准指定了评判调查问题的五个标准:清晰度与精确性、中立性与偏见、相关性与聚焦、完整性以及对受众的适当性。对于每个标准,分配 1 到 5 的分数,并且输出中需要详细的理由和反馈。代码构建一个包含标准和待评估调查问题的提示。
judge_survey_question 方法将此提示发送到配置的 Gemini 模型,请求根据定义的结构格式化的 JSON 响应。预期的输出 JSON 包括总体分数、摘要理由、每个标准的详细反馈、关注点列表以及推荐操作。该类处理 AI 模型交互期间的潜在错误,例如 JSON 解码问题或空响应。该脚本通过评估法律调查问题的示例来演示其操作,说明 AI 如何基于预定义标准评估质量。
在结束之前,让我们考虑各种评估方法的优缺点。
| 评估方法 | 优势 | 劣势 |
|---|---|---|
| 人工评估 | 捕捉细微行为 | 难以扩展、成本高且耗时,因为涉及主观的人为因素。 |
| LLM 作为评判者 | 一致、高效且可扩展 | 中间步骤可能被忽略,受 LLM 能力限制。 |
| 自动化指标 | 可扩展、高效且客观 | 在捕捉完整能力方面可能存在局限性。 |
智能体轨迹
评估智能体的轨迹至关重要,因为传统的软件测试是不够的。标准代码产生可预测的通过/失败结果,而智能体以概率方式运行,需要对最终输出和智能体轨迹——达到解决方案所采取的步骤序列——进行定性评估。评估多智能体系统具有挑战性,因为它们不断变化。这需要开发超越个体性能的复杂指标,以衡量沟通和团队合作的有效性。此外,环境本身不是静态的,要求评估方法(包括测试用例)随时间适应。
这涉及检查决策质量、推理过程和整体结果。实施自动化评估是有价值的,特别是对于原型阶段之后的开发。分析轨迹和工具使用包括评估智能体实现目标所采用的步骤,如工具选择、策略和任务效率。例如,处理客户产品查询的智能体可能理想地遵循涉及意图确定、数据库搜索工具使用、结果审查和报告生成的轨迹。智能体的实际操作与这个预期的或真实的(ground truth)轨迹进行比较,以识别错误和低效。比较方法包括精确匹配(要求与理想序列完美匹配)、顺序匹配(正确操作按顺序,允许额外步骤)、任意顺序匹配(正确操作以任意顺序,允许额外步骤)、精确度(测量预测操作的相关性)、召回率(测量捕获多少基本操作)和单工具使用(检查特定操作)。指标选择取决于特定的智能体需求,高风险场景可能要求精确匹配,而更灵活的情况可能使用顺序或任意顺序匹配。
AI 智能体的评估涉及两种主要方法:使用测试文件和使用评估集(evalset)文件。测试文件采用 JSON 格式,代表单个、简单的智能体-模型交互或会话,非常适合在积极开发期间进行单元测试,专注于快速执行和简单的会话复杂性。每个测试文件包含一个具有多个回合的单个会话,其中回合是用户-智能体交互,包括用户查询、预期工具使用轨迹、中间智能体响应和最终响应。例如,测试文件可能详细说明用户请求「Turn off device_2 in the Bedroom」,指定智能体使用 set_device_info 工具及参数如 location: Bedroom、device_id: device_2 和 status: OFF,以及预期的最终响应「I have set the device_2 status to off」。测试文件可以组织到文件夹中,并可能包含一个 test_config.json 文件来定义评估标准。评估集文件利用称为 evalset 的数据集来评估交互,包含多个可能很长的会话,适合模拟复杂的多回合对话和集成测试。评估集文件包含多个 evals,每个代表一个独立的会话,具有一个或多个回合,包括用户查询、预期工具使用、中间响应和参考最终响应。示例评估集可能包括一个会话,其中用户首先询问「What can you do?」,然后说「Roll a 10 sided dice twice and then check if 9 is a prime or not」,定义预期的 roll_die 工具调用和 check_prime 工具调用,以及总结骰子投掷和素数检查的最终响应。
多智能体: 评估具有多个智能体的复杂 AI 系统很像评估团队项目。由于有许多步骤和交接,其复杂性是一个优势,允许您检查每个阶段的工作质量。您可以检查每个单独的「智能体」执行其特定工作的情况,但也必须评估整个系统作为一个整体的表现。
为此,您需要提出关于团队动态的关键问题,并通过具体示例支持:
- 智能体是否有效合作?例如,在「航班预订智能体」确保航班后,它是否成功地将正确的日期和目的地传递给「酒店预订智能体」?合作失败可能导致为错误的周预订酒店。
- 它们是否制定了良好的计划并坚持执行?想象一下,计划是先预订航班,然后预订酒店。如果「酒店智能体」在航班确认之前尝试预订房间,它就偏离了计划。您还要检查智能体是否卡住了,例如,无休止地搜索「完美」的租车,永远不进入下一步。
- 是否为正确的任务选择了正确的智能体?如果用户询问旅行的天气,系统应该使用提供实时数据的专门「天气智能体」。如果它使用「通用知识智能体」给出像「夏天通常很温暖」这样的通用答案,则它为这项工作选择了错误的工具。
-
- 最后,添加更多智能体是否会提高性能?如果您向团队添加新的「餐厅预订智能体」,它是否会使整体旅行规划更好、更有效率?还是它会造成冲突并减慢系统速度,表明存在可扩展性问题?
从智能体到高级承包商
最近有人提出(Agent Companion,Gulli 等人)从简单的 AI 智能体演进到高级「承包商」,从概率性的、往往不可靠的系统转向更确定性和可问责的系统,专为复杂、高风险环境设计(见图 2)。
当今常见的 AI 智能体基于简短、未充分指定的指令运行,这使它们适合简单演示,但在生产环境中脆弱,模糊性会导致失败。「承包商」模型通过在用户和 AI 之间建立严格的、正式化的关系来解决这个问题,建立在明确定义且双方同意的条款基础上,很像人类世界的法律服务协议。这一转变由四个关键支柱支撑,它们共同确保了先前超出自主系统范围的任务的清晰性、可靠性和稳健执行。
第一个支柱是正式化合约(Formalized Contract),这是一个详细的规范,作为任务的单一真实来源。它远远超出了简单的提示。例如,财务分析任务的合约不会只是说「分析上一季度的销售额」;它会要求「一份 20 页的 PDF 报告,分析 2025 年第一季度欧洲市场销售情况,包括五个特定的数据可视化、与 2024 年第一季度的比较分析,以及基于包含的供应链中断数据集的风险评估」。此合约明确定义了所需的交付成果、其精确规范、可接受的数据源、工作范围,甚至预期的计算成本和完成时间,使结果客观可验证。
第二个支柱是协商与反馈的动态生命周期(Dynamic Lifecycle of Negotiation and Feedback)。合约不是静态命令,而是对话的开始。承包商智能体可以分析初始条款并协商。例如,如果合约要求使用智能体无法访问的特定专有数据源,它可以返回反馈说:「指定的 XYZ 数据库无法访问。请提供凭据或批准使用替代公共数据库,这可能会略微改变数据的粒度。」这个协商阶段还允许智能体标记模糊性或潜在风险,在执行开始之前解决误解,防止代价高昂的失败,并确保最终输出完全符合用户的实际意图。
![![[Pasted image 20260119124204.png]]](https://i-blog.csdnimg.cn/direct/ecdcbd6e569845a0a30f9904cf40ee5c.png)
第三个支柱是质量导向的迭代执行(Quality-Focused Iterative Execution)。与设计为低延迟响应的智能体不同,承包商优先考虑正确性和质量。它基于自我验证和纠正的原则运作。例如,对于代码生成合约,智能体不会只是编写代码;它会生成多种算法方法,针对合约中定义的一套单元测试编译并运行它们,根据性能、安全性和可读性等指标为每个解决方案评分,并且只提交通过所有验证标准的版本。这种生成、审查和改进自己工作的内部循环,直到满足合约规范,对于建立对其输出的信任至关重要。
最后,第四个支柱是通过子合约的分层分解(Hierarchical Decomposition via Subcontracts)。对于重大复杂性的任务,主承包商智能体可以充当项目经理,将主要目标分解为更小、更可管理的子任务。它通过生成新的、正式的「子合约」来实现这一点。例如,「构建电子商务移动应用程序」的主合约可以由主智能体分解为「设计 UI/UX」、「开发用户身份验证模块」、「创建产品数据库模式」和「集成支付网关」的子合约。这些子合约中的每一个都是一个完整的、独立的合约,具有自己的交付成果和规范,可以分配给其他专业智能体。这种结构化分解允许系统以高度组织化和可扩展的方式处理庞大、多方面的项目,标志着 AI 从简单工具过渡到真正自主和可靠的问题解决引擎。
最终,这个承包商框架通过将正式规范、协商和可验证执行的原则直接嵌入到智能体的核心逻辑中,重新构想了 AI 交互。这种系统性方法将人工智能从一个有前途但往往不可预测的助手提升为一个能够以可审计的精度自主管理复杂项目的可靠系统。通过解决模糊性和可靠性的关键挑战,该模型为在信任和问责至关重要的关键任务领域部署 AI 铺平了道路。
Google ADK
在结束之前,让我们看一个支持评估的框架的具体示例。使用 Google ADK 进行智能体评估(见图 3)可以通过三种方法进行:基于 Web 的 UI(adk web)用于交互式评估和数据集生成、使用 pytest 的程序化集成用于融入测试管道,以及直接命令行界面(adk eval)用于适合定期构建生成和验证过程的自动化评估。
![![[Pasted image 20260119124340.png]]](https://i-blog.csdnimg.cn/direct/937d53c9500b4c3c92cc8aaf211bea59.png)
基于 Web 的 UI 可以交互式创建会话并将其保存到现有或新的评估集中,显示评估状态。Pytest 集成允许通过调用 AgentEvaluator.evaluate 将测试文件作为集成测试的一部分运行,指定智能体模块和测试文件路径。
命令行界面通过提供智能体模块路径和评估集文件来促进自动化评估,并提供指定配置文件或打印详细结果的选项。可以通过在评估集文件名后列出它们并用逗号分隔来选择更大评估集中的特定评估进行执行。
要点速览
what: 智能体系统(Agentic systems)和 LLM 在复杂、动态的环境中运行,其性能可能随时间而下降。它们的概率性和非确定性特性意味着传统的软件测试不足以确保可靠性。评估动态多智能体系统是一项重大挑战,因为它们不断变化的本质及其环境要求开发自适应测试方法和复杂指标,这些指标可以衡量超越个体性能的协作成功。数据漂移、意外交互、工具调用和偏离预期目标等问题可能在部署后出现。因此,持续评估对于衡量智能体的有效性、效率以及对运营和安全要求的遵守是必要的。
why: 标准化的评估与监控框架提供了一种系统性方法来评估和确保智能体的持续性能。这涉及为准确性、延迟和资源消耗(如 LLM 的 token 使用)定义清晰的指标。它还包括先进的技术,如分析智能体轨迹以理解推理过程,以及采用 LLM 作为评判者进行细微的定性评估。通过建立反馈循环和报告系统,该框架允许持续改进、A/B 测试以及异常或性能漂移的检测,确保智能体保持与其目标一致。
经验法则: 在将智能体部署到实时性能和可靠性至关重要的实时生产环境时使用此模式。此外,当需要系统性地比较智能体的不同版本或其底层模型以推动改进时,以及在需要合规性、安全性和伦理审计的受监管或高风险领域运营时使用它。当智能体的性能可能因数据或环境变化(漂移)而随时间下降时,或当评估复杂的智能体行为(包括操作序列(轨迹)和主观输出(如有用性)的质量)时,此模式也适用。
可视化总结
![![[Pasted image 20260119124627.png]]](https://i-blog.csdnimg.cn/direct/4275c5518aea4e57b078b2b9493365a8.png)
关键要点
- 评估智能体超越了传统测试,可以持续测量其在现实世界环境中的有效性、效率以及对需求的遵守。
- 智能体评估的实际应用包括实时系统中的性能跟踪、改进的 A/B 测试、合规性审计以及检测行为漂移或异常。
- 基本的智能体评估涉及评估响应准确性,而现实场景需要更复杂的指标,如延迟监控和基于 LLM 的智能体的 token 使用跟踪。
- 智能体轨迹,即智能体采取的步骤序列,对于评估至关重要,将实际操作与理想的真实路径进行比较,以识别错误和低效。
- ADK 通过用于单元测试的单个测试文件和用于集成测试的综合评估集文件提供结构化评估方法,两者都定义了预期的智能体行为。
- 智能体评估可以通过基于 Web 的 UI 进行交互式测试、使用 pytest 以编程方式进行 CI/CD 集成,或通过命令行界面进行自动化工作流程执行。
- 为了使 AI 在复杂、高风险任务中可靠,我们必须从简单的提示转向精确定义可验证交付成果和范围的正式「合约」。这种结构化协议允许智能体协商、澄清模糊性并迭代验证其自身工作,将其从不可预测的工具转变为可问责和可信赖的系统。
结论
总之,有效评估 AI 智能体需要超越简单的准确性检查,对其在动态环境中的性能进行持续、多方面的评估。这涉及对延迟和资源消耗等指标的实际监控,以及通过其轨迹对智能体决策过程的复杂分析。对于有用性等细微品质,LLM 作为评判者等创新方法正变得至关重要,而像 Google ADK 这样的框架为单元测试和集成测试提供了结构化工具。在多智能体系统中,挑战加剧,焦点转移到评估协作成功和有效合作上。
为确保关键应用中的可靠性,范式正从简单的、由提示驱动的智能体转向受正式协议约束的高级"承包商"。这些承包商智能体基于明确、可验证的条款运作,允许它们协商、分解任务并自我验证其工作以满足严格的质量标准。这种结构化方法将智能体从不可预测的工具转变为能够处理复杂、高风险任务的可问责系统。最终,这一演进对于建立在关键任务领域部署复杂智能体 AI 所需的信任至关重要。
参考文献
相关研究包括:
- ADK Web: https://github.com/google/adk-web
- ADK Evaluate: https://google.github.io/adk-docs/evaluate/
- Survey on Evaluation of LLM-based Agents, https://arxiv.org/abs/2503.16416
- Agent-as-a-Judge: Evaluate Agents with Agents, https://arxiv.org/abs/2410.10934
- Agent Companion, gulli et al: https://www.kaggle.com/whitepaper-agent-companion
更多推荐



所有评论(0)