isaac_manipulator_asset_bringup#
Source code available on GitHub.
Overview#
isaac_manipulator_asset_bringup is an asset management and model setup utility package for Isaac for Manipulation that automates the download, conversion, and configuration of deep learning models and test assets required for perception-based manipulation workflows. This package simplifies the setup process by providing a unified interface for preparing all necessary models and sample objects.
The package is automatically invoked during the build process when the MANIPULATOR_INSTALL_ASSETS environment variable is set, ensuring that all required perception models and assets are ready for use in Isaac for Manipulation tutorials and workflows.
Key Features#
- Automated Model Download: Downloads deep learning models from NGC, Google Drive, and other sources 
- Model Conversion: Converts PyTorch models to ONNX format for inference on x86 platforms 
- Asset Management: Organizes downloaded models and assets in the Isaac ROS workspace 
- Multi-Model Support: Handles setup for FoundationPose, DOPE, Segment Anything, and Gear Assembly models 
- Selective Setup: Allows users to download specific models or all models at once 
- Force Re-download: Option to force re-download and overwrite existing models 
- Directory Structure: Automatically creates and organizes the - isaac_ros_assetsdirectory structure
Supported Models and Assets#
The package supports setup for the following model types:
FoundationPose#
Purpose: 6DOF object pose estimation for manipulation tasks
Downloads:
- Mac and Cheese sample object assets (mesh and texture files) 
- Test assets for FoundationPose quickstart 
Requirements:
- FoundationPose models ( - refine_trt_engine.plan,- score_trt_engine.plan)
- SyntheticaDETR models ( - sdetr_grasp.plan)
Location: ${ISAAC_ROS_WS}/isaac_ros_assets/isaac_ros_foundationpose/
DOPE#
Purpose: Deep Object Pose Estimation for object tracking
Downloads:
- soup_60.pth: Pre-trained DOPE model for soup can detection
Source: Google Drive (via gdown)
Location: ${ISAAC_ROS_WS}/isaac_ros_assets/models/dope/
Segment Anything (SAM)#
Purpose: Object segmentation for Pick and Place workflows
Downloads:
- vit_b.pth:- ViT-BSAM model checkpoint from Meta AI
- SAM quickstart assets and configuration files 
Conversion: Converts PyTorch model to ONNX format on x86 platforms
Location:
- Assets: - ${ISAAC_ROS_WS}/isaac_ros_assets/isaac_ros_segment_anything/
- Model: - ${ISAAC_ROS_WS}/isaac_ros_assets/models/segment_anything/
Gear Assembly (UR DNN Policy)#
Purpose: Reinforcement learning policy for precision gear insertion
Downloads:
- UR DNN Policy assets for Gear Assembly tutorial 
- Pre-trained RL models for gear insertion tasks 
Location: ${ISAAC_ROS_WS}/isaac_ros_assets/isaac_manipulator_ur_dnn_policy/
Package Components#
Script: setup_perception_models.py#
The main executable script that handles all model setup operations.
Key Classes
ModelType Enum#
Defines supported model types:
- FOUNDATIONPOSE: FoundationPose model assets
- DOPE: DOPE model for pose estimation
- SEGMENT_ANYTHING: Segment Anything model and assets
- GEAR_ASSEMBLY: UR DNN Policy assets for gear assembly
- ALL: All available models
ModelSetup Class#
Main class that orchestrates model download, extraction, and conversion.
Key Methods:
def __init__(
    self,
    workspace_path: str,
    verbose: bool = False,
    force: bool = False
)
Initializes the model setup tool with workspace path and creates necessary directories.
def setup_foundation_pose() -> bool
Downloads FoundationPose quickstart assets including Mac and Cheese sample object.
def setup_dope() -> bool
Downloads DOPE model weights using gdown from Google Drive.
def setup_segment_anything() -> bool
Downloads SAM model and converts to ONNX format on x86 platforms.
def setup_sam_model() -> bool
Handles SAM model download and ONNX conversion with platform detection.
def setup_gear_assembly() -> bool
Downloads UR DNN Policy assets for gear assembly workflows.
def setup_models(model_types: List[ModelType]) -> bool
Main entry point that processes all requested model types.
Command-Line Interface#
The script provides a comprehensive CLI for model setup:
ros2 run isaac_manipulator_asset_bringup setup_perception_models.py [OPTIONS]
Command-Line Arguments#
| Argument | Type | Default | Description | 
|---|---|---|---|
| 
 | string | 
 | Path to the Isaac ROS workspace | 
| 
 | string[] | 
 | Models to set up ( | 
| 
 | flag | 
 | Skip TensorRT conversion steps | 
| 
 | flag | 
 | Enable verbose output | 
| 
 | flag | 
 | Show the directory structure after setup | 
| 
 | flag | 
 | Force re-download of models | 
Environment Variables#
| Variable | Description | Default | 
|---|---|---|
| 
 | Enable asset installation during build | Not set | 
| 
 | Isaac ROS workspace path | Required | 
| 
 | Alternative path for determining workspace location | Optional | 
Directory Structure#
The package creates and manages the following directory structure:
${ISAAC_ROS_WS}/
└── isaac_ros_assets/
    ├── isaac_ros_foundationpose/
    │   └── Mac_and_cheese_0_1/
    │       ├── Mac_and_cheese_0_1.obj
    │       └── texture_map.png
    ├── isaac_ros_segment_anything/
    │   ├── vit_b.pth
    │   └── sam_config_onnx.pbtxt
    ├── isaac_manipulator_ur_dnn_policy/
    │   └── [RL policy assets]
    └── models/
        ├── foundationpose/
        │   ├── refine_trt_engine.plan
        │   └── score_trt_engine.plan
        ├── synthetica_detr/
        │   └── sdetr_grasp.plan
        ├── dope/
        │   └── soup_60.pth
        └── segment_anything/
            ├── 1/
            │   └── model.onnx
            └── config.pbtxt
Usage Examples#
Example 1: Automatic Setup During Build#
The most common usage is during the build process:
# Enable asset installation
export MANIPULATOR_INSTALL_ASSETS=1
# Build the package (automatically downloads models)
cd ${ISAAC_ROS_WS}
colcon build --packages-up-to isaac_manipulator_asset_bringup
Example 2: Manual Setup for All Models#
# Set the environment variable
export MANIPULATOR_INSTALL_ASSETS=1
# Run the setup script for all models
ros2 run isaac_manipulator_asset_bringup setup_perception_models.py \
   --models all \
   --show-structure
Example 3: Setup Specific Models#
# Download only FoundationPose and Segment Anything models
export MANIPULATOR_INSTALL_ASSETS=1
ros2 run isaac_manipulator_asset_bringup setup_perception_models.py \
   --models foundationpose segment_anything \
   --verbose
Example 4: Force Re-download#
# Force re-download and overwrite existing models
export MANIPULATOR_INSTALL_ASSETS=1
ros2 run isaac_manipulator_asset_bringup setup_perception_models.py \
   --models all \
   --force
Example 5: Setup for Gear Assembly#
# Download only gear assembly assets
export MANIPULATOR_INSTALL_ASSETS=1
ros2 run isaac_manipulator_asset_bringup setup_perception_models.py \
   --models gear_assembly segment_anything
Integration with Isaac for Manipulation Tutorials#
This package is referenced in all Isaac for Manipulation tutorials that require perception models:
Pick and Place Tutorial#
The Pick and Place tutorial requires FoundationPose and SyntheticaDETR models:
export MANIPULATOR_INSTALL_ASSETS=1
colcon build --packages-up-to isaac_manipulator_asset_bringup
This downloads the Mac and Cheese sample object and verifies that perception models are available.
Gear Assembly Tutorial#
The Gear Assembly tutorial additionally requires UR DNN Policy assets:
export MANIPULATOR_INSTALL_ASSETS=1
colcon build --packages-up-to isaac_manipulator_asset_bringup
This ensures all models including reinforcement learning policies are available.
Isaac Sim Tutorials#
Isaac Sim tutorials use the same setup process to ensure consistent model availability:
export MANIPULATOR_INSTALL_ASSETS=1
export FOUNDATIONSTEREO_MODEL_RES=low_res
colcon build --packages-up-to isaac_manipulator_asset_bringup
Platform-Specific Behavior#
x86 Platforms#
On x86 platforms (x86_64, AMD64), the script performs ONNX conversion for SAM models:
- Downloads PyTorch checkpoint 
- Converts to ONNX format using - ros2 run isaac_ros_segment_anything torch_to_onnx.py
- Saves ONNX model for TensorRT inference 
ARM Platforms (Jetson)#
On ARM platforms (Jetson devices):
- Downloads PyTorch checkpoint for reference 
- Skips ONNX conversion (handled differently for Jetson)- this is not supported for Jetson, the user is expected to do the manual - onnxconversion using documentation specific to each package and then copy over their model assets to the correct folders. The ONNX conversion is required for the- GROUNDING_DINO,- SEGMENT_ANYTHINGand- SEGMENT_ANYTHING2models.
- Uses platform-optimized inference paths 
Troubleshooting#
Models Not Found After Build#
Issue: Models are not downloaded during build.
Solution: Ensure MANIPULATOR_INSTALL_ASSETS=1 is set before building:
export MANIPULATOR_INSTALL_ASSETS=1
colcon build --packages-up-to isaac_manipulator_asset_bringup
Download Failures#
Issue: Network errors or download failures.
Solution: Use --force to retry downloads:
export MANIPULATOR_INSTALL_ASSETS=1
ros2 run isaac_manipulator_asset_bringup setup_perception_models.py \
   --force --verbose
ONNX Conversion Fails#
Issue: SAM model conversion to ONNX fails.
Solution: Ensure segment_anything package is installed:
pip install --break-system-packages git+https://github.com/facebookresearch/segment-anything.git
Missing gdown Package#
Issue: DOPE model download fails due to missing gdown.
Solution: The script automatically installs gdown, but if it fails:
pip install --break-system-packages gdown
Dependencies#
Runtime Dependencies
- isaac_ros_dope: DOPE perception pipeline
- isaac_common_py: Isaac common Python utilities
- python3-gdown: Google Drive file download utility
Build Dependencies
- isaac_ros_common: Isaac ROS common infrastructure
- isaac_ros_ess_models_install: ESS depth estimation models
- isaac_ros_foundationpose_models_install: FoundationPose models
- isaac_ros_foundationstereo_models_install: FoundationStereo models
- isaac_ros_grounding_dino_models_install: Grounding DINO models
- isaac_ros_rtdetr_models_install: RT-DETR models
- isaac_ros_segment_anything: Segment Anything model management
Python Dependencies (via requirements.txt)
- torchvision==0.16.1+cu121: PyTorch vision utilities
- gdown==5.2.0: Google Drive download utility
Implementation Notes#
Design Philosophy
The package follows these design principles:
- Idempotent Operations: Re-running setup is safe and skips existing files 
- Logging and Verbosity: Clear logging with optional verbose mode for debugging 
- Error Handling: Graceful failure handling with informative error messages 
- Platform Detection: Automatic platform detection for optimal setup paths 
Performance Considerations
- Large files are downloaded with progress tracking 
- Extraction happens in-place to minimize disk usage 
- Tarballs are removed after extraction to save space 
- Existing files are skipped unless - --forceis used
Extensibility
To add new model types:
- Add new enum value to - ModelType
- Implement setup method (e.g., - setup_new_model())
- Add case in - setup_models()method
- Update documentation and CLI help