#!/usr/bin/env python # Copyright 2024 Columbia Artificial Intelligence, Robotics Lab, # and 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. import torch from lerobot.constants import POSTPROCESSOR_DEFAULT_NAME, PREPROCESSOR_DEFAULT_NAME from lerobot.policies.diffusion.configuration_diffusion import DiffusionConfig from lerobot.processor import ( AddBatchDimensionProcessorStep, DeviceProcessorStep, NormalizerProcessorStep, PolicyProcessorPipeline, ProcessorKwargs, RenameProcessorStep, UnnormalizerProcessorStep, ) def make_diffusion_pre_post_processors( config: DiffusionConfig, dataset_stats: dict[str, dict[str, torch.Tensor]] | None = None, preprocessor_kwargs: ProcessorKwargs | None = None, postprocessor_kwargs: ProcessorKwargs | None = None, ) -> tuple[PolicyProcessorPipeline, PolicyProcessorPipeline]: if preprocessor_kwargs is None: preprocessor_kwargs = {} if postprocessor_kwargs is None: postprocessor_kwargs = {} input_steps = [ RenameProcessorStep(rename_map={}), NormalizerProcessorStep( features={**config.input_features, **config.output_features}, norm_map=config.normalization_mapping, stats=dataset_stats, ), AddBatchDimensionProcessorStep(), DeviceProcessorStep(device=config.device), ] output_steps = [ DeviceProcessorStep(device="cpu"), UnnormalizerProcessorStep( features=config.output_features, norm_map=config.normalization_mapping, stats=dataset_stats ), ] return ( PolicyProcessorPipeline( steps=input_steps, name=PREPROCESSOR_DEFAULT_NAME, **preprocessor_kwargs, ), PolicyProcessorPipeline( steps=output_steps, name=POSTPROCESSOR_DEFAULT_NAME, **postprocessor_kwargs, ), )