编写一个最基本的 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 就可以调用真实模型。

相关推荐
xiaoxiaoxiaolll1 小时前
Nature Communications:三维超原子库+原子层保护,突破全彩VR超透镜量产瓶颈
人工智能·算法
用户5191495848451 小时前
WordPress Portfolleo 插件漏洞利用工具 (CVE-2024-49653)
人工智能·aigc
俊哥V1 小时前
每日 AI 研究简报 · 2026-05-13
人工智能·ai
用户4330514143811 小时前
和 TypeScript / Node 交互
人工智能
Wanderer X1 小时前
【LLM】RAG mRAG
人工智能
eastyuxiao2 小时前
数字孪生教程(软件篇)官方学习路径
大数据·人工智能·学习·数字孪生
茉莉玫瑰花茶2 小时前
LangGraph 入门教程:构建 AI 工作流 [ 案例三 ]
前端·人工智能·python
我有医保我先冲2 小时前
【无标题】
java·大数据·人工智能
染指11102 小时前
2.AI大模型-链式思考TOC让AI实现思考-优秀提示词设计技巧
大数据·数据库·人工智能