EVAL

GitHub
868 80 中等 1 次阅读 1周前MIT语言模型图像Agent其他
AI 解读 由 AI 自动生成,仅供参考

EVAL(Elastic Versatile Agent with Langchain)是一款基于大语言模型的智能代理工具,旨在将用户的自然语言指令直接转化为可执行的行动。它解决了传统 AI 助手仅能回答问题而无法自主完成复杂任务的痛点:用户只需描述期望的结果,EVAL 便能自动规划路径,自主进行搜索、编写代码、运行程序、调试错误乃至构建完整的多文件 Web 应用,最终交付可用成果。

这款工具特别适合开发者、技术研究人员以及希望自动化工作流的进阶用户。对于需要快速原型开发、数据检索分析或跨模态内容生成的场景,EVAL 能显著降低操作门槛并提升效率。

其核心技术亮点在于“自我进化”能力与多模态交互支持。EVAL 不仅能理解文本、图像和数据表格,还能在运行过程中动态创建和修改自身工具库——当遇到错误时,它能自动编写补丁修复代码;面对新需求,它能即时开发专用脚本。此外,它集成了终端操作、代码编辑器、多源搜索引擎(Google/Bing/Wikipedia)以及先进的图像生成与编辑模型(如 Stable Diffusion),形成了一个闭环的自主执行环境。通过简单的 Docker 部署,用户即可拥有一个能像"eval"函数一样灵活执行各类请求的智能伙伴。

使用场景

一位全栈开发者需要在半天内构建一个具备实时数据可视化功能的葡萄酒推荐 Web 应用,并自动部署上线。

没有 EVAL 时

  • 开发者需手动切换浏览器搜索最新葡萄酒评分数据、查阅文档确定技术栈,并在本地反复配置环境。
  • 编写代码时需人工处理多文件结构,一旦报错需逐行调试,修复逻辑漏洞和样式问题耗时极长。
  • 若要加入“上传酒标图片识别品种”功能,必须单独研究计算机视觉模型并编写复杂的图像预处理脚本。
  • 完成开发后,还需手动购买服务器、配置域名及部署流程,整个周期往往超过数天。

使用 EVAL 后

  • 只需告诉 EVAL“创建一个基于最新数据的葡萄酒推荐网站”,它会自动搜索网络数据、规划架构并生成完整代码库。
  • EVAL 在运行中若遇到报错,会利用内置的 PATCH 工具自动修正代码错误,并通过终端自行测试直到服务稳定运行。
  • 当提出“增加图片识别功能”时,EVAL 能直接调用内置的 BLIP 和 Stable Diffusion 模型,即时生成并集成图像理解模块。
  • 最终 EVAL 不仅交付了可运行的 Web 服务,还能自动管理 GitHub 仓库版本,将原本数天的工作压缩至分钟级。

EVAL 的核心价值在于将开发者从繁琐的搜索、编码、调试及运维链条中解放出来,实现“只定义结果,过程全自动”的敏捷开发模式。

运行环境要求

操作系统
  • 未说明
GPU
  • 非必需
  • 仅在使用多模态对话功能(图像理解、生成、编辑)时需要 GPU
  • 若无此需求,官方推荐使用无 GPU 的 Docker 容器(eval),并指出带 GPU 的版本因依赖庞大目前较重且不稳定
  • 未指定具体显卡型号、显存大小或 CUDA 版本
内存

未说明

依赖
notes该工具主要通过 Docker Compose 部署。提供两种服务模式:'eval'(无 GPU,轻量级,适用于文本和代码任务)和 'eval.gpu'(含 GPU,用于多模态任务,但官方提示其依赖庞大且目前不够稳定)。必须配置 OPENAI_API_KEY 环境变量。若需使用 Google 或 Bing 搜索工具,还需分别配置对应的 API Key。
python未说明
LangChain
Visual ChatGPT
llama index
Stable Diffusion 1.5
blip-image-captioning
blip-vqa
InstructPix2Pix
EVAL hero image

快速开始

EVAL

EVAL(基于 LangChain 的弹性多功能代理)将执行您所有的请求。就像 eval 方法一样!

您无需考虑具体如何实现。只要告诉它您想要的结果,它就会自行在互联网上搜索、编写代码、运行并测试,最终返回结果。

https://user-images.githubusercontent.com/19206046/229892113-481437b7-a332-4e0c-bfb3-d2c97c9035be.mp4

EVAL 使用多文件构建一个完整的 Web 应用程序

https://user-images.githubusercontent.com/51526347/230061897-b3479405-8ebd-45ab-a432-6506730242b9.mov

EVAL 为自己创建 UI

EVAL-BOT

EVAL 自行管理的 GitHub 账号。除了注册和设置个人简介外,其他一切均由 EVAL 完成。

示例

这里提供了一些示例。

EVAL 的特性

  1. 多模态对话
    • 它能够理解生成文本、图像、数据框、音频(待开发)、视频(待开发)等多种数据格式。
  2. 服务提供
    • 它可以提供阻塞型服务,例如 Web 应用。
  3. 自我进化
    • 它可以通过编写、修改、执行和测试代码来创建自己的工具

内置工具

  1. 终端
    • SyscallTracer
  2. 代码编辑器
    • READ:读取并理解文件内容。
    • WRITE:编写代码以创建新工具。
    • PATCH:如果出现错误,通过代码补丁进行修复。
    • DELETE:删除文件中的代码以便重新开始。
  3. 搜索
    • Google、Bing、维基百科
    • 自定义数据库搜索(目前使用 Corca 的 Wine 数据,网址为 https://www.workershop.kr/en)
      • 利用 GPT 索引快速在文档中找到所需信息,并据此回答问题。
    • Requests.get(从任何您希望的地方获取信息)。
  4. 图像理解、生成与编辑
    • 图像理解
      • 图像描述:blip-image-captioning
      • 视觉问答:blip-vqa
    • 图像生成:Stable Diffusion 1.5
    • 图像编辑
      • 替换或移除对象:Stable Diffusion Inpainting
      • 改变图像风格:InstructPix2Pix

感谢 LangChainVisual ChatGPTllama index 的支持。

自定义工具

我们同样无法预测 EVAL 将会创造出哪些工具。每一天,它都会根据您的需求,生成最合适的工具来完成任务。


使用方法

  1. 设置环境变量
  2. 使用 docker-compose 运行
  3. 向 EVAL 发送请求

1. 环境变量

您需要在 .env 文件中填写一些环境变量。如果您不确定格式,请参考 .env.example

必填项

这些环境变量是运行 EVAL 所必需的。

  • OPENAI_API_KEY - OpenAI API 密钥

可选项

每个可选环境变量都有默认值,因此除非您想更改,否则无需设置。

  • EVAL_PORT - 端口(默认:8000)
  • SERVER - 服务器地址(默认:http://localhost:8000)
  • LOG_LEVEL - INFO | DEBUG(默认:INFO)
  • BOT_NAME - 为它起个名字吧!(默认:Orca)
  • MODEL_NAME - GPT 模型名称(默认:gpt-4)

用于更多工具

某些工具需要特定的环境变量。请根据您希望使用的工具设置相应的环境变量。

  • Google 搜索工具
    • SERPAPI_API_KEY
  • Bing 搜索工具
    • BING_SEARCH_URL
    • BING_SUBSCRIPTION_KEY

2. 使用 docker-compose 运行

  • docker-compose.yml 中有两个服务:
    • eval - 不带 GPU,更加轻量
      docker-compose up --build eval
      
    • eval.gpu - 带 GPU,用于多模态对话
      docker-compose up --build eval.gpu
      
  • 目前,带 GPU 的版本由于依赖项过多,较为沉重且不稳定。如果您不需要多模态对话,建议使用不带 GPU 的版本。

3. 向 EVAL 发送请求

  • 您可以使用 Web GUI 轻松使用 EVAL:

    • 在浏览器中访问 http://localhost:8000
  • 或者,您也可以通过 API 手动向 EVAL 发送请求。

    • POST /api/execute

      • session - 会话 ID

      • files - 输入文件的 URL

      • prompt - 提示语

      • 示例:

        curl -X POST -H "Content-Type: application/json" -d '{"session": "sessionid", "files": [], "prompt": "你好!"}' http://localhost:8000/api/execute
        
        http POST http://localhost:8000/api/execute session=sessionid files:='[]' prompt="你好!"
        
  • EVAL 还支持异步执行。您可以使用 POST /api/execute/async 替代 POST /api/execute,请求体保持不变。

    • 它会返回执行的 id。您可以使用 GET /api/execute/async/{id} 来获取结果。

待办事项

  • GUI
  • 内存优化
  • 会话管理
  • 转换为 Alpaca 格式
  • 提升提示语质量
  • 提供一种用于创建工具的工具
  • 等等。

参考文献

感谢以下项目的支持:

常见问题

相似工具推荐

openclaw

OpenClaw 是一款专为个人打造的本地化 AI 助手,旨在让你在自己的设备上拥有完全可控的智能伙伴。它打破了传统 AI 助手局限于特定网页或应用的束缚,能够直接接入你日常使用的各类通讯渠道,包括微信、WhatsApp、Telegram、Discord、iMessage 等数十种平台。无论你在哪个聊天软件中发送消息,OpenClaw 都能即时响应,甚至支持在 macOS、iOS 和 Android 设备上进行语音交互,并提供实时的画布渲染功能供你操控。 这款工具主要解决了用户对数据隐私、响应速度以及“始终在线”体验的需求。通过将 AI 部署在本地,用户无需依赖云端服务即可享受快速、私密的智能辅助,真正实现了“你的数据,你做主”。其独特的技术亮点在于强大的网关架构,将控制平面与核心助手分离,确保跨平台通信的流畅性与扩展性。 OpenClaw 非常适合希望构建个性化工作流的技术爱好者、开发者,以及注重隐私保护且不愿被单一生态绑定的普通用户。只要具备基础的终端操作能力(支持 macOS、Linux 及 Windows WSL2),即可通过简单的命令行引导完成部署。如果你渴望拥有一个懂你

349.3k|★★★☆☆|2周前
Agent开发框架图像

n8n

n8n 是一款面向技术团队的公平代码(fair-code)工作流自动化平台,旨在让用户在享受低代码快速构建便利的同时,保留编写自定义代码的灵活性。它主要解决了传统自动化工具要么过于封闭难以扩展、要么完全依赖手写代码效率低下的痛点,帮助用户轻松连接 400 多种应用与服务,实现复杂业务流程的自动化。 n8n 特别适合开发者、工程师以及具备一定技术背景的业务人员使用。其核心亮点在于“按需编码”:既可以通过直观的可视化界面拖拽节点搭建流程,也能随时插入 JavaScript 或 Python 代码、调用 npm 包来处理复杂逻辑。此外,n8n 原生集成了基于 LangChain 的 AI 能力,支持用户利用自有数据和模型构建智能体工作流。在部署方面,n8n 提供极高的自由度,支持完全自托管以保障数据隐私和控制权,也提供云端服务选项。凭借活跃的社区生态和数百个现成模板,n8n 让构建强大且可控的自动化系统变得简单高效。

184.7k|★★☆☆☆|今天
数据工具开发框架Agent

AutoGPT

AutoGPT 是一个旨在让每个人都能轻松使用和构建 AI 的强大平台,核心功能是帮助用户创建、部署和管理能够自动执行复杂任务的连续型 AI 智能体。它解决了传统 AI 应用中需要频繁人工干预、难以自动化长流程工作的痛点,让用户只需设定目标,AI 即可自主规划步骤、调用工具并持续运行直至完成任务。 无论是开发者、研究人员,还是希望提升工作效率的普通用户,都能从 AutoGPT 中受益。开发者可利用其低代码界面快速定制专属智能体;研究人员能基于开源架构探索多智能体协作机制;而非技术背景用户也可直接选用预置的智能体模板,立即投入实际工作场景。 AutoGPT 的技术亮点在于其模块化“积木式”工作流设计——用户通过连接功能块即可构建复杂逻辑,每个块负责单一动作,灵活且易于调试。同时,平台支持本地自托管与云端部署两种模式,兼顾数据隐私与使用便捷性。配合完善的文档和一键安装脚本,即使是初次接触的用户也能在几分钟内启动自己的第一个 AI 智能体。AutoGPT 正致力于降低 AI 应用门槛,让人人都能成为 AI 的创造者与受益者。

183.6k|★★★☆☆|今天
Agent语言模型插件

stable-diffusion-webui

stable-diffusion-webui 是一个基于 Gradio 构建的网页版操作界面,旨在让用户能够轻松地在本地运行和使用强大的 Stable Diffusion 图像生成模型。它解决了原始模型依赖命令行、操作门槛高且功能分散的痛点,将复杂的 AI 绘图流程整合进一个直观易用的图形化平台。 无论是希望快速上手的普通创作者、需要精细控制画面细节的设计师,还是想要深入探索模型潜力的开发者与研究人员,都能从中获益。其核心亮点在于极高的功能丰富度:不仅支持文生图、图生图、局部重绘(Inpainting)和外绘(Outpainting)等基础模式,还独创了注意力机制调整、提示词矩阵、负向提示词以及“高清修复”等高级功能。此外,它内置了 GFPGAN 和 CodeFormer 等人脸修复工具,支持多种神经网络放大算法,并允许用户通过插件系统无限扩展能力。即使是显存有限的设备,stable-diffusion-webui 也提供了相应的优化选项,让高质量的 AI 艺术创作变得触手可及。

162.1k|★★★☆☆|2周前
开发框架图像Agent

everything-claude-code

everything-claude-code 是一套专为 AI 编程助手(如 Claude Code、Codex、Cursor 等)打造的高性能优化系统。它不仅仅是一组配置文件,而是一个经过长期实战打磨的完整框架,旨在解决 AI 代理在实际开发中面临的效率低下、记忆丢失、安全隐患及缺乏持续学习能力等核心痛点。 通过引入技能模块化、直觉增强、记忆持久化机制以及内置的安全扫描功能,everything-claude-code 能显著提升 AI 在复杂任务中的表现,帮助开发者构建更稳定、更智能的生产级 AI 代理。其独特的“研究优先”开发理念和针对 Token 消耗的优化策略,使得模型响应更快、成本更低,同时有效防御潜在的攻击向量。 这套工具特别适合软件开发者、AI 研究人员以及希望深度定制 AI 工作流的技术团队使用。无论您是在构建大型代码库,还是需要 AI 协助进行安全审计与自动化测试,everything-claude-code 都能提供强大的底层支持。作为一个曾荣获 Anthropic 黑客大奖的开源项目,它融合了多语言支持与丰富的实战钩子(hooks),让 AI 真正成长为懂上

161.1k|★★☆☆☆|今天
开发框架Agent语言模型

opencode

OpenCode 是一款开源的 AI 编程助手(Coding Agent),旨在像一位智能搭档一样融入您的开发流程。它不仅仅是一个代码补全插件,而是一个能够理解项目上下文、自主规划任务并执行复杂编码操作的智能体。无论是生成全新功能、重构现有代码,还是排查难以定位的 Bug,OpenCode 都能通过自然语言交互高效完成,显著减少开发者在重复性劳动和上下文切换上的时间消耗。 这款工具专为软件开发者、工程师及技术研究人员设计,特别适合希望利用大模型能力来提升编码效率、加速原型开发或处理遗留代码维护的专业人群。其核心亮点在于完全开源的架构,这意味着用户可以审查代码逻辑、自定义行为策略,甚至私有化部署以保障数据安全,彻底打破了传统闭源 AI 助手的“黑盒”限制。 在技术体验上,OpenCode 提供了灵活的终端界面(Terminal UI)和正在测试中的桌面应用程序,支持 macOS、Windows 及 Linux 全平台。它兼容多种包管理工具,安装便捷,并能无缝集成到现有的开发环境中。无论您是追求极致控制权的资深极客,还是渴望提升产出的独立开发者,OpenCode 都提供了一个透明、可信

144.3k|★☆☆☆☆|4天前
Agent插件