【论文精读】OS-Copilot: Towards Generalist Computer Agents with Self-Improvement

OS-Copilot: Towards Generalist Computer Agents with Self-Improvement

  • 前言
  • ABSTRACT
  • 1 INTRODUCTION
  • 2 THE OS-COPILOT FRAMEWORK
    • 2.1 PLANNER
    • 2.2 CONFIGURATOR
      • 2.2.1 DECLARATIVE MEMORY
      • 2.2.2 PROCEDURAL MEMORY
      • 2.2.3 WORKING MEMORY
    • 2.3 ACTOR
  • 3 THE FRIDAY AGENT
    • 3.1 A RUNNING EXAMPLE
    • 3.2 SELF-DIRECTED LEARNING
  • 4 EXPERIMENTS
    • 4.1 MAIN RESULTS
    • 4.2 SELF-DIRECTED LEARNING
  • 5 RELATED WORK
  • 6 CONCLUSION
  • 阅读总结

前言

这是第一篇OS智能体框架工作,提出了操作系统上通用且能自我改进的AI助手FRIDAY,这与只能解决简单问题的AI助手Cortana相比有着本质的区别和显著的提升。其github仓库开放一周就收获了600+stars,受到了大量科研人员和科技企业的关注,在业界有着不俗的影响力。文章投稿于ICML 2024,为LLM智能体在OS领域的应用奠定了坚实的基础。

Paperhttps://arxiv.org/pdf/2402.07456.pdf
Codehttps://github.com/OS-Copilot
FromarXiv 15 Feb 2024

image.png

ABSTRACT

与计算机的自动交互一直是长期存在的挑战,最近LLM的发展加速了构建数字智能体的进展。但是现有的智能体交互领域过于局限,比如特定的软件或者网页,这显著限制了对一般计算机任务的适用性。本文提出OS-Copilot,一个用于构建与OS中元素(Web,Code,代码,多媒体和各种第三方应用)交互的通用智能体框架。基于OS-Copilot,作者创建了FRIDAY,一个用于自动化处理计算机任务的自我改进的具身智能体。在通用AI助手benchmark上,FRIDAY相对于之前的方法提升了35%,通过对技能的累积,展现出对未见应用程序的强大泛化能力,定量定性实验在Excel和PPT上展示了FRIDAY的自我改进。OS-Copilot为未来更强大、更通用的计算机智能体奠定了基础,提供了深刻的见解。

1 INTRODUCTION

从1920年的小说《R.U.R》到电影《钢铁侠》中的JARVIS,人们一直梦想着构建数字智能体来自动化日常的工作。然而现有的数字智能体只能处理简单的任务,难以适应复杂的人类需求。幸运的是,LLM的进步让我们更接近实现下一代数字助理。当前的智能体主要关注于特定的场景的应用,比如网络浏览,命令行终端,我的世界游戏等,缺少与整个操作系统进行交互的探索。由于操作系统固有的异构性,开发操作系统级别的语言智能体是一个巨大的挑战,具体有如下两点:

  1. 智能体需要一个统一的接口与操作系统交互。
  2. 大量不同的应用程序对语言智能体的泛化和可扩展性提出了重大挑战。

为了解决第一个挑战,作者提出OS-Copilot,旨在通过提供通用的交互接口来加速Linux和MacOS上计算机智能体的构建。该通用接口整合了操作系统中常见的操作,包括Python解释器,Bash终端,鼠标键盘输入,API调用等。下表是OS-Copilot的示例用例。
image.png
对于第二点挑战,作者基于OS-Copilot创建了FRIDAY,这是一个自我改进的具身智能体,可以无缝集成到OS中自动执行计算机任务。它与现有的通用智能体如AutoGPT不同,它具有自我进化配置器来控制不熟悉的程序。控制器包括一个自主学习模块,可以自主提出不熟悉应用程序的任务课程。FRIDAY通过解决这些任务从而累积工具来学习控制这个程序。图一提供了三个案例,证明通过自主学习,FRIDAY学会了操作Excel并使用前端库ReAct构建了一个网站。
为了系统评估FRIDAY在OS中解决任务的能力,作者在通用AI助手benchmark GAIA上评估了其性能,在最简单的一级任务上,FRIDAY成功率比先前最好的系统提高了35%,甚至在其他模型都无法成功的三级任务中,也取得了6.12%的成功率。作者进一步评估了FRIDAY在Excel中的自主学习能力,起初FRIDAY未能解决任何问题,但是经过自主学习,成功率达到了60%,甚至超过了专门为Excel设计的最先进的模型。
本文的贡献如下:

  1. OS-Copilot是一个开创性概念框架,用于在Linux和MacOS上构建通用计算机智能体,为异构OS系统提供了统一的应用交互。此外,OS-Copilot可以作为一个基础平台,支持个性化数字助理、多模态智能体、特定场景智能体学习等领域的研究。
  2. 依托OS-Copilot,作者构建了FRIDAY,一个可以自我提升的AI助理用于解决通用的计算机任务。FRIDAY在benchmark上展示出色的性能,并且在未见的应用上展示了强大的泛化能力。

2 THE OS-COPILOT FRAMEWORK

image.png
OS-Copilot的框架如上图所示,收到用户的请求后,planner首先构建计划并将请求分解为子任务,给定一个子任务,配置器维护一个工作存储库,它负责存储检索到的工具,知识,以及任何相关的用于完成任务的信息。基于配置器提供的信息,actor会迭代执行直到子任务完成。特别的,评估模块会根据收集的执行反馈进行自我修复和提升。此外用户可以根据他们的偏好定制智能体。

2.1 PLANNER

planner组件会对用户的请求进行推理分析,然后将复杂的问题进行分解。最重要的是,planner需要拥有以正确的粒度生成计划的能力,为此,它需要检索有关智能体能力的相关信息,例如内部工具和操作系统信息,以协助规划。为了支持不同的规划方法,作者提出了基于有向无环图的planner。
现有的planner,无论是生成线性结构还是非线性结构的计划,本质上都需要智能体按照顺序执行任务,然而现实场景中并行执行任务可以最小化缩短执行时间。为此,作者利用LLM将计划转化为有向无环图,其中每个节点代表一个子任务,箭头表示子任务之间的相互依赖关系,下图是该planner的工作原理以及部分prompt模板。
image.png
image.png

2.2 CONFIGURATOR

配置器组件从planner组件获取子任务并对其进行配置。配置器的灵感来源于人脑的生物本质,人脑具有工作记忆,陈述性记忆和程序记忆。

2.2.1 DECLARATIVE MEMORY

陈述性或者显式记忆是长期记忆的一个子类别,用于存储事实和事件。本文的陈述性记忆包含两个组件:

  1. 用户画像。记录用户的偏好,对话风格,工具使用习惯。
  2. 语义知识。存储智能体过去获取的知识(比如系统版本,当前的工作目录),该模块对智能体根据当前环境正确采取行动并从经验中学习至关重要。

2.2.2 PROCEDURAL MEMORY

程序记忆是长期记忆的另一种形式,主要与个人的技能发展有关,一旦学会,程序记忆就会自动执行不涉及用户意识的功能。OS-Copilot的程序记忆主要由作为智能体技能库的工具仓库组成。LLMs虽然可以读写,但是不具备与操作系统交互的能力,因此需要为智能体配备将自然语言转换为操作系统可行操作的工具。作者为OS-Copilot植入了四个手动创建的工具:网页浏览,音频转录,图像caption,网页检索。工具以两种形式存在:部署为API服务以使用POST请求,或者存储为python文件。

2.2.3 WORKING MEMORY

工作记忆是短期记忆,它是OS-Copilot的核心,用于连接planner,配置器和参与者组件。工作记忆通过内部和外部操作与其他模块交换信息:

  • 内部操作:从长期记忆中检索信息并更新,比如检索工具来帮助规划或者自我纠错。
  • 外部操作:工作记忆模块从planner中接收子任务,从陈述性记忆和程序性记忆中收集相关的信息,然后将这些信息提供给actor组件。actor的反馈信息将输入回工作记忆中以进行潜在的修改。

2.3 ACTOR

actor分为两个阶段:执行和自我评判。执行器根据配置器的prompt在OS下执行action,自我批判模块根据执行的结果给出优化的反馈,并将高质量的action保存到长期记忆中。

  • 执行器会根据配置器提供的子任务和预设的prompt,生成可执行的工具类和对应的调用来完成子任务。它提供了封装Python运行、Bash运行、API调用、键鼠控制的接口,涵盖了大部分操作系统的用例。
  • 自我评判模块会收集执行前后全面的系统信息,利用LLM自动评估完成状态。具体来说,它会评判当前子任务是否完成,分析执行报错的原因,以及评估是否需要重新规划子任务。

3 THE FRIDAY AGENT

FRIDAY设计的原则旨在通过赋予智能体自我完善和学习的能力来最大化通用性。本节先用一个例子说明FRIDAY是如何运行的,接着深入研究FRIDAY如何通过自主学习来操作不熟悉的应用程序。

3.1 A RUNNING EXAMPLE

image.png
在收到“将系统改为深色模式”的任务后,配置器从长期记忆中检索相关信息来构建prompt,该prompt中包含相关工具、用户配置文件、操作系统版本以及工作目录。由于该任务中没有识别出合适的工具,因此工具生成器将根据prompt(工具prompt和任务相关信息)构建工具类。接着,执行器将生成工具调用并运行工具,执行结果将输入给评判模块,用于评估任务是否完成。评估模块有两个指标,一个是任务是否完成,一个是工具质量得分(1—10分),得分大于等于8分被认为是高质量的工具,会被保存到长期记忆中。如果任务没有完成,那么需要判断错误的类型,是代码本身有错误还是计划有缺陷,如果是代码本身的错误,那么amend模块会根据LLM分析的错误原因对原始代码进行修复(最多尝试三次),否则replan模块会对当前的子任务进行重新的规划,一个常见的示例是缺少相关的依赖包,那么会repaln一个子任务用于安装该依赖包。

3.2 SELF-DIRECTED LEARNING

自我学习是人类获取新信息、学习新技能的关键,FRIDAY也有类似的能力。为了掌握excel的使用,FRIDAY会被提示执行与该目标相关的任务流,从简单再到具有挑战性。在这个过程中,FRIDAY累积有价值的工具,从而学习到使用excel的能力。

4 EXPERIMENTS

FRIDAY在通用AI助手benchmark GAIA上的466个QA问答上进行评估。为了回答相关的问题,智能体需要掌握计算、网页浏览、网页检索、音频转换等能力。
作者采用四个基本的工具初始化FRIDAY,在评估完毕后,又增加了9个工具。LLM采用GPT4-turbo-1106。
baseline采用AutoGPT-4、带有工具的和不带工具的GPT-4,此外作者还引入了人类的表现结果。

4.1 MAIN RESULTS

image.png
上表是实验结果,FRIDAY在leve 1上比SOTA高了35%,level 2上提升更甚,即使是难度很大的Level 3,也有6.12%的表现。为了探究FRIDAY有效性的根源,作者对比了FRIDAY和AutoGPT-4,二者在任务分解和存储上有相似之处,但是FRIDAY强调了自我评判和完善的重要性,GPT-4 Plugins优于AutoGPT-4的原因在于它具有能力访问广泛的工具库,而FRIDAY优于GPT-4 Plugins在于OS-Copilot架构的优越性,规划、评判和改进模块将其提升到新的水平。
虽然OS-Copilot中的概念并不都是首次创新出,但是它将这些模块有机结合到一起,通过强有力的实验结果证明架构的有效性,这对未来的相关工作具有指导作用。
通过对比未经学习和经过学习后的FRIDAY,可以看到自我导向学习对最终表现的贡献。当然也正如所见,即使没有自主学习,FRIDAY仍然显著优于所有基线,这进一步凸显了框架和定制设计的有效性。自主学习的结果一方面说明了类似于GAIA这种开放环境的数据集的挑战,也强调了FRIDAY自主设计和使用工具能力在去的显著成功中的关键作用。附录中有细化的效率评估和每个领域能力的评分。
image.png

4.2 SELF-DIRECTED LEARNING

本节从定量和定性角度评估FRIDAY的自我导向学习能力。
定量评估在SheetCopilot-20数据集上进行,该数据集包含20个excel操作任务,代表了excel中的典型任务。FRIDAY通过自我指导生成了10个有关excel操作的任务,并且累积了10个工具,如下表所示:
image.png
image.png
实验结果如上表所示,最初,FRIDAY没有进行自主学习,无法完成任何任务,在编写代码时倾向使用pandas和matplotlib等包进行电子表格操作导致失败。当配备自我学习能力后,FRIDAY性能超过了为excel专门设计的智能体SheetCopilot。值得注意的是,sheetCopilot中所有原子操作和工具都是人工编写的,而FRIDAY是自主生成的,这进一步表明本文构建的通用操作系统智能体可以有效扩展支持各种应用,而不需要人工干涉。
定性分析中,作者设计了一个任务,要求FRIDAY根据文字和图片资料创建PPT来介绍OS-Copilot。任务说明中详述了PPT所需的内容、字体、字号等,构建过程如下图所示:
image.png
在没有学习时,FRIDAY很难控制字号、字体以及图片的大小和位置。经过一段时间的学习,FRIDAY掌握了各种文本配置技能,比如字体,字号,颜色,行间距等等,进一步学习还有控制图像大小、图像位置,最终完成任务。所展示的过程证明FRIDAY通过自主学习掌握不熟悉应用程序的能力。下表是学习过程中积累的工具。
image.png

5 RELATED WORK

由LLM支持的自主智能体或者语言智能体是一个快速发展的研究领域,最近引起了广泛的关注。
语言智能体被设计应用于各个领域,包括机器人,网络操作,游戏等,但是这些智能体都是针对特定环境量身定制的,无法泛化到别的场景。
语言智能体代表了一个复杂的系统,它是由各种组件组成,每个组件都代表了大量值得研究的方向。对于规划组件,它包括任务的分解,推理路径的多样性,是否需要自我评估等。对于记忆组件,又涉及短期记忆和长期记忆,不同的记忆采用不同的工具或者数据结构存储。执行组件的难点在于如何将LLM的输出转化为可执行的操作,并在真实环境中执行,这里又涉及针对执行信息的收集以及纠错。

6 CONCLUSION

本文提出了OS-Copilot,一个用于构建OS级的语言智能体框架。基于该框架,作者开发了具身计算机智能体FRIDAY,它在解决开放环境计算机任务上展现了令人惊叹的性能,此外还展示了其通过自主学习有效学习和控制以前未见过的应用程序的能力。
当然,OS-Copilot还存在一定的局限性,如下所述:

  1. LLM的改变,会对FRIDAY的性能产生巨大的影响。
  2. 仅通过代码和自然语言控制计算机是不可行的,因此扩展OS-Copilot以支持视觉输入势在必行。
  3. 评估通用的计算机智能体是一个巨大的挑战,因为很多任务的执行缺乏基本事实。
  4. 与操作系统的交互必须透明、可解释且安全。如何确保与OS进行交互的系统不会造成任何形式的伤害是一个重大挑战。

阅读总结

本文是真正意义上第一篇开源的与操作系统交互的智能体的工作,也是博主本人的第一篇工作。整个开发的过程是紧张且刺激的,核心的开发周期只有一个半月的时间,再加上一个月的实验,满打满算all in了近三个月的时间,疲惫不堪但收获满满。在开始这个项目之初,团队leader(即一作)就提出以钢铁侠的FRIDAY为工作的最终目标,设计出一个全新的用于与操作系统全方位交互的框架,从而开发出通用的、可以自我学习提升的计算机AI助手。为了设计出合理的框架,让每个模块的组合达到1+1>2的效果,我也是阅读了大量的文献工作,包括并不限于:

  • ReAct,学习其对任务的走一步看一步的执行形式。
  • VOYAGER,学习其工具积累的方法。
  • HuggingGPT,学习其任务规划的设计。
  • Adapter,学习其replan的思想。
  • reflexion,学习其基于强化学习思想的纠错和提升模式。

基于对这一系列工作的学习,我逐渐对和OS交互的智能体有了一个比较清晰的认知,对于这样的具身智能体,它首先得有自己的大脑,即LLM,可以是基于API的,也可以是开源的LLM;其次,它得有积累工具和检索工具的能力,那么我就想到了用向量数据库的方式对工具进行存储;最后,它需要拥有与OS交互的接口,而Python是非常出色的交互环境,因此任务的执行都是在Python环境下执行。拥有这三个基本组件后,剩下的就是如何利用这三个组件来开发交互的模块。大方向上的模块有三个,planner,配置器和执行器。三者都会用上LLM,配置器会检索工具,执行器会利用检索工具,没有工具就利用LLM的能力生成工具并在python环境下执行。执行器中有复杂的执行和改进流程,需要对原始代码进行分析才便于解释,如果有朋友看完文章后对代码实现的细节感兴趣,欢迎留言或私信,我将会再出一期博客来对代码进行讲解分析。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/263027.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# winfroms使用socket客户端服务端代码详解

文章目录 1️⃣ 通信相关说明1.1服务端与客户端1.2 信息发送原理1.3 信息接收原理 2️⃣ socket代码2.1 客户端代码2.2 服务端代码 3️⃣ 定时任务处理报文3.1 Timers定时任务 优质资源分享 作者:xcLeigh 文章地址:https://blog.csdn.net/weixin_4315141…

用友U8-OA协同工作系统doUpload.jsp接口任意文件上传漏洞

声明 本文仅用于技术交流,请勿用于非法用途 由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,文章作者不为此承担任何责任。 1、系统介绍 用友协同云是新一代的企业社交化协同办公平台&#xff0c…

LangChain原理学习笔记

最新越发觉得AI的发展,对未来是一场革命,LangChain已经在工程设计上有了最佳实践,类似于AI时代的编程模型或编程框架,有点Spring框架的意思。之前在LangChain上也有些最佳实践,所以在这里分享记录下。 LangChain解决什…

每日五道java面试题之spring篇(二)

目录: 第一题 Spring事务传播机制第二题 Spring事务什么时候会失效?第三题 什么是bean的⾃动装配,有哪些⽅式?第四题 Spring中的Bean创建的⽣命周期有哪些步骤?第五题 Spring中Bean是线程安全的吗? 第一题 Spring事务…

加载arcgis切片服务网络请求有大量404错误

需求: 前端访问arcgis切片服务时,在网络请求中出现大量404(Not Found)错误,切片时设置了感兴趣区域,在感兴趣范围内请求切片时能够正常返回切片。 问题分析: 设置感兴趣区域切片的目的是减少站…

Docker vs VM

关于应用程序的托管和开发,市场中的技术和产品琳琅满目。对比 Docker 和 VM,如何取舍?这主要由自身团队的因素决定,在选择 Docker 的情况下,你需要保证程序可在容器和虚拟机中运行。另外,成本和易用性也是重…

ArcgisForJS如何在线编辑ArcGIS Server发布的几何要素?

文章目录 0.引言1.ArcGIS创建几何要素2.ArcGIS Server发布几何要素3.ArcgisForJS在线编辑ArcGIS Server发布的几何要素 0.引言 ArcGIS For JS 是一种用于创建和编辑地理信息的 JavaScript 库,它允许用户在线编辑 ArcGIS Server 发布的几何要素。本文从ArcGIS创建几…

P8630 [蓝桥杯 2015 国 B] 密文搜索

P8630 [蓝桥杯 2015 国 B] 密文搜索 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)https://www.luogu.com.cn/problem/P8630 题目分析 基本上是hash的板子,但实际上对于密码串,只要判断主串中任意连续的八个位置是否存在密码串即可;那么我们…

使用Python制作进度条有多少种方法?看这一篇文章就够了!

前言 偶然间刷到一个视频,说到:当程序正在运算时,会有一个较长时间的空白期,谁也不知道程序运行的进度如何,不如给他加个进度条。 于是我今个就搜寻一下,Python版的进度条都可以怎么写! 送书…

PNPM 批量检查和更新项目依赖

🚀 作者主页: 有来技术 🔥 开源项目: youlai-mall 🍃 vue3-element-admin 🍃 youlai-boot 🌺 仓库主页: Gitee 💫 Github 💫 GitCode 💖 欢迎点赞…

国家建筑装配式内装产业基地在沪成立,副主任单位优积科技协同助推绿色低碳循环发展

上海市室内装饰行业协会装配式内装产业专业委员会成立大会暨“国家建筑装配式内装产业基地”项目启动会于3月21日下午1点在上海光大酒店隆重举行。出席此次活动的包括市装协会长徐国俭,市装协党支部书记兼秘书长丛国梁,市装协装配式内装委主任顾泰昌&…

热点参数流控(Sentinel)

热点参数流控 热点流控 资源必须使用注解 @SentinelResource编写接口 以及 热点参数流控处理器 /*** 热点流控 必须使用注解 @SentinelResource* @param id* @return*/ @RequestMapping("/getById/{id}") @SentinelResource(value = "getById", blockHand…

华清远见嵌入式学习——驱动开发——day9

目录 作业要求: 作业答案: 代码效果: ​编辑 Platform总线驱动代码: 应用程序代码: 设备树配置: 作业要求: 通过platform总线驱动框架编写LED灯的驱动,编写应用程序测试&…

转运机器人,AGV底盘小车:打造高效、精准的汽车电子生产线

为了满足日益增长的市场需求,保持行业领先地位,某汽车行业电子产品企业引入富唯智能AMR智能搬运机器人及其智能物流解决方案,采用自动化运输措施优化生产节拍和搬运效率,企业生产效率得到显著提升。 项目背景: 1、工厂…

C++中的STL数据结构

内容来自:代码随想录:哈希表理论基础 1.常见的三种哈希结构 当我们想使用哈希法来解决问题的时候,我们一般会选择如下三种数据结构 数组 set (集合) map(映射) 在C中,set 和 map 分别提供以下三种数据结构…

HTTPS(超文本传输安全协议)被恶意请求该如何处理。

HTTPS(超文本传输安全协议)端口攻击通常是指SSL握手中的一些攻击方式,比如SSL握手协商过程中的暴力破解、中间人攻击和SSL剥离攻击等。 攻击原理 攻击者控制受害者发送大量请求,利用压缩算法的机制猜测请求中的关键信息&#xf…

什么是SSD型云服务器?

​  SSD云服务器是一种使用固态硬盘代替传统HDD进行存储的虚拟机。SDD 使用闪存单元来存储数据,与云计算技术相结合,形成强大且高效的存储解决方案,可以随时随地访问。 SSD云服务器如何工作? SSD云服务器是利用虚拟化和云计算技术创建的。…

ElementUI table表格组件实现双击编辑单元格失去焦点还原,支持多单元格

在使用ElementUI table表格组件时有时需要双击单元格显示编辑状态,失去焦点时还原表格显示。 实现思路: 在数据中增加isFocus:false.控制是否显示在table中用cell-dblclick双击方法 先看效果: 上源码:在表格模板中用scope.row…

最新Unity游戏主程进阶学习大纲(2个月)

过完年了,很多同学开始重新规划自己的职业方向,找更好的机会,准备升职或加薪。今天给那些工作了1~5年的开发者梳理”游戏开发客户端主程”的学习大纲,帮助大家做好面试准备。适合Unity客户端开发者。进阶主程其实就是从固定的几个方面搭建好完整的知识体…

python编程中模块的调用方法

模块,就是制造大型程序的“零件"。这些零件可以是外购的也可以是“自造”的。它们的使用方法很简单,就是“拿来”——import. “拿来”模块的方法有from***import*** 和import***,宗旨就是“拿来”——import. 对不对?