编写一个最基本的 ReAct Agent

编写一个最基本的 ReAct Agent

ReAct 指的是 Reason → Act → Observe:Agent 先判断下一步要做什么,调用工具,把工具结果整理成 observation,然后基于 observation 回答。

这篇教程故意使用一个很简单的工具:通过 env://process 读取一个环境变量。这样不需要 MCP 或网络配置,也可以直接运行示例。

完整源码:../../../tutorials/react.as

1. 完整程序

创建 react.as,或者直接打开仓库里的 tutorials/react.as

ts 复制代码
import llm Qwen from "ollama://localhost:11434/qwen3.6"
import tool Env from "env://process"

main agent BasicReAct {
    model Qwen
    role "Diagnostic assistant"
    description "Answer one question with a minimal Reason-Act-Observe flow."

    main func(input {
        question: string
    }) {
        env_name = "USER"
        thought = reason(input.question, env_name)
        action = Env.get({
            name: env_name
        })
        observation = observe(input.question, env_name, action)

        answer(input.question, thought, observation)
    }

    func reason(question, env_name) {
        use question as "question"
        use env_name as "planned tool input"

        generate({ input: "Explain why this environment variable may help answer the question", max_output: 300 }) -> {
            why
        }
    }

    func observe(question, env_name, action) {
        use question as "question"
        use env_name as "environment variable"
        use action.value as "environment value"

        generate({ input: "Turn the tool result into a useful observation", max_output: 400 }) -> {
            facts: list[string]
            value_found: boolean
        }
    }

    func answer(question, thought, observation) {
        use question as "question"
        use thought.why as "reasoning note"
        use observation.facts max 1k as "observed facts"
        use observation.value_found as "value found"

        generate({ input: "Answer using only the observation", max_output: 500 }) -> {
            answer
            confidence
        }
    }
}

2. Reason

reason 是规划步骤。它不调用工具,只查看问题和计划使用的工具输入,然后解释为什么这个输入可能有帮助。

关键点是 use question 是显式的。以后这个函数可以接收更多参数,但只有被 use 选中的值会进入这次模型调用。

3. Act

Act 步骤是工具调用:

ts 复制代码
action = Env.get({
    name: env_name
})

模型不会直接调用工具。AgentScript 程序用结构化参数调用工具,这样模型输出和宿主能力之间的边界是清楚的。这个最小教程里把工具输入固定为 "USER",这样示例在 --mock 下也能直接运行。

4. Observe

observe 把原始工具结果整理成适合模型使用的 observation。这样最后回答时依赖的是经过整理的信息,而不是直接依赖未处理的宿主返回值。

5. Answer

最后一步使用原始问题、reasoning note 和 observed facts。它不会默认看到所有局部变量;只有被 use 选择的值会进入 prompt。

6. 运行

先用 mock 模型输出运行:

bash 复制代码
agentscript tutorials/react.as --mock --input '{"question":"Which environment variable identifies my shell user?"}'

打印 trace,观察 Reason → Act → Observe 的形状:

bash 复制代码
agentscript tutorials/react.as --mock --trace --input '{"question":"Which environment variable identifies my shell user?"}'

配置好真实模型 provider 后,去掉 --mock 就可以调用真实模型。

相关推荐
火山引擎开发者社区21 小时前
技术速递|使用 GitHub Copilot CLI 构建 Emoji 列表生成器
人工智能
codefan※21 小时前
干掉“幻觉“实战:如何构建企业级知识图谱增强 RAG
人工智能·知识图谱
wukangjupingbb1 天前
传统基于药物 SMILES 序列和蛋白质氨基酸序列的 DTI(Drug-Target Interaction)预测方法的缺陷
人工智能
沪漂阿龙1 天前
Codex 额度重置周期变化:AI 编程免费试玩时代正在结束
人工智能
TickDB1 天前
美股行情 API 接入避坑:REST 快照、WebSocket 推送、盘前盘后数据的边界
人工智能·python·websocket·行情数据 api
装不满的克莱因瓶1 天前
深入理解卷积神经网络(CNN)——从原理到代码实践
人工智能·神经网络·cnn
完成大叔1 天前
模块二,Agent知识图谱的工具链思考
人工智能
lauo1 天前
ibbot手机发布:搭载poplang技术 + token节点经济,革新AI手机体验
人工智能·智能手机
咖啡星人k1 天前
云端开发环境技术架构深度解析:从容器隔离到AI Agent集成
人工智能·架构
袋鼠云数栈1 天前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能