ZeroWBC: Learning Natural Visuomotor Humanoid Control Directly from Human Egocentric Video

ZeroWBC 是一种无需大规模机器人遥操作数据、直接利用人类第一人称视频微调视觉语言模型以生成并执行自然全身动作的人形机器人控制框架,显著提升了人形机器人在场景交互中的自然性与通用性。

Haoran Yang, Jiacheng Bao, Yucheng Xin, Haoming Song, Yuyang Tian, Bin Zhao, Dong Wang, Xuelong Li

发布于 Wed, 11 Ma
📖 1 分钟阅读☕ 轻松阅读

Each language version is independently generated for its own context, not a direct translation.

这篇论文介绍了一个名为 ZeroWBC 的新框架,它的核心目标非常宏大:让人形机器人像真人一样,自然地与环境互动,而且不需要昂贵的“真人遥控”数据来训练。

为了让你更容易理解,我们可以把机器人学习控制的过程想象成**“培养一个机器人演员”**。

1. 以前的痛点:教机器人太贵、太笨

  • 传统方法(遥控教学): 以前想教机器人“踢足球”或“坐沙发”,科学家得穿着特制衣服,像操纵木偶一样,用遥控器一步步控制机器人做动作,录下来教机器人。
    • 比喻: 这就像教一个小孩学骑车,你必须亲自扶着车把,一步步带着他走,累得半死,而且只能教这一种骑法。换个场景(比如去公园骑),小孩可能就不会了。
  • 现有问题: 这种方法成本极高,而且教出来的机器人动作很僵硬,只会死板地模仿,不会像人一样灵活地根据环境(比如前面有石头要绕开)调整动作。

2. ZeroWBC 的绝招:看“第一人称”视频自学

ZeroWBC 换了一种思路:既然机器人很难遥控,那我们就让它直接看人类自己拍的视频学习!

核心流程(两步走):

第一步:像“编剧”一样生成动作(多模态运动生成)

  • 输入: 给机器人看一段第一人称视角的视频(就像你戴着头盔摄像机拍的一样,能看到你眼前的沙发、球、障碍物),再给它一个文字指令(比如“去踢那个球”)。
  • 大脑(VLM): 系统里有一个经过微调的“超级大脑”(基于大语言模型)。它看过海量的人类视频和动作数据。
  • 输出: 这个大脑会根据视频画面和文字,脑补出接下来人类身体会怎么动(比如先抬腿、再摆臂、最后踢球)。
    • 比喻: 这就像你给一个资深编剧看一张“客厅里有沙发”的图,并说“我想坐下”,编剧立刻就能写出详细的剧本:人怎么走过去、怎么转身、怎么屁股着地。ZeroWBC 就是那个能写出“动作剧本”的编剧。

第二步:像“替身演员”一样精准执行(通用运动追踪)

  • 问题: 人类的身体和机器人的身体结构不一样(人有膝盖,机器人是关节电机),直接照搬剧本会摔倒。
  • 解决: 系统有一个**“通用追踪策略”。它就像一个经验丰富的替身演员武术指导**。
  • 过程: 它把“编剧”写好的“人类动作剧本”,瞬间翻译成“机器人能听懂的语言”,并指挥机器人精准地复现这些动作。
    • 比喻: 无论剧本里是“跳舞”、“打拳”还是“坐沙发”,这个替身演员都能完美演绎,而且不管场景怎么变(沙发位置变了、球滚远了),他都能灵活调整,不会死板地按原路走。

3. 它的厉害之处(实验结果)

作者在真实的 Unitree G1 机器人(一种人形机器人)上做了测试,效果惊人:

  • 零遥控数据: 全程没有用机器人遥控数据训练,完全靠看人类视频。
  • 自然流畅: 机器人能自然地踢足球避开障碍物走到椅子前坐下
  • 举一反三(泛化能力):
    • 少样本学习: 训练时没见过某种形状的箱子,但机器人能学会搬它。
    • 零样本能力(最牛): 训练数据里完全没有“坐椅子” 的例子,但机器人看到指令“坐椅子上”和眼前的椅子,竟然能自己分析出怎么坐,而且坐得很稳!
    • 比喻: 就像你教过孩子“坐沙发”,没教过“坐椅子”,但孩子看到椅子也能自己坐上去,因为他理解了“坐”这个动作的本质,而不是死记硬背。

4. 总结:为什么这很重要?

以前,让人形机器人变得“像人”一样灵活,需要花费巨资去采集数据,而且很难推广。
ZeroWBC 就像给机器人装上了一个“人类视角的模拟器”和“超级替身系统”。 它证明了:只要给机器人看足够多的人类第一人称视频,它就能学会像人一样在复杂的世界里灵活行动,而且成本极低,效率极高。

一句话总结:
ZeroWBC 让机器人不再需要人类手把手教,而是通过“看人类视频 + 听指令”,自己学会像人一样灵活地踢球、避障、坐沙发,真正迈向了“通用机器人”的时代。