protomotions.utils.component_builder module¶
Utility functions for building environment components.
This module provides helper functions to create terrain, scene_lib, motion_lib, and simulator objects from their configs, reducing boilerplate in entry scripts.
- protomotions.utils.component_builder.build_terrain_from_config(terrain_config, num_envs, device)[source]¶
Build Terrain from config.
- Parameters:
terrain_config – TerrainConfig or None (exception: can be None for no terrain)
num_envs (int) – Number of environments
device (<Mock object at 0x701e6b29f710>[]) – PyTorch device
- Returns:
Terrain instance or None if config is None
- protomotions.utils.component_builder.build_scene_lib_from_config(scene_lib_config, num_envs, device, terrain, scene_weights=None)[source]¶
Build SceneLib from config.
Always returns a SceneLib instance. If config.scene_file is None, creates an empty SceneLib (Null Object pattern).
- Parameters:
scene_lib_config – SceneLibConfig (required, scene_file can be None for empty)
num_envs (int) – Number of environments
device (<Mock object at 0x701e6b2e3e10>[]) – PyTorch device
terrain – Terrain instance (required by SceneLib)
scene_weights (list | None) – Optional scene weights for curriculum learning
- Returns:
SceneLib instance (empty if scene_file is None)
- protomotions.utils.component_builder.build_motion_lib_from_config(motion_lib_config, device)[source]¶
Build MotionLib from config.
Always returns a MotionLib instance. If config.motion_file is None, creates an empty MotionLib (Null Object pattern).
Note: Contact smoothing is NOT applied here - it’s the Env’s responsibility to modify the motion_lib during initialization based on its config.
- Parameters:
motion_lib_config – MotionLibConfig (required, motion_file can be None for empty)
device (<Mock object at 0x701e6b2e0c90>[]) – PyTorch device
- Returns:
MotionLib instance (empty if motion_file is None)
- protomotions.utils.component_builder.build_simulator_from_config(simulator_config, robot_config, terrain, scene_lib, device, **simulator_extra_params)[source]¶
Build Simulator from config.
Creates simulator shell (deferred initialization - will be finalized by Env).
- Parameters:
simulator_config – SimulatorConfig
robot_config – RobotConfig
terrain – Terrain instance
scene_lib – SceneLib instance or None
device (<Mock object at 0x701e6b29eb90>[]) – PyTorch device
**simulator_extra_params – Simulator-specific params (e.g., simulation_app for IsaacLab)
- Returns:
Simulator instance (shell, not yet initialized)
- protomotions.utils.component_builder.build_all_components(terrain_config, scene_lib_config, motion_lib_config, simulator_config, robot_config, device, save_dir=None, **simulator_extra_params)[source]¶
Build all environment components from configs.
Convenience function that builds terrain, scene_lib, motion_lib, and simulator.
- Parameters:
terrain_config – TerrainConfig (or None for no terrain - exception)
scene_lib_config – SceneLibConfig (always provided, scene_file can be None for empty)
motion_lib_config – MotionLibConfig (always provided, motion_file can be None for empty)
simulator_config – SimulatorConfig
robot_config – RobotConfig
device (<Mock object at 0x701e6b2ed150>[]) – PyTorch device
save_dir (str | None) – Optional save directory for loading motion weights as scene weights
**simulator_extra_params – Simulator-specific params (e.g., simulation_app for IsaacLab)
- Returns:
terrain, scene_lib, motion_lib, simulator
- Return type:
Dict with keys