mirror of
https://github.com/huggingface/lerobot.git
synced 2026-05-20 19:19:56 +00:00
ca87ccd941
* feat(scripts): lerobot-rollout * fix(rollout) require dataset in dagger + use duration too * fix(docs): dagger num_episodes * test(rollout): fix expectations * fix(rollout): features check * fix(rollout): device and task propagation + feature pos + warn fps + move rename_map config * docs(rollout): edit rename_map instructions * chore(rollout): multiple minor improvements * chore(rollout): address coments + minor improvements * fix(rollout): enable default * fix(tests): default value RTCConfig * fix(rollout): robot_observation_processor and notify_observation at policy frequency instead of interpolator rate Co-authored-by: Pepijn <138571049+pkooij@users.noreply.github.com> * fix(rollout): prevent relativeactions with sync inference engine Co-authored-by: Pepijn <138571049+pkooij@users.noreply.github.com> * fix(rollout): rtc reanchor to non normalized state Co-authored-by: Pepijn <138571049+pkooij@users.noreply.github.com> * fix(rollout): fixing the episode length to use hwc (#3469) also reducing default length to 5 minutes * feat(rollout): go back to initial position is now a config * fix(rollout): properly propagating video_files_size_in_mb to lerobot_dataset (#3470) * chore(rollout): note about dagger correction stage * chore(docs): update comments and docstring * fix(test): move rtc relative out of rollout module * fix(rollout): address the review comments --------- Co-authored-by: Pepijn <138571049+pkooij@users.noreply.github.com> Co-authored-by: Maxime Ellerbach <maxime.ellerbach@huggingface.co>
56 lines
1.8 KiB
Python
56 lines
1.8 KiB
Python
#!/usr/bin/env python
|
|
|
|
# Copyright 2025 The HuggingFace Inc. team. All rights reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
"""
|
|
Real Time Chunking (RTC) and Bidirectional Decoding (BID) configuration classes.
|
|
|
|
Based on:
|
|
- Real Time Chunking: https://www.physicalintelligence.company/research/real_time_chunking
|
|
"""
|
|
|
|
from dataclasses import dataclass
|
|
|
|
from lerobot.configs import RTCAttentionSchedule
|
|
|
|
|
|
@dataclass
|
|
class RTCConfig:
|
|
"""Configuration for Real Time Chunking (RTC) inference.
|
|
|
|
RTC improves real-time inference by treating chunk generation as an inpainting problem,
|
|
strategically handling overlapping timesteps between action chunks using prefix attention.
|
|
"""
|
|
|
|
# Infrastructure
|
|
enabled: bool = True
|
|
|
|
# Core RTC settings
|
|
# Todo change to exp
|
|
prefix_attention_schedule: RTCAttentionSchedule = RTCAttentionSchedule.LINEAR
|
|
max_guidance_weight: float = 10.0
|
|
execution_horizon: int = 10
|
|
|
|
# Debug settings
|
|
debug: bool = False
|
|
debug_maxlen: int = 100
|
|
|
|
def __post_init__(self):
|
|
"""Validate RTC configuration parameters."""
|
|
if self.max_guidance_weight <= 0:
|
|
raise ValueError(f"max_guidance_weight must be positive, got {self.max_guidance_weight}")
|
|
if self.debug_maxlen <= 0:
|
|
raise ValueError(f"debug_maxlen must be positive, got {self.debug_maxlen}")
|