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

实战 Claude 的 effort 参数:让智能体“按需用力“省 token(含 Opus 4.8 更新)

TL;DR

effort 参数最早随 Claude Opus 4.5(2025 年 11 月)引入,用来控制模型“思考多努力”;在 2026 年 5 月 28 日发布的 Claude Opus 4.8 中,它进一步成熟——effort 控制被带到了 claude.ai 界面,模型也更擅长在长程任务里自我纠错。本文给应用开发者一套可直接套用的思路:用低 effort 跑批量、简单、对延迟敏感的任务,用高 effort 跑复杂推理与长程智能体任务,并通过实测对比成本与质量来挑档位。下面给出可运行的 Python 代码与一套压测脚本骨架。

为什么 effort 值得你关心

对智能体类应用,真正吃成本的往往是模型"想得太多"——在不需要深思的子任务上也输出长篇推理。effort 参数的意义就是把"用多少力"变成一个你能显式控制的旋钮:简单任务调低,省 token、降延迟;难任务调高,换质量。

官方数据给了很实在的参照:在 Opus 4.5 上,medium effort 能在追平此前最强模型表现的同时少用约 76% 的 token。Opus 4.8 延续了这套机制,并在 agentic coding、computer-use(浏览器智能体)等基准上进一步提升——这些能力在高 effort 下最能发挥,但并非每个调用都需要。

注意:参数的确切字段名与取值范围请以你所用 SDK 版本的官方文档为准,下面代码以通用调用形态示意,落地时按文档校正字段名。

实战一:按任务类型分配 effort

核心思路是写一个路由函数,根据任务复杂度选择档位。

importanthropic client=anthropic.Anthropic()# 读取环境变量 ANTHROPIC_API_KEYMODEL="claude-opus-4-8"# effort 起于 4.5,本文用当前最新的 Opus 4.8defclassify_effort(task:str)->str:"""极简启发式:实际可换成一个轻量分类模型或规则集。"""cheap_signals=["格式化","抽取字段","翻译一句","分类","yes/no"]ifany(sintaskforsincheap_signals)orlen(task)<80:return"low"ifany(sintaskforsin["重构","调试","多步","规划","证明"]):return"high"return"medium"defrun(task:str,effort:str|None=None)->str:effort=effortorclassify_effort(task)resp=client.messages.create(model=MODEL,max_tokens=2048,# 若 SDK 暴露的是 thinking/effort 配置,请按文档替换下面这行extra_body={"effort":effort},messages=[{"role":"user","content":task}],)returnresp.content[0].textprint(run("把这段地址抽取成 JSON:北京市海淀区中关村大街1号"))# → lowprint(run("帮我重构这个有竞态条件的多线程下载器并解释每步"))# → high

实战二:用一次压测挑出"够用就好"的档位

不要凭感觉选 effort。对你自己的真实任务集跑一轮对比,看质量是否真的随 effort 提升、提升是否值回 token。

importtime,jsondefbenchmark(tasks:list[str],efforts=("low","medium","high")):rows=[]fortintasks:foreinefforts:t0=time.time()out=run(t,effort=e)rows.append({"task":t[:40],"effort":e,"latency_s":round(time.time()-t0,2),"out_chars":len(out),})print(json.dumps(rows,ensure_ascii=False,indent=2))returnrows# 评分可接入你已有的自动判分(如单测通过率、字段抽取准确率)benchmark(["把这句翻译成英文:今天发布了新模型","为给定函数写出能覆盖边界条件的单元测试"])

判定规则很简单:如果某任务在 low 和 high 下的下游指标几乎一致,就固定用 low;只有当高档位带来可量化的质量提升时,才为它多付 token。

实战三:在智能体循环里动态升档

长程智能体里更聪明的做法,是默认低档跑,只有在遇到失败或不确定时才临时升档重试。

defagent_step(task:str,max_retries:int=1)->str:out=run(task,effort="low")attempt=0whileneeds_more_thinking(out)andattempt<max_retries:out=run(task,effort="high")# 升档重试attempt+=1returnoutdefneeds_more_thinking(out:str)->bool:# 替换成你的真实校验:JSON 是否合法、测试是否通过、是否含"我不确定"return"我不确定"inoutorlen(out)<5

这套"先省后补"的策略,能在绝大多数简单步骤上吃到低成本,只在真正困难的步骤上花算力,往往是性价比最高的组合。

落地清单

先把任务分成廉价/普通/困难三类并默认走低档;再用真实任务集压测,只为带来可量化质量提升的步骤升档;最后在智能体循环里加"失败再升档重试"。务必以官方文档核对 effort 字段名与取值,再上生产。

参考资料

  • Anthropic, Introducing Claude Opus 4.8: https://www.anthropic.com/news/claude-opus-4-8
  • Anthropic, Effort (Claude API Docs): https://platform.claude.com/docs/en/build-with-claude/effort
http://www.gsyq.cn/news/1430444.html

相关文章:

  • 告别闪退!手把手教你用VS2010旗舰版写出第一个C++程序(附Hello World完整代码)
  • MedMNIST:18个标准化医疗图像数据集如何重塑医疗AI开发范式
  • 20253921 2025-2026-2 《网络攻防实践》第十周作业
  • 13502开源:黄大年茶思屋榜文135期 第2题:多模态Agentic Reasoning
  • Keil MDK USB调试中Event Recorder语法错误解决方案
  • 你的Power BI散点图还不会‘说话’?手把手教你添加动态标题和智能切片器
  • 20260530 3
  • 【微电网调度】考虑需求响应的基于改进多目标灰狼算法的微电网优化调度研究附Matlab代码
  • 2026实测:专业降AI率网站选它准没错
  • 网盘文件直链获取终极指南:如何实现跨平台高速下载体验
  • 模块二,规划模式的定义
  • 基于复杂网络理论的快递网络优化方案【附仿真】
  • 别再删库重Fork了!Gitee同步上游代码的3种正确姿势(附Git命令详解)
  • 终极Android设备安全检测:免费开源工具Play Integrity API Checker完整指南
  • 2026年京东云OpenClaw/Hermes Agent配置Token Plan部署保姆教程
  • 3分钟上手HiveWE:8倍速打造你的魔兽争霸地图
  • Hugging Face Pipeline加载失败?4类CUDA版本兼容性暗坑,附自动化检测CLI工具(限免72小时)
  • Android Studio装AI插件总失败?手把手教你搞定Bito和Codeium的安装、登录与配置(2024最新)
  • Lindy工作流不再黑盒:用eBPF+OpenTelemetry实现端到端可观测性(附开源诊断工具包)
  • Type-C接口选型避坑指南:24Pin和16Pin到底差在哪?你的项目该用哪个?
  • MoRe-ERL框架:残差强化学习在机器人控制中的应用
  • 用HX711压力传感器做个厨房电子秤:从Arduino到STM32的完整DIY教程
  • 【限时解密】故宫/迪士尼/苹果合作方未公开的AI纪念品交互协议V2.3:含BLE 5.3+多模态触发SDK(首批申领仅剩87席)
  • 如何通过Betaflight的模块化架构解决无人机飞控的三大核心挑战
  • 模块二,Agent规划模式的四个工具思考
  • 别再只用GetX做状态管理了!它的路由、主题、网络请求全家桶功能,一个Demo全搞定
  • 白话Skills之一:什么是 Skills?
  • Unlock Music音乐解密工具:高效解锁加密音乐的完整免费方案
  • 商业智能实战:从数据孤岛到决策引擎的五大行业案例解析