首页
/ UI-TARS项目中动作历史传递机制的技术解析

UI-TARS项目中动作历史传递机制的技术解析

2025-06-09 14:16:09作者:董宙帆

背景概述

UI-TARS是一个由字节跳动开发的智能UI交互系统,其核心模型能够理解任务指令并根据历史交互记录进行决策。在项目文档中提到,模型输入包括任务指令、历史交互序列(观察o和动作a)以及当前观察oi。然而,许多开发者在实际应用中发现,官方示例提示中并未明确展示如何将历史动作和观察传递给模型。

技术实现原理

UI-TARS模型采用了基于Transformer的多模态架构,能够同时处理文本指令和视觉输入。对于历史交互的处理,系统采用以下技术方案:

  1. 上下文窗口管理:系统会维护一个固定长度的历史交互缓冲区,通常保留最近5次交互记录(受限于模型上下文长度)

  2. 多模态输入整合:历史记录以文本形式保存动作序列,而视觉观察则选择性保留。在实际实现中,为节省token消耗,通常会丢弃历史图像而仅保留文本描述

  3. 渐进式任务分解:模型通过分析历史步骤来理解当前任务进度,并据此规划下一步操作

实际应用建议

根据项目维护者的建议和示例代码,开发者可以按照以下方式实现历史传递:

  1. 文本历史记录:将之前的动作序列以纯文本形式追加到当前提示中

  2. 视觉信息处理:仅保留当前屏幕截图,历史视觉信息可选择性丢弃或用文本描述替代

  3. 上下文长度优化:采用滑动窗口机制,只保留最近几次关键交互记录

性能优化技巧

对于在AndroidWorld等环境中性能不佳的情况,可以考虑:

  1. 提示工程优化:调整历史记录的表述方式,使其更加简洁明确

  2. 关键帧选择:不是保留所有历史截图,而是识别并保留关键操作节点的屏幕状态

  3. 记忆压缩:对历史动作进行概括性描述而非完整记录

实现示例

参考项目中的测试消息示例,一个典型的多轮交互提示应包含:

{
  "instruction": "完成X任务",
  "history": [
    {"observation": "看到了Y界面", "action": "点击了Z按钮"},
    {"observation": "进入了W页面", "action": "输入了文本T"}
  ],
  "current_observation": "当前屏幕截图(base64编码)"
}

这种结构允许模型理解任务上下文,同时避免过长的提示消耗过多计算资源。

结论

UI-TARS的历史传递机制是其实现复杂任务的关键所在。开发者需要平衡历史信息的完整性和模型上下文限制,通过合理的提示设计和历史信息压缩,可以显著提升模型在AndroidWorld等环境中的表现。项目提供的示例消息结构为这种平衡提供了很好的实践参考。

登录后查看全文
热门项目推荐
相关项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
54
468
kernelkernel
deepin linux kernel
C
22
5
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
879
517
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
336
1.1 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
180
264
cjoycjoy
一个高性能、可扩展、轻量、省心的仓颉Web框架。Rest, 宏路由,Json, 中间件,参数绑定与校验,文件上传下载,MCP......
Cangjie
87
14
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.08 K
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
359
381
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
612
60