Prop-Robotics-Isaac Profile#
This document describes how to author a USD asset that conforms to the
Prop-Robotics-Isaac profile. It consolidates the required feature set, USD
properties, naming conventions, and Isaac Sim composition requirements.
Profile definition#
The Prop-Robotics-Isaac profile includes the following feature set (see profiles.toml and the feature dependency graph). Each feature’s requirements and dependencies are defined in the feature specifications.
[Prop-Robotics-Isaac]
"1.0.0" = {features = [
{"FET001_BASE_NEUTRAL" = {version = "0.1.0"}}, # Minimal
{"FET003_BASE_PHYSX" = {version = "0.1.0"}}, # RBD Physics (PhysX)
{"FET004_BASE_PHYSX" = {version = "0.1.0"}}, # Multi-Body Physics (PhysX)
{"FET005_BASE_NEUTRAL" = {version = "0.1.0"}}, # Grasp Physics
{"FET100_BASE_ISAACSIM" = {version = "0.1.0"}}, # Isaac composition
]}
Required USD properties and schemas#
Stage metadata (required)#
defaultPrimmust be set on every layer.upAxis = "Z"andmetersPerUnit = 1must be set on every stage.
PhysX rigid bodies and colliders (required)#
Apply
PhysicsRigidBodyAPIto any simulated rigid body prim.Apply
PhysicsCollisionAPIto collision-enabled prims.Author
physics:approximation = "sdf"for PhysX collider approximation.Rigid body prims must be
UsdGeomXformable.
Multi-body joints (required)#
Use
UsdPhysicsJointprims (or subtypes) to connect rigid bodies.Author
rel physics:body0andrel physics:body1relationships.Apply
PhysxJointAPIwhen authoring PhysX-specific joint properties.
Grasp physics (required)#
Author grasp data according to
FET005_BASE_NEUTRALrequirements.
Isaac Sim composition requirements#
Assets must follow the Isaac Sim composition pattern with a main USD that references and payloads separate mesh and physics layers.
Required structure#
asset_name.usd # Main composition file
payloads/
asset_name_meshes.usd # Geometry and materials
asset_name_base.usd # Base reference layer
asset_name_physics.usd # Physics data
configuration/
asset_name_physics.usd # Configuration layer combining base+physics
Composition rules#
The main USD must have a default prim with
kind = "component".Use relative paths for all references and payloads.
Materials are organized under a
Looksscope in the meshes payload.Raw meshes live under a
Meshesscope (invisible).Visual hierarchy lives under a
Visualsscope (invisible).Physics schemas and attributes are applied in the physics payload only.
Naming conventions#
Prim naming#
Choose either
camelCaseorsnake_caseand use it consistently.Avoid spaces, special characters, and reserved keywords.
Use descriptive, purpose-driven names.
Use prefixes by prim type when appropriate (e.g.,
mesh_,material_).
File naming#
Use lowercase file names.
Use
.usd,.usda,.usdc, or.usdzas appropriate.Use underscores or hyphens; avoid spaces and special characters.
Avoid reserved names (e.g.,
CON,PRN,AUX,NUL).Use version numbers when appropriate (e.g.,
_v1.0).
Validation metadata (recommended)#
Include profile metadata in customLayerData to simplify validation workflows:
customLayerData = {
dictionary SimReady_Metadata = {
dictionary validation = {
string profile = "Prop-Robotics-Isaac"
string profile_version = "1.0.0"
}
}
}
References#
Feature dependency graph — requirements and dependencies for all features
nv_core/sr_specs/docs/profiles/profiles.tomlnv_core/sr_specs/docs/features/FET_001-minimal.mdnv_core/sr_specs/docs/features/FET_003-rigid_body_physics.mdnv_core/sr_specs/docs/features/FET_004-simulate_multi_body_physics.mdnv_core/sr_specs/docs/features/FET_005-simulate_grasp_physics.mdnv_core/sr_specs/docs/features/FET_100-isaacsim-0.1.0-composition.mdnv_core/sr_specs/docs/capabilities/isaac_sim/composition/requirements/composition.mdnv_core/sr_specs/docs/capabilities/core/naming_paths/requirements/prim-naming-convention.mdnv_core/sr_specs/docs/capabilities/core/naming_paths/requirements/file-naming-convention.md