harness engineering

rag系列文章目录


文章目录


前言

现在大家都在使用claude code进行ai coding,当大家觉得ai coding做的不太好的时候,首先想到的是模型能力不行,这合理吗?其实现在模型能力并没有那么重要了,或者说一般大模型都是能够满足coding的需求的,此时需要考虑的就是harness engineering。

这里还有一个问题,就是在ai时代,ai输出了大量的代码,人无法逐行理解,如何保证代码的准确性,这也是需要harness engineering。


一、简介

harness本质:

不是写代码,而是设计一个"环境 + 约束 + 反馈系统",让 AI 稳定地产生正确代码

换句话说:

bash 复制代码
传统工程:人 → 写代码
Harness 工程:人 → 设计系统 → AI 写代码

它的核心职责:

bash 复制代码
精确 specification(避免歧义)
设计执行环境(repo / tools / context)
构建验证机制(tests / CI / lint)
控制 agent 行为(边界 +流程)
审核输出而不是实现细节

二、关键思想

  • 不要让 AI 做设计决策

    架构,数据模型,API 约束,依赖选择,必须由人进行定义。

    否则:模糊输入 → AI 自行设计 → 不可控系统

  • 模糊 = 随机行为

    ai的行为规律:

    描述越模糊 → 偏差越大

    描述越精确 → 可预测性越强

  • Harness ≠ Prompt

    不要只靠 prompt 控制 AI,把控制逻辑外移到系统层,对应实现可以是:CI / 测试、hooks、tool 限制、repo 结构。

  • 把 AI 放进"轨道"而不是"对话"

    不要对话驱动,而要系统驱动

三、核心组成

  1. Specification(规格层)
    定义:要做什么,不允许做什么,成功标准
  2. Context(上下文层)
    长上下文会丢失信息,需要结构化管理
  3. Tools(工具层)
    设计原则:小而明确(单职责),有边界,可验证
  4. Constraints(约束层)
    强制规则:文件访问限制,命令白名单,权限控制
    不是告诉 AI "不要做",而是"做不了"
  5. Feedback(反馈层)
    核心:tests,lint,CI,自动检查
    让系统告诉 AI 对不对,而不是人去看代码

一般的ai开发流程:

bash 复制代码
1. 明确定义任务(spec)
2. 限定作用范围(scope)
3. 提供必要上下文
4. AI 实现
5. 自动验证(tests / CI)
6. 人只做结果审查

总结

Agent 能力 = 模型能力 × Harness 质量。如果 agent 表现不稳定,不要调 prompt,不要换模型,先重构 harness。

参考文档123

相关推荐
恋猫de小郭24 分钟前
如何让 AI 快速搭建一套生产 Agent ?全面理解 Agent 架构。
前端·人工智能·ai编程
aneasystone本尊1 小时前
学习 turbovec 的量化算法
人工智能
To_OC9 小时前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC9 小时前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
九酒11 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
蝎子莱莱爱打怪11 小时前
DSpark 讲透:DeepSeek 不换模型,硬把 V4 提速 85%,是怎么做到的?
人工智能·面试·程序员
BadBadBad__AK11 小时前
线段树维护区间 k 次方和
c++·数学·算法·stl
巫山老妖13 小时前
置身AI内
人工智能
IT_陈寒14 小时前
JavaScript项目实战经验分享
前端·人工智能·后端