AI Agents 相关度: 7/10

Edit-As-Act: Goal-Regressive Planning for Open-Vocabulary 3D Indoor Scene Editing

Seongrae Noh, SeungWon Seo, Gyeong-Moon Park, HyeongYeop Kang
arXiv: 2603.17583v1 发布: 2026-03-18 更新: 2026-03-18

AI 摘要

该论文提出Edit-As-Act框架,利用目标回溯规划实现开放词汇3D室内场景编辑。

主要贡献

  • 提出Edit-As-Act框架
  • 设计EditLang动作语言
  • 构建E2A-Bench基准测试

方法论

将场景编辑视为目标回溯规划,通过语言驱动的规划器和验证器实现指令忠实、语义一致和物理合理的编辑。

原文摘要

Editing a 3D indoor scene from natural language is conceptually straightforward but technically challenging. Existing open-vocabulary systems often regenerate large portions of a scene or rely on image-space edits that disrupt spatial structure, resulting in unintended global changes or physically inconsistent layouts. These limitations stem from treating editing primarily as a generative task. We take a different view. A user instruction defines a desired world state, and editing should be the minimal sequence of actions that makes this state true while preserving everything else. This perspective motivates Edit-As-Act, a framework that performs open-vocabulary scene editing as goal-regressive planning in 3D space. Given a source scene and free-form instruction, Edit-As-Act predicts symbolic goal predicates and plans in EditLang, a PDDL-inspired action language that we design with explicit preconditions and effects encoding support, contact, collision, and other geometric relations. A language-driven planner proposes actions, and a validator enforces goal-directedness, monotonicity, and physical feasibility, producing interpretable and physically coherent transformations. By separating reasoning from low-level generation, Edit-As-Act achieves instruction fidelity, semantic consistency, and physical plausibility - three criteria that existing paradigms cannot satisfy together. On E2A-Bench, our benchmark of 63 editing tasks across 9 indoor environments, Edit-As-Act significantly outperforms prior approaches across all edit types and scene categories.

标签

3D scene editing goal-regressive planning open-vocabulary

arXiv 分类

cs.CV cs.AI