Intercept Grab#

Language Instruction

Intercept the rolling ball and grasp it to stop it.

Task Description

Predictive capture: infer a rolling ball path and grasp or stop it.

Render preview for Intercept Grab

Source#

  • Module: mikasa_robo_suite.vla.memory_envs.intercept_grab_vla

  • Source file: mikasa_robo_suite/vla/memory_envs/intercept_grab_vla.py

Difficulty and Parameters#

Slow, Medium, and Fast variants change timing precision.

Variants#

Env ID

Horizon

Data Source

InterceptGrabFast-VLA-v0

60

PPO

InterceptGrabMedium-VLA-v0

60

PPO

InterceptGrabSlow-VLA-v0

60

PPO

Run Example#

import gymnasium as gym
import torch

import mikasa_robo_suite.vla.memory_envs  # registers VLA env IDs
from mikasa_robo_suite.vla.utils.apply_wrappers import apply_mikasa_vla_wrappers

env = gym.make(
    "InterceptGrabSlow-VLA-v0",
    num_envs=1,
    obs_mode="rgb",
    control_mode="pd_ee_delta_pose",
    render_mode="all",
)
env = apply_mikasa_vla_wrappers(env)
obs, info = env.reset(seed=42)
for _ in range(env.max_episode_steps):
    action = env.action_space.sample()
    if not torch.is_tensor(action):
        action = torch.as_tensor(action, device=env.unwrapped.device)
    obs, reward, terminated, truncated, info = env.step(action)
env.close()

Dataset Collection#

PPO-sourced MIKASA-Robo-90 variants use oracle checkpoints:

uv run python mikasa_robo_suite/vla/dataset_collectors/get_mikasa_robo_datasets.py \
  --env-id InterceptGrabSlow-VLA-v0 \
  --path-to-save-data data_mikasa_robo \
  --ckpt-dir . \
  --num-train-data 250

Render Videos#

Generate a fresh MP4/GIF render with:

uv run python utils/prepare_benchmark_demo_videos.py \
  --tasks InterceptGrabSlow-VLA-v0 \
  --output-dir videos/benchmark_demos \
  --max-attempts-per-task 8 \
  --overwrite

Generated media stays under videos/ and should be published deliberately rather than committed by default.