isaaclab.assets#
Sub-package for different assets, such as rigid objects and articulations.
An asset is a physical object that can be spawned in the simulation. The class handles both the spawning of the asset into the USD stage as well as initialization of necessary physics handles to interact with the asset.
Upon construction of the asset instance, the prim corresponding to the asset is spawned into the
USD stage if the spawn configuration is not None. The spawn configuration is defined in the
AssetBaseCfg.spawn attribute. In case the configured AssetBaseCfg.prim_path is
an expression, then the prim is spawned at all the matching paths. Otherwise, a single prim is
spawned at the configured path. For more information on the spawn configuration, see the
isaaclab.sim.spawners module.
The asset class also registers callbacks for the stage play/stop events. These are used to
construct the physics handles for the asset as the physics engine is only available when the
stage is playing. Additionally, the class registers a callback for debug visualization of the
asset. This can be enabled by setting the AssetBaseCfg.debug_vis attribute to True.
The asset class follows the following naming convention for its methods:
- set_xxx(): These are used to only set the buffers into the - datainstance. However, they do not write the data into the simulator. The writing of data only happens when the- write_data_to_sim()method is called.
- write_xxx_to_sim(): These are used to set the buffers into the - datainstance and write the corresponding data into the simulator as well.
- update(dt): These are used to update the buffers in the - datainstance. This should be called after a simulation step is performed.
The main reason to separate the set and write operations is to provide flexibility to the
user when they need to perform a post-processing operation of the buffers before applying them
into the simulator. A common example for this is dealing with explicit actuator models where the
specified joint targets are not directly applied to the simulator but are instead used to compute
the corresponding actuator torques.
Classes
| The base interface class for assets. | |
| The base configuration class for an asset's parameters. | |
| A rigid object asset class. | |
| Data container for a rigid object. | |
| Configuration parameters for a rigid object. | |
| A rigid object collection class. | |
| Data container for a rigid object collection. | |
| Configuration parameters for a rigid object collection. | |
| An articulation asset class. | |
| Data container for an articulation. | |
| Configuration parameters for an articulation. | |
| A deformable object asset class. | |
| Data container for a deformable object. | |
| Configuration parameters for a deformable object. | 
Asset Base#
- class isaaclab.assets.AssetBase[源代码]#
- The base interface class for assets. - An asset corresponds to any physics-enabled object that can be spawned in the simulation. These include rigid objects, articulated objects, deformable objects etc. The core functionality of an asset is to provide a set of buffers that can be used to interact with the simulator. The buffers are updated by the asset class and can be written into the simulator using the their respective - writemethods. This allows a convenient way to perform post-processing operations on the buffers before writing them into the simulator and obtaining the corresponding simulation results.- The class handles both the spawning of the asset into the USD stage as well as initialization of necessary physics handles to interact with the asset. Upon construction of the asset instance, the prim corresponding to the asset is spawned into the USD stage if the spawn configuration is not None. The spawn configuration is defined in the - AssetBaseCfg.spawnattribute. In case the configured- AssetBaseCfg.prim_pathis an expression, then the prim is spawned at all the matching paths. Otherwise, a single prim is spawned at the configured path. For more information on the spawn configuration, see the- isaaclab.sim.spawnersmodule.- Unlike Isaac Sim interface, where one usually needs to call the - isaacsim.core.prims.XFormPrim.initialize()method to initialize the PhysX handles, the asset class automatically initializes and invalidates the PhysX handles when the stage is played/stopped. This is done by registering callbacks for the stage play/stop events.- Additionally, the class registers a callback for debug visualization of the asset if a debug visualization is implemented in the asset class. This can be enabled by setting the - AssetBaseCfg.debug_visattribute to True. The debug visualization is implemented through the- _set_debug_vis_impl()and- _debug_vis_callback()methods.- Methods: - __init__(cfg)- Initialize the asset base. - set_visibility(visible[, env_ids])- Set the visibility of the prims corresponding to the asset. - set_debug_vis(debug_vis)- Sets whether to visualize the asset data. - reset([env_ids])- Resets all internal buffers of selected environments. - Writes data to the simulator. - update(dt)- Update the internal buffers. - Attributes: - Whether the asset is initialized. - Number of instances of the asset. - Memory device for computation. - Data related to the asset. - Whether the asset has a debug visualization implemented. - __init__(cfg: AssetBaseCfg)[源代码]#
- Initialize the asset base. - 参数:
- cfg – The configuration class for the asset. 
- 抛出:
- RuntimeError – If no prims found at input prim path or prim path expression. 
 
 - property is_initialized: bool#
- Whether the asset is initialized. - Returns True if the asset is initialized, False otherwise. 
 - abstract property num_instances: int#
- Number of instances of the asset. - This is equal to the number of asset instances per environment multiplied by the number of environments. 
 - property has_debug_vis_implementation: bool#
- Whether the asset has a debug visualization implemented. 
 - set_visibility(visible: bool, env_ids: Sequence[int] | None = None)[源代码]#
- Set the visibility of the prims corresponding to the asset. - This operation affects the visibility of the prims corresponding to the asset in the USD stage. It is useful for toggling the visibility of the asset in the simulator. For instance, one can hide the asset when it is not being used to reduce the rendering overhead. - 备注 - This operation uses the PXR API to set the visibility of the prims. Thus, the operation may have an overhead if the number of prims is large. - 参数:
- visible – Whether to make the prims visible or not. 
- env_ids – The indices of the object to set visibility. Defaults to None (all instances). 
 
 
 - set_debug_vis(debug_vis: bool) bool[源代码]#
- Sets whether to visualize the asset data. - 参数:
- debug_vis – Whether to visualize the asset data. 
- 返回:
- Whether the debug visualization was successfully set. False if the asset does not support debug visualization. 
 
 
- class isaaclab.assets.AssetBaseCfg[源代码]#
- The base configuration class for an asset’s parameters. - Please see the - AssetBaseclass for more information on the asset class.- Attributes: - Prim path (or expression) to the asset. - Spawn configuration for the asset. - Initial state of the rigid object. - Collision group of the asset. - Whether to enable debug visualization for the asset. - prim_path: str#
- Prim path (or expression) to the asset. - 备注 - The expression can contain the environment namespace regex - {ENV_REGEX_NS}which will be replaced with the environment namespace.- Example: - {ENV_REGEX_NS}/Robotwill be replaced with- /World/envs/env_.*/Robot.
 - spawn: SpawnerCfg | None#
- Spawn configuration for the asset. Defaults to None. - If None, then no prims are spawned by the asset class. Instead, it is assumed that the asset is already present in the scene. 
 - init_state: InitialStateCfg#
- Initial state of the rigid object. Defaults to identity pose. 
 - collision_group: Literal[0, -1]#
- Collision group of the asset. Defaults to - 0.- -1: global collision group (collides with all assets in the scene).
- 0: local collision group (collides with other assets in the same environment).
 
 
Rigid Object#
- class isaaclab.assets.RigidObject[源代码]#
- 基类: - AssetBase- A rigid object asset class. - Rigid objects are assets comprising of rigid bodies. They can be used to represent dynamic objects such as boxes, spheres, etc. A rigid body is described by its pose, velocity and mass distribution. - For an asset to be considered a rigid object, the root prim of the asset must have the USD RigidBodyAPI applied to it. This API is used to define the simulation properties of the rigid body. On playing the simulation, the physics engine will automatically register the rigid body and create a corresponding rigid body handle. This handle can be accessed using the - root_physx_viewattribute.- 备注 - For users familiar with Isaac Sim, the PhysX view class API is not the exactly same as Isaac Sim view class API. Similar to Isaac Lab, Isaac Sim wraps around the PhysX view API. However, as of now (2023.1 release), we see a large difference in initializing the view classes in Isaac Sim. This is because the view classes in Isaac Sim perform additional USD-related operations which are slow and also not required. - Attributes: - Configuration instance for the rigid object. - Data related to the asset. - Number of instances of the asset. - Number of bodies in the asset. - Ordered names of bodies in the rigid object. - Rigid body view for the asset (PhysX). - Memory device for computation. - Whether the asset has a debug visualization implemented. - Whether the asset is initialized. - Methods: - __init__(cfg)- Initialize the rigid object. - reset([env_ids])- Resets all internal buffers of selected environments. - Write external wrench to the simulation. - update(dt)- Update the internal buffers. - find_bodies(name_keys[, preserve_order])- Find bodies in the rigid body based on the name keys. - write_root_state_to_sim(root_state[, env_ids])- Set the root state over selected environment indices into the simulation. - write_root_com_state_to_sim(root_state[, ...])- Set the root center of mass state over selected environment indices into the simulation. - write_root_link_state_to_sim(root_state[, ...])- Set the root link state over selected environment indices into the simulation. - write_root_pose_to_sim(root_pose[, env_ids])- Set the root pose over selected environment indices into the simulation. - write_root_link_pose_to_sim(root_pose[, env_ids])- Set the root link pose over selected environment indices into the simulation. - write_root_com_pose_to_sim(root_pose[, env_ids])- Set the root center of mass pose over selected environment indices into the simulation. - write_root_velocity_to_sim(root_velocity[, ...])- Set the root center of mass velocity over selected environment indices into the simulation. - write_root_com_velocity_to_sim(root_velocity)- Set the root center of mass velocity over selected environment indices into the simulation. - write_root_link_velocity_to_sim(root_velocity)- Set the root link velocity over selected environment indices into the simulation. - set_external_force_and_torque(forces, torques)- Set external force and torque to apply on the asset's bodies in their local frame. - set_debug_vis(debug_vis)- Sets whether to visualize the asset data. - set_visibility(visible[, env_ids])- Set the visibility of the prims corresponding to the asset. - cfg: RigidObjectCfg#
- Configuration instance for the rigid object. 
 - __init__(cfg: RigidObjectCfg)[源代码]#
- Initialize the rigid object. - 参数:
- cfg – A configuration instance. 
 
 - property data: RigidObjectData#
- Data related to the asset. 
 - property num_instances: int#
- Number of instances of the asset. - This is equal to the number of asset instances per environment multiplied by the number of environments. 
 - property num_bodies: int#
- Number of bodies in the asset. - This is always 1 since each object is a single rigid body. 
 - property root_physx_view: omni.physics.tensors.impl.api.RigidBodyView#
- Rigid body view for the asset (PhysX). - 备注 - Use this view with caution. It requires handling of tensors in a specific way. 
 - reset(env_ids: Sequence[int] | None = None)[源代码]#
- Resets all internal buffers of selected environments. - 参数:
- env_ids – The indices of the object to reset. Defaults to None (all instances). 
 
 - write_data_to_sim()[源代码]#
- Write external wrench to the simulation. - 备注 - We write external wrench to the simulation here since this function is called before the simulation step. This ensures that the external wrench is applied at every simulation step. 
 - update(dt: float)[源代码]#
- Update the internal buffers. - The time step - dtis used to compute numerical derivatives of quantities such as joint accelerations which are not provided by the simulator.- 参数:
- dt – The amount of time passed from last - updatecall.
 
 - find_bodies(name_keys: str | Sequence[str], preserve_order: bool = False) tuple[list[int], list[str]][源代码]#
- Find bodies in the rigid body based on the name keys. - Please check the - isaaclab.utils.string_utils.resolve_matching_names()function for more information on the name matching.- 参数:
- name_keys – A regular expression or a list of regular expressions to match the body names. 
- preserve_order – Whether to preserve the order of the name keys in the output. Defaults to False. 
 
- 返回:
- A tuple of lists containing the body indices and names. 
 
 - write_root_state_to_sim(root_state: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root state over selected environment indices into the simulation. - The root state comprises of the cartesian position, quaternion orientation in (w, x, y, z), and linear and angular velocity. All the quantities are in the simulation frame. - 参数:
- root_state – Root state in simulation frame. Shape is (len(env_ids), 13). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_com_state_to_sim(root_state: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root center of mass state over selected environment indices into the simulation. - The root state comprises of the cartesian position, quaternion orientation in (w, x, y, z), and linear and angular velocity. All the quantities are in the simulation frame. - 参数:
- root_state – Root state in simulation frame. Shape is (len(env_ids), 13). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_link_state_to_sim(root_state: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root link state over selected environment indices into the simulation. - The root state comprises of the cartesian position, quaternion orientation in (w, x, y, z), and linear and angular velocity. All the quantities are in the simulation frame. - 参数:
- root_state – Root state in simulation frame. Shape is (len(env_ids), 13). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_pose_to_sim(root_pose: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root pose over selected environment indices into the simulation. - The root pose comprises of the cartesian position and quaternion orientation in (w, x, y, z). - 参数:
- root_pose – Root link poses in simulation frame. Shape is (len(env_ids), 7). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_link_pose_to_sim(root_pose: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root link pose over selected environment indices into the simulation. - The root pose comprises of the cartesian position and quaternion orientation in (w, x, y, z). - 参数:
- root_pose – Root link poses in simulation frame. Shape is (len(env_ids), 7). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_com_pose_to_sim(root_pose: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root center of mass pose over selected environment indices into the simulation. - The root pose comprises of the cartesian position and quaternion orientation in (w, x, y, z). The orientation is the orientation of the principle axes of inertia. - 参数:
- root_pose – Root center of mass poses in simulation frame. Shape is (len(env_ids), 7). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_velocity_to_sim(root_velocity: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root center of mass velocity over selected environment indices into the simulation. - The velocity comprises linear velocity (x, y, z) and angular velocity (x, y, z) in that order. NOTE: This sets the velocity of the root’s center of mass rather than the roots frame. - 参数:
- root_velocity – Root center of mass velocities in simulation world frame. Shape is (len(env_ids), 6). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_com_velocity_to_sim(root_velocity: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root center of mass velocity over selected environment indices into the simulation. - The velocity comprises linear velocity (x, y, z) and angular velocity (x, y, z) in that order. NOTE: This sets the velocity of the root’s center of mass rather than the roots frame. - 参数:
- root_velocity – Root center of mass velocities in simulation world frame. Shape is (len(env_ids), 6). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_link_velocity_to_sim(root_velocity: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root link velocity over selected environment indices into the simulation. - The velocity comprises linear velocity (x, y, z) and angular velocity (x, y, z) in that order. NOTE: This sets the velocity of the root’s frame rather than the roots center of mass. - 参数:
- root_velocity – Root frame velocities in simulation world frame. Shape is (len(env_ids), 6). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - set_external_force_and_torque(forces: torch.Tensor, torques: torch.Tensor, positions: torch.Tensor | None = None, body_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None, is_global: bool = False)[源代码]#
- Set external force and torque to apply on the asset’s bodies in their local frame. - For many applications, we want to keep the applied external force on rigid bodies constant over a period of time (for instance, during the policy control). This function allows us to store the external force and torque into buffers which are then applied to the simulation at every step. Optionally, set the position to apply the external wrench at (in the local link frame of the bodies). - 小心 - If the function is called with empty forces and torques, then this function disables the application of external wrench to the simulation. - # example of disabling external wrench asset.set_external_force_and_torque(forces=torch.zeros(0, 3), torques=torch.zeros(0, 3)) - 小心 - If the function is called consecutively with and with different values for - is_global, then the all the external wrenches will be applied in the frame specified by the last call.- # example of setting external wrench in the global frame asset.set_external_force_and_torque(forces=torch.ones(1, 1, 3), env_ids=[0], is_global=True) # example of setting external wrench in the link frame asset.set_external_force_and_torque(forces=torch.ones(1, 1, 3), env_ids=[1], is_global=False) # Both environments will have the external wrenches applied in the link frame - 备注 - This function does not apply the external wrench to the simulation. It only fills the buffers with the desired values. To apply the external wrench, call the - write_data_to_sim()function right before the simulation step.- 参数:
- forces – External forces in bodies’ local frame. Shape is (len(env_ids), len(body_ids), 3). 
- torques – External torques in bodies’ local frame. Shape is (len(env_ids), len(body_ids), 3). 
- positions – External wrench positions in bodies’ local frame. Shape is (len(env_ids), len(body_ids), 3). Defaults to None. 
- body_ids – Body indices to apply external wrench to. Defaults to None (all bodies). 
- env_ids – Environment indices to apply external wrench to. Defaults to None (all instances). 
- is_global – Whether to apply the external wrench in the global frame. Defaults to False. If set to False, the external wrench is applied in the link frame of the bodies. 
 
 
 - property has_debug_vis_implementation: bool#
- Whether the asset has a debug visualization implemented. 
 - property is_initialized: bool#
- Whether the asset is initialized. - Returns True if the asset is initialized, False otherwise. 
 - set_debug_vis(debug_vis: bool) bool#
- Sets whether to visualize the asset data. - 参数:
- debug_vis – Whether to visualize the asset data. 
- 返回:
- Whether the debug visualization was successfully set. False if the asset does not support debug visualization. 
 
 - set_visibility(visible: bool, env_ids: Sequence[int] | None = None)#
- Set the visibility of the prims corresponding to the asset. - This operation affects the visibility of the prims corresponding to the asset in the USD stage. It is useful for toggling the visibility of the asset in the simulator. For instance, one can hide the asset when it is not being used to reduce the rendering overhead. - 备注 - This operation uses the PXR API to set the visibility of the prims. Thus, the operation may have an overhead if the number of prims is large. - 参数:
- visible – Whether to make the prims visible or not. 
- env_ids – The indices of the object to set visibility. Defaults to None (all instances). 
 
 
 
- class isaaclab.assets.RigidObjectData[源代码]#
- 基类: - object- Data container for a rigid object. - This class contains the data for a rigid object in the simulation. The data includes the state of the root rigid body and the state of all the bodies in the object. The data is stored in the simulation world frame unless otherwise specified. - For a rigid body, there are two frames of reference that are used: - Actor frame: The frame of reference of the rigid body prim. This typically corresponds to the Xform prim with the rigid body schema. 
- Center of mass frame: The frame of reference of the center of mass of the rigid body. 
 - Depending on the settings of the simulation, the actor frame and the center of mass frame may be the same. This needs to be taken into account when interpreting the data. - The data is lazily updated, meaning that the data is only updated when it is accessed. This is useful when the data is expensive to compute or retrieve. The data is updated when the timestamp of the buffer is older than the current simulation timestamp. The timestamp is updated whenever the data is updated. - Methods: - update(dt)- Updates the data for the rigid object. - Attributes: - Body names in the order parsed by the simulation view. - Default root state - [pos, quat, lin_vel, ang_vel]in local environment frame.- Default mass read from the simulation. - Default inertia tensor read from the simulation. - Root link pose - [pos, quat]in simulation world frame.- Root link velocity - [lin_vel, ang_vel]in simulation world frame.- Root center of mass pose - [pos, quat]in simulation world frame.- Root center of mass velocity - [lin_vel, ang_vel]in simulation world frame.- Root state - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Root state - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Root center of mass state - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Body link pose - [pos, quat]in simulation world frame.- Body link velocity - [lin_vel, ang_vel]in simulation world frame.- Body center of mass pose - [pos, quat]in simulation world frame.- Body center of mass velocity - [lin_vel, ang_vel]in simulation world frame.- State of all bodies [pos, quat, lin_vel, ang_vel] in simulation world frame. - State of all bodies - [pos, quat, lin_vel, ang_vel]in simulation world frame.- State of all bodies - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Acceleration of all bodies - [lin_acc, ang_acc]in the simulation world frame.- Center of mass pose - [pos, quat]of all bodies in their respective body's link frames.- Projection of the gravity direction on base frame. - Yaw heading of the base frame (in radians). - Root link linear velocity in base frame. - Root link angular velocity in base world frame. - Root center of mass linear velocity in base frame. - Root center of mass angular velocity in base world frame. - Root link position in simulation world frame. - Root link orientation (w, x, y, z) in simulation world frame. - Root linear velocity in simulation world frame. - Root link angular velocity in simulation world frame. - Root center of mass position in simulation world frame. - Root center of mass orientation (w, x, y, z) in simulation world frame. - Root center of mass linear velocity in simulation world frame. - Root center of mass angular velocity in simulation world frame. - Positions of all bodies in simulation world frame. - Orientation (w, x, y, z) of all bodies in simulation world frame. - Linear velocity of all bodies in simulation world frame. - Angular velocity of all bodies in simulation world frame. - Positions of all bodies in simulation world frame. - Orientation (w, x, y, z) of the principle axis of inertia of all bodies in simulation world frame. - Linear velocity of all bodies in simulation world frame. - Angular velocity of all bodies in simulation world frame. - Linear acceleration of all bodies in simulation world frame. - Angular acceleration of all bodies in simulation world frame. - Center of mass position of all of the bodies in their respective link frames. - Orientation (w, x, y, z) of the principle axis of inertia of all of the bodies in their respective link frames. - Same as - root_link_pose_w.- Same as - root_link_pos_w.- Same as - root_link_quat_w.- Same as - root_com_vel_w.- Same as - root_com_lin_vel_w.- Same as - root_com_ang_vel_w.- Same as - root_com_lin_vel_b.- Same as - root_com_ang_vel_b.- Same as - body_link_pose_w.- Same as - body_link_pos_w.- Same as - body_link_quat_w.- Same as - body_com_vel_w.- Same as - body_com_lin_vel_w.- Same as - body_com_ang_vel_w.- Same as - body_com_acc_w.- Same as - body_com_lin_acc_w.- Same as - body_com_ang_acc_w.- Same as - body_com_pos_b.- Same as - body_com_quat_b.- update(dt: float)[源代码]#
- Updates the data for the rigid object. - 参数:
- dt – The time step for the update. This must be a positive value. 
 
 - default_root_state: torch.Tensor = None#
- Default root state - [pos, quat, lin_vel, ang_vel]in local environment frame. Shape is (num_instances, 13).- The position and quaternion are of the rigid body’s actor frame. Meanwhile, the linear and angular velocities are of the center of mass frame. 
 - default_mass: torch.Tensor = None#
- Default mass read from the simulation. Shape is (num_instances, 1). 
 - default_inertia: torch.Tensor = None#
- Default inertia tensor read from the simulation. Shape is (num_instances, 9). - The inertia tensor should be given with respect to the center of mass, expressed in the rigid body’s actor frame. The values are stored in the order \([I_{xx}, I_{yx}, I_{zx}, I_{xy}, I_{yy}, I_{zy}, I_{xz}, I_{yz}, I_{zz}]\). However, due to the symmetry of inertia tensors, row- and column-major orders are equivalent. - This quantity is parsed from the USD schema at the time of initialization. 
 - property root_link_pose_w: torch.Tensor#
- Root link pose - [pos, quat]in simulation world frame. Shape is (num_instances, 7).- This quantity is the pose of the actor frame of the root rigid body relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property root_link_vel_w: torch.Tensor#
- Root link velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 6).- This quantity contains the linear and angular velocities of the actor frame of the root rigid body relative to the world. 
 - property root_com_pose_w: torch.Tensor#
- Root center of mass pose - [pos, quat]in simulation world frame. Shape is (num_instances, 7).- This quantity is the pose of the center of mass frame of the root rigid body relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property root_com_vel_w: torch.Tensor#
- Root center of mass velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 6).- This quantity contains the linear and angular velocities of the root rigid body’s center of mass frame relative to the world. 
 - property root_state_w: torch.Tensor#
- Root state - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 13).- The position and orientation are of the rigid body’s actor frame. Meanwhile, the linear and angular velocities are of the rigid body’s center of mass frame. 
 - property root_link_state_w: torch.Tensor#
- Root state - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 13).- The position, quaternion, and linear/angular velocity are of the rigid body root frame relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property root_com_state_w: torch.Tensor#
- Root center of mass state - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 13).- The position, quaternion, and linear/angular velocity are of the rigid body’s center of mass frame relative to the world. Center of mass frame is the orientation principle axes of inertia. 
 - property body_link_pose_w: torch.Tensor#
- Body link pose - [pos, quat]in simulation world frame. Shape is (num_instances, 1, 7).- This quantity is the pose of the actor frame of the rigid body relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property body_link_vel_w: torch.Tensor#
- Body link velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 1, 6).- This quantity contains the linear and angular velocities of the actor frame of the root rigid body relative to the world. 
 - property body_com_pose_w: torch.Tensor#
- Body center of mass pose - [pos, quat]in simulation world frame. Shape is (num_instances, 1, 7).- This quantity is the pose of the center of mass frame of the rigid body relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property body_com_vel_w: torch.Tensor#
- Body center of mass velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 1, 6).- This quantity contains the linear and angular velocities of the root rigid body’s center of mass frame relative to the world. 
 - property body_state_w: torch.Tensor#
- State of all bodies [pos, quat, lin_vel, ang_vel] in simulation world frame. Shape is (num_instances, 1, 13). - The position and orientation are of the rigid bodies’ actor frame. Meanwhile, the linear and angular velocities are of the rigid bodies’ center of mass frame. 
 - property body_link_state_w: torch.Tensor#
- State of all bodies - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 1, 13).- The position, quaternion, and linear/angular velocity are of the body’s link frame relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property body_com_state_w: torch.Tensor#
- State of all bodies - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, num_bodies, 13).- The position, quaternion, and linear/angular velocity are of the body’s center of mass frame relative to the world. Center of mass frame is assumed to be the same orientation as the link rather than the orientation of the principle inertia. The orientation is provided in (w, x, y, z) format. 
 - property body_com_acc_w: torch.Tensor#
- Acceleration of all bodies - [lin_acc, ang_acc]in the simulation world frame. Shape is (num_instances, 1, 6).- This quantity is the acceleration of the rigid bodies’ center of mass frame relative to the world. 
 - property body_com_pose_b: torch.Tensor#
- Center of mass pose - [pos, quat]of all bodies in their respective body’s link frames. Shape is (num_instances, 1, 7).- This quantity is the pose of the center of mass frame of the rigid body relative to the body’s link frame. The orientation is provided in (w, x, y, z) format. 
 - property projected_gravity_b: torch.Tensor#
- Projection of the gravity direction on base frame. Shape is (num_instances, 3). 
 - property heading_w: torch.Tensor#
- Yaw heading of the base frame (in radians). Shape is (num_instances,). - 备注 - This quantity is computed by assuming that the forward-direction of the base frame is along x-direction, i.e. \((1, 0, 0)\). 
 - property root_link_lin_vel_b: torch.Tensor#
- Root link linear velocity in base frame. Shape is (num_instances, 3). - This quantity is the linear velocity of the actor frame of the root rigid body frame with respect to the rigid body’s actor frame. 
 - property root_link_ang_vel_b: torch.Tensor#
- Root link angular velocity in base world frame. Shape is (num_instances, 3). - This quantity is the angular velocity of the actor frame of the root rigid body frame with respect to the rigid body’s actor frame. 
 - property root_com_lin_vel_b: torch.Tensor#
- Root center of mass linear velocity in base frame. Shape is (num_instances, 3). - This quantity is the linear velocity of the root rigid body’s center of mass frame with respect to the rigid body’s actor frame. 
 - property root_com_ang_vel_b: torch.Tensor#
- Root center of mass angular velocity in base world frame. Shape is (num_instances, 3). - This quantity is the angular velocity of the root rigid body’s center of mass frame with respect to the rigid body’s actor frame. 
 - property root_link_pos_w: torch.Tensor#
- Root link position in simulation world frame. Shape is (num_instances, 3). - This quantity is the position of the actor frame of the root rigid body relative to the world. 
 - property root_link_quat_w: torch.Tensor#
- Root link orientation (w, x, y, z) in simulation world frame. Shape is (num_instances, 4). - This quantity is the orientation of the actor frame of the root rigid body. 
 - property root_link_lin_vel_w: torch.Tensor#
- Root linear velocity in simulation world frame. Shape is (num_instances, 3). - This quantity is the linear velocity of the root rigid body’s actor frame relative to the world. 
 - property root_link_ang_vel_w: torch.Tensor#
- Root link angular velocity in simulation world frame. Shape is (num_instances, 3). - This quantity is the angular velocity of the actor frame of the root rigid body relative to the world. 
 - property root_com_pos_w: torch.Tensor#
- Root center of mass position in simulation world frame. Shape is (num_instances, 3). - This quantity is the position of the actor frame of the root rigid body relative to the world. 
 - property root_com_quat_w: torch.Tensor#
- Root center of mass orientation (w, x, y, z) in simulation world frame. Shape is (num_instances, 4). - This quantity is the orientation of the actor frame of the root rigid body relative to the world. 
 - property root_com_lin_vel_w: torch.Tensor#
- Root center of mass linear velocity in simulation world frame. Shape is (num_instances, 3). - This quantity is the linear velocity of the root rigid body’s center of mass frame relative to the world. 
 - property root_com_ang_vel_w: torch.Tensor#
- Root center of mass angular velocity in simulation world frame. Shape is (num_instances, 3). - This quantity is the angular velocity of the root rigid body’s center of mass frame relative to the world. 
 - property body_link_pos_w: torch.Tensor#
- Positions of all bodies in simulation world frame. Shape is (num_instances, 1, 3). - This quantity is the position of the rigid bodies’ actor frame relative to the world. 
 - property body_link_quat_w: torch.Tensor#
- Orientation (w, x, y, z) of all bodies in simulation world frame. Shape is (num_instances, 1, 4). - This quantity is the orientation of the rigid bodies’ actor frame relative to the world. 
 - property body_link_lin_vel_w: torch.Tensor#
- Linear velocity of all bodies in simulation world frame. Shape is (num_instances, 1, 3). - This quantity is the linear velocity of the rigid bodies’ center of mass frame relative to the world. 
 - property body_link_ang_vel_w: torch.Tensor#
- Angular velocity of all bodies in simulation world frame. Shape is (num_instances, 1, 3). - This quantity is the angular velocity of the rigid bodies’ center of mass frame relative to the world. 
 - property body_com_pos_w: torch.Tensor#
- Positions of all bodies in simulation world frame. Shape is (num_instances, 1, 3). - This quantity is the position of the rigid bodies’ actor frame. 
 - property body_com_quat_w: torch.Tensor#
- Orientation (w, x, y, z) of the principle axis of inertia of all bodies in simulation world frame. - Shape is (num_instances, 1, 4). This quantity is the orientation of the rigid bodies’ actor frame. 
 - property body_com_lin_vel_w: torch.Tensor#
- Linear velocity of all bodies in simulation world frame. Shape is (num_instances, 1, 3). - This quantity is the linear velocity of the rigid bodies’ center of mass frame. 
 - property body_com_ang_vel_w: torch.Tensor#
- Angular velocity of all bodies in simulation world frame. Shape is (num_instances, 1, 3). - This quantity is the angular velocity of the rigid bodies’ center of mass frame. 
 - property body_com_lin_acc_w: torch.Tensor#
- Linear acceleration of all bodies in simulation world frame. Shape is (num_instances, 1, 3). - This quantity is the linear acceleration of the rigid bodies’ center of mass frame. 
 - property body_com_ang_acc_w: torch.Tensor#
- Angular acceleration of all bodies in simulation world frame. Shape is (num_instances, 1, 3). - This quantity is the angular acceleration of the rigid bodies’ center of mass frame. 
 - property body_com_pos_b: torch.Tensor#
- Center of mass position of all of the bodies in their respective link frames. Shape is (num_instances, 1, 3). - This quantity is the center of mass location relative to its body’slink frame. 
 - property body_com_quat_b: torch.Tensor#
- Orientation (w, x, y, z) of the principle axis of inertia of all of the bodies in their respective link frames. Shape is (num_instances, 1, 4). - This quantity is the orientation of the principles axes of inertia relative to its body’s link frame. 
 - property root_pose_w: torch.Tensor#
- Same as - root_link_pose_w.
 - property root_pos_w: torch.Tensor#
- Same as - root_link_pos_w.
 - property root_quat_w: torch.Tensor#
- Same as - root_link_quat_w.
 - property root_vel_w: torch.Tensor#
- Same as - root_com_vel_w.
 - property root_lin_vel_w: torch.Tensor#
- Same as - root_com_lin_vel_w.
 - property root_ang_vel_w: torch.Tensor#
- Same as - root_com_ang_vel_w.
 - property root_lin_vel_b: torch.Tensor#
- Same as - root_com_lin_vel_b.
 - property root_ang_vel_b: torch.Tensor#
- Same as - root_com_ang_vel_b.
 - property body_pose_w: torch.Tensor#
- Same as - body_link_pose_w.
 - property body_pos_w: torch.Tensor#
- Same as - body_link_pos_w.
 - property body_quat_w: torch.Tensor#
- Same as - body_link_quat_w.
 - property body_vel_w: torch.Tensor#
- Same as - body_com_vel_w.
 - property body_lin_vel_w: torch.Tensor#
- Same as - body_com_lin_vel_w.
 - property body_ang_vel_w: torch.Tensor#
- Same as - body_com_ang_vel_w.
 - property body_acc_w: torch.Tensor#
- Same as - body_com_acc_w.
 - property body_lin_acc_w: torch.Tensor#
- Same as - body_com_lin_acc_w.
 - property body_ang_acc_w: torch.Tensor#
- Same as - body_com_ang_acc_w.
 - property com_pos_b: torch.Tensor#
- Same as - body_com_pos_b.
 - property com_quat_b: torch.Tensor#
- Same as - body_com_quat_b.
 
- class isaaclab.assets.RigidObjectCfg[源代码]#
- 基类: - AssetBaseCfg- Configuration parameters for a rigid object. - Classes: - Initial state of the rigid body. - Attributes: - Prim path (or expression) to the asset. - Spawn configuration for the asset. - Collision group of the asset. - Whether to enable debug visualization for the asset. - Initial state of the rigid object. - class InitialStateCfg[源代码]#
- 
Initial state of the rigid body. Attributes: Linear velocity of the root in simulation world frame. Angular velocity of the root in simulation world frame. Position of the root in simulation world frame. Quaternion rotation (w, x, y, z) of the root in simulation world frame. - lin_vel: tuple[float, float, float]#
- Linear velocity of the root in simulation world frame. Defaults to (0.0, 0.0, 0.0). 
 - ang_vel: tuple[float, float, float]#
- Angular velocity of the root in simulation world frame. Defaults to (0.0, 0.0, 0.0). 
 
 - prim_path: str#
- Prim path (or expression) to the asset. - 备注 - The expression can contain the environment namespace regex - {ENV_REGEX_NS}which will be replaced with the environment namespace.- Example: - {ENV_REGEX_NS}/Robotwill be replaced with- /World/envs/env_.*/Robot.
 - spawn: SpawnerCfg | None#
- Spawn configuration for the asset. Defaults to None. - If None, then no prims are spawned by the asset class. Instead, it is assumed that the asset is already present in the scene. 
 - collision_group: Literal[0, -1]#
- Collision group of the asset. Defaults to - 0.- -1: global collision group (collides with all assets in the scene).
- 0: local collision group (collides with other assets in the same environment).
 
 - init_state: InitialStateCfg#
- Initial state of the rigid object. Defaults to identity pose with zero velocity. 
 
Rigid Object Collection#
- class isaaclab.assets.RigidObjectCollection[源代码]#
- 基类: - AssetBase- A rigid object collection class. - This class represents a collection of rigid objects in the simulation, where the state of the rigid objects can be accessed and modified using a batched - (env_ids, object_ids)API.- For each rigid body in the collection, the root prim of the asset must have the USD RigidBodyAPI applied to it. This API is used to define the simulation properties of the rigid bodies. On playing the simulation, the physics engine will automatically register the rigid bodies and create a corresponding rigid body handle. This handle can be accessed using the - root_physx_viewattribute.- Rigid objects in the collection are uniquely identified via the key of the dictionary - rigid_objectsin the- RigidObjectCollectionCfgconfiguration class. This differs from the- RigidObjectclass, where a rigid object is identified by the name of the Xform where the USD RigidBodyAPI is applied. This would not be possible for the rigid object collection since the- rigid_objectsdictionary could contain the same rigid object multiple times, leading to ambiguity.- Methods: - __init__(cfg)- Initialize the rigid object collection. - reset([env_ids, object_ids])- Resets all internal buffers of selected environments and objects. - Write external wrench to the simulation. - update(dt)- Update the internal buffers. - find_objects(name_keys[, preserve_order])- Find objects in the collection based on the name keys. - write_object_state_to_sim(object_state[, ...])- Set the object state over selected environment and object indices into the simulation. - write_object_com_state_to_sim(object_state)- Set the object center of mass state over selected environment indices into the simulation. - write_object_link_state_to_sim(object_state)- Set the object link state over selected environment indices into the simulation. - write_object_pose_to_sim(object_pose[, ...])- Set the object pose over selected environment and object indices into the simulation. - write_object_link_pose_to_sim(object_pose[, ...])- Set the object pose over selected environment and object indices into the simulation. - write_object_com_pose_to_sim(object_pose[, ...])- Set the object center of mass pose over selected environment indices into the simulation. - write_object_velocity_to_sim(object_velocity)- Set the object velocity over selected environment and object indices into the simulation. - write_object_com_velocity_to_sim(object_velocity)- Set the object center of mass velocity over selected environment and object indices into the simulation. - write_object_link_velocity_to_sim(...[, ...])- Set the object link velocity over selected environment indices into the simulation. - set_external_force_and_torque(forces, torques)- Set external force and torque to apply on the objects' bodies in their local frame. - reshape_view_to_data(data)- Reshapes and arranges the data coming from the - root_physx_viewto (num_instances, num_objects, data_dim).- reshape_data_to_view(data)- Reshapes and arranges the data to the be consistent with data from the - root_physx_view.- set_debug_vis(debug_vis)- Sets whether to visualize the asset data. - set_visibility(visible[, env_ids])- Set the visibility of the prims corresponding to the asset. - Attributes: - Configuration instance for the rigid object collection. - Data related to the asset. - Number of instances of the collection. - Number of objects in the collection. - Ordered names of objects in the rigid object collection. - Rigid body view for the rigid body collection (PhysX). - Memory device for computation. - Whether the asset has a debug visualization implemented. - Whether the asset is initialized. - __init__(cfg: RigidObjectCollectionCfg)[源代码]#
- Initialize the rigid object collection. - 参数:
- cfg – A configuration instance. 
 
 - cfg: RigidObjectCollectionCfg#
- Configuration instance for the rigid object collection. 
 - property data: RigidObjectCollectionData#
- Data related to the asset. 
 - property num_objects: int#
- Number of objects in the collection. - This corresponds to the distinct number of rigid bodies in the collection. 
 - property root_physx_view: omni.physics.tensors.impl.api.RigidBodyView#
- Rigid body view for the rigid body collection (PhysX). - 备注 - Use this view with caution. It requires handling of tensors in a specific way. 
 - reset(env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Resets all internal buffers of selected environments and objects. - 参数:
- env_ids – The indices of the object to reset. Defaults to None (all instances). 
- object_ids – The indices of the object to reset. Defaults to None (all objects). 
 
 
 - write_data_to_sim()[源代码]#
- Write external wrench to the simulation. - 备注 - We write external wrench to the simulation here since this function is called before the simulation step. This ensures that the external wrench is applied at every simulation step. 
 - update(dt: float)[源代码]#
- Update the internal buffers. - The time step - dtis used to compute numerical derivatives of quantities such as joint accelerations which are not provided by the simulator.- 参数:
- dt – The amount of time passed from last - updatecall.
 
 - find_objects(name_keys: str | Sequence[str], preserve_order: bool = False) tuple[torch.Tensor, list[str]][源代码]#
- Find objects in the collection based on the name keys. - Please check the - isaaclab.utils.string_utils.resolve_matching_names()function for more information on the name matching.- 参数:
- name_keys – A regular expression or a list of regular expressions to match the object names. 
- preserve_order – Whether to preserve the order of the name keys in the output. Defaults to False. 
 
- 返回:
- A tuple containing the object indices and names. 
 
 - write_object_state_to_sim(object_state: torch.Tensor, env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Set the object state over selected environment and object indices into the simulation. - The object state comprises of the cartesian position, quaternion orientation in (w, x, y, z), and linear and angular velocity. All the quantities are in the simulation frame. - 参数:
- object_state – Object state in simulation frame. Shape is (len(env_ids), len(object_ids), 13). 
- env_ids – Environment indices. If None, then all indices are used. 
- object_ids – Object indices. If None, then all indices are used. 
 
 
 - write_object_com_state_to_sim(object_state: torch.Tensor, env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Set the object center of mass state over selected environment indices into the simulation. - The object state comprises of the cartesian position, quaternion orientation in (w, x, y, z), and linear and angular velocity. All the quantities are in the simulation frame. - 参数:
- object_state – Object state in simulation frame. Shape is (len(env_ids), len(object_ids), 13). 
- env_ids – Environment indices. If None, then all indices are used. 
- object_ids – Object indices. If None, then all indices are used. 
 
 
 - write_object_link_state_to_sim(object_state: torch.Tensor, env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Set the object link state over selected environment indices into the simulation. - The object state comprises of the cartesian position, quaternion orientation in (w, x, y, z), and linear and angular velocity. All the quantities are in the simulation frame. - 参数:
- object_state – Object state in simulation frame. Shape is (len(env_ids), len(object_ids), 13). 
- env_ids – Environment indices. If None, then all indices are used. 
- object_ids – Object indices. If None, then all indices are used. 
 
 
 - write_object_pose_to_sim(object_pose: torch.Tensor, env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Set the object pose over selected environment and object indices into the simulation. - The object pose comprises of the cartesian position and quaternion orientation in (w, x, y, z). - 参数:
- object_pose – Object poses in simulation frame. Shape is (len(env_ids), len(object_ids), 7). 
- env_ids – Environment indices. If None, then all indices are used. 
- object_ids – Object indices. If None, then all indices are used. 
 
 
 - write_object_link_pose_to_sim(object_pose: torch.Tensor, env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Set the object pose over selected environment and object indices into the simulation. - The object pose comprises of the cartesian position and quaternion orientation in (w, x, y, z). - 参数:
- object_pose – Object poses in simulation frame. Shape is (len(env_ids), len(object_ids), 7). 
- env_ids – Environment indices. If None, then all indices are used. 
- object_ids – Object indices. If None, then all indices are used. 
 
 
 - write_object_com_pose_to_sim(object_pose: torch.Tensor, env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Set the object center of mass pose over selected environment indices into the simulation. - The object pose comprises of the cartesian position and quaternion orientation in (w, x, y, z). The orientation is the orientation of the principle axes of inertia. - 参数:
- object_pose – Object poses in simulation frame. Shape is (len(env_ids), len(object_ids), 7). 
- env_ids – Environment indices. If None, then all indices are used. 
- object_ids – Object indices. If None, then all indices are used. 
 
 
 - write_object_velocity_to_sim(object_velocity: torch.Tensor, env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Set the object velocity over selected environment and object indices into the simulation. - 参数:
- object_velocity – Object velocities in simulation frame. Shape is (len(env_ids), len(object_ids), 6). 
- env_ids – Environment indices. If None, then all indices are used. 
- object_ids – Object indices. If None, then all indices are used. 
 
 
 - write_object_com_velocity_to_sim(object_velocity: torch.Tensor, env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Set the object center of mass velocity over selected environment and object indices into the simulation. - 参数:
- object_velocity – Object velocities in simulation frame. Shape is (len(env_ids), len(object_ids), 6). 
- env_ids – Environment indices. If None, then all indices are used. 
- object_ids – Object indices. If None, then all indices are used. 
 
 
 - write_object_link_velocity_to_sim(object_velocity: torch.Tensor, env_ids: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None)[源代码]#
- Set the object link velocity over selected environment indices into the simulation. - The velocity comprises linear velocity (x, y, z) and angular velocity (x, y, z) in that order. NOTE: This sets the velocity of the object’s frame rather than the objects center of mass. - 参数:
- object_velocity – Object velocities in simulation frame. Shape is (len(env_ids), len(object_ids), 6). 
- env_ids – Environment indices. If None, then all indices are used. 
- object_ids – Object indices. If None, then all indices are used. 
 
 
 - set_external_force_and_torque(forces: torch.Tensor, torques: torch.Tensor, positions: torch.Tensor | None = None, object_ids: slice | torch.Tensor | None = None, env_ids: torch.Tensor | None = None, is_global: bool = False)[源代码]#
- Set external force and torque to apply on the objects’ bodies in their local frame. - For many applications, we want to keep the applied external force on rigid bodies constant over a period of time (for instance, during the policy control). This function allows us to store the external force and torque into buffers which are then applied to the simulation at every step. - 小心 - If the function is called with empty forces and torques, then this function disables the application of external wrench to the simulation. - # example of disabling external wrench asset.set_external_force_and_torque(forces=torch.zeros(0, 0, 3), torques=torch.zeros(0, 0, 3)) - 小心 - If the function is called consecutively with and with different values for - is_global, then the all the external wrenches will be applied in the frame specified by the last call.- # example of setting external wrench in the global frame asset.set_external_force_and_torque(forces=torch.ones(1, 1, 3), env_ids=[0], is_global=True) # example of setting external wrench in the link frame asset.set_external_force_and_torque(forces=torch.ones(1, 1, 3), env_ids=[1], is_global=False) # Both environments will have the external wrenches applied in the link frame - 备注 - This function does not apply the external wrench to the simulation. It only fills the buffers with the desired values. To apply the external wrench, call the - write_data_to_sim()function right before the simulation step.- 参数:
- forces – External forces in bodies’ local frame. Shape is (len(env_ids), len(object_ids), 3). 
- torques – External torques in bodies’ local frame. Shape is (len(env_ids), len(object_ids), 3). 
- positions – External wrench positions in bodies’ local frame. Shape is (len(env_ids), len(object_ids), 3). 
- object_ids – Object indices to apply external wrench to. Defaults to None (all objects). 
- env_ids – Environment indices to apply external wrench to. Defaults to None (all instances). 
- is_global – Whether to apply the external wrench in the global frame. Defaults to False. If set to False, the external wrench is applied in the link frame of the bodies. 
 
 
 - reshape_view_to_data(data: torch.Tensor) torch.Tensor[源代码]#
- Reshapes and arranges the data coming from the - root_physx_viewto (num_instances, num_objects, data_dim).- 参数:
- data – The data coming from the - root_physx_view. Shape is (num_instances * num_objects, data_dim).
- 返回:
- The reshaped data. Shape is (num_instances, num_objects, data_dim). 
 
 - reshape_data_to_view(data: torch.Tensor) torch.Tensor[源代码]#
- Reshapes and arranges the data to the be consistent with data from the - root_physx_view.- 参数:
- data – The data to be reshaped. Shape is (num_instances, num_objects, data_dim). 
- 返回:
- The reshaped data. Shape is (num_instances * num_objects, data_dim). 
 
 - property has_debug_vis_implementation: bool#
- Whether the asset has a debug visualization implemented. 
 - property is_initialized: bool#
- Whether the asset is initialized. - Returns True if the asset is initialized, False otherwise. 
 - set_debug_vis(debug_vis: bool) bool#
- Sets whether to visualize the asset data. - 参数:
- debug_vis – Whether to visualize the asset data. 
- 返回:
- Whether the debug visualization was successfully set. False if the asset does not support debug visualization. 
 
 - set_visibility(visible: bool, env_ids: Sequence[int] | None = None)#
- Set the visibility of the prims corresponding to the asset. - This operation affects the visibility of the prims corresponding to the asset in the USD stage. It is useful for toggling the visibility of the asset in the simulator. For instance, one can hide the asset when it is not being used to reduce the rendering overhead. - 备注 - This operation uses the PXR API to set the visibility of the prims. Thus, the operation may have an overhead if the number of prims is large. - 参数:
- visible – Whether to make the prims visible or not. 
- env_ids – The indices of the object to set visibility. Defaults to None (all instances). 
 
 
 
- class isaaclab.assets.RigidObjectCollectionData[源代码]#
- 基类: - object- Data container for a rigid object collection. - This class contains the data for a rigid object collection in the simulation. The data includes the state of all the bodies in the collection. The data is stored in the simulation world frame unless otherwise specified. The data is in the order - (num_instances, num_objects, data_size), where data_size is the size of the data.- For a rigid body, there are two frames of reference that are used: - Actor frame: The frame of reference of the rigid body prim. This typically corresponds to the Xform prim with the rigid body schema. 
- Center of mass frame: The frame of reference of the center of mass of the rigid body. 
 - Depending on the settings of the simulation, the actor frame and the center of mass frame may be the same. This needs to be taken into account when interpreting the data. - The data is lazily updated, meaning that the data is only updated when it is accessed. This is useful when the data is expensive to compute or retrieve. The data is updated when the timestamp of the buffer is older than the current simulation timestamp. The timestamp is updated whenever the data is updated. - Methods: - update(dt)- Updates the data for the rigid object collection. - Attributes: - Object names in the order parsed by the simulation view. - Default object state - [pos, quat, lin_vel, ang_vel]in local environment frame.- Default object mass read from the simulation. - Default object inertia tensor read from the simulation. - Object link pose - [pos, quat]in simulation world frame.- Object link velocity - [lin_vel, ang_vel]in simulation world frame.- Object center of mass pose - [pos, quat]in simulation world frame.- Object center of mass velocity - [lin_vel, ang_vel]in simulation world frame.- Object state - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Object center of mass state - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Object state - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Acceleration of all objects. - Object center of mass pose - [pos, quat]in their respective body's link frame.- Projection of the gravity direction on base frame. - Yaw heading of the base frame (in radians). - Object link linear velocity in base frame. - Object link angular velocity in base world frame. - Object center of mass linear velocity in base frame. - Object center of mass angular velocity in base world frame. - Object link position in simulation world frame. - Object link orientation (w, x, y, z) in simulation world frame. - Object link linear velocity in simulation world frame. - Object link angular velocity in simulation world frame. - Object center of mass position in simulation world frame. - Object center of mass orientation (w, x, y, z) in simulation world frame. - Object center of mass linear velocity in simulation world frame. - Object center of mass angular velocity in simulation world frame. - Object center of mass linear acceleration in simulation world frame. - Object center of mass angular acceleration in simulation world frame. - Center of mass of all of the bodies in their respective body's link frame. - Orientation (w,x,y,z) of the principle axis of inertia of all of the bodies in simulation world frame. - Same as - object_link_pose_w.- Same as - object_link_pos_w.- Same as - object_link_quat_w.- Same as - object_com_vel_w.- Same as - object_com_lin_vel_w.- Same as - object_com_ang_vel_w.- Same as - object_com_lin_vel_b.- Same as - object_com_ang_vel_b.- Same as - object_com_acc_w.- Same as - object_com_lin_acc_w.- Same as - object_com_ang_acc_w.- Same as - object_com_pos_b.- Same as - object_com_quat_b.- update(dt: float)[源代码]#
- Updates the data for the rigid object collection. - 参数:
- dt – The time step for the update. This must be a positive value. 
 
 - default_object_state: torch.Tensor = None#
- Default object state - [pos, quat, lin_vel, ang_vel]in local environment frame. Shape is (num_instances, num_objects, 13).- The position and quaternion are of each object’s rigid body’s actor frame. Meanwhile, the linear and angular velocities are of the center of mass frame. 
 - default_mass: torch.Tensor = None#
- Default object mass read from the simulation. Shape is (num_instances, num_objects, 1). 
 - default_inertia: torch.Tensor = None#
- Default object inertia tensor read from the simulation. Shape is (num_instances, num_objects, 9). - The inertia tensor should be given with respect to the center of mass, expressed in the rigid body’s actor frame. The values are stored in the order \([I_{xx}, I_{yx}, I_{zx}, I_{xy}, I_{yy}, I_{zy}, I_{xz}, I_{yz}, I_{zz}]\). However, due to the symmetry of inertia tensors, row- and column-major orders are equivalent. - This quantity is parsed from the USD schema at the time of initialization. 
 - property object_link_pose_w#
- Object link pose - [pos, quat]in simulation world frame. Shape is (num_instances, num_objects, 7).- The position and orientation are of the rigid body’s actor frame. 
 - property object_link_vel_w#
- Object link velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, num_objects, 6).- The linear and angular velocities are of the rigid body’s actor frame. 
 - property object_com_pose_w#
- Object center of mass pose - [pos, quat]in simulation world frame. Shape is (num_instances, num_objects, 7).- The position and orientation are of the rigid body’s center of mass frame. 
 - property object_com_vel_w#
- Object center of mass velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, num_objects, 6).- The linear and angular velocities are of the rigid body’s center of mass frame. 
 - property object_state_w#
- Object state - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, num_objects, 13).- The position and orientation are of the rigid body’s actor frame. Meanwhile, the linear and angular velocities are of the rigid body’s center of mass frame. 
 - property object_link_state_w#
- Object center of mass state - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, num_objects, 13).- The position, quaternion, and linear/angular velocity are of the rigid body root frame relative to the world. 
 - property object_com_state_w#
- Object state - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, num_objects, 13).- The position, quaternion, and linear/angular velocity are of the rigid body’s center of mass frame relative to the world. Center of mass frame has the orientation along the principle axes of inertia. 
 - property object_com_acc_w#
- Acceleration of all objects. Shape is (num_instances, num_objects, 6). - This quantity is the acceleration of the rigid bodies’ center of mass frame. 
 - property object_com_pose_b#
- Object center of mass pose - [pos, quat]in their respective body’s link frame. Shape is (num_instances, num_objects, 7).- The position and orientation are of the rigid body’s center of mass frame. The orientation is provided in (w, x, y, z) format. 
 - property projected_gravity_b#
- Projection of the gravity direction on base frame. Shape is (num_instances, num_objects, 3). 
 - property heading_w#
- Yaw heading of the base frame (in radians). Shape is (num_instances, num_objects,). - 备注 - This quantity is computed by assuming that the forward-direction of the base frame is along x-direction, i.e. \((1, 0, 0)\). 
 - property object_link_lin_vel_b: torch.Tensor#
- Object link linear velocity in base frame. Shape is (num_instances, num_objects, 3). - This quantity is the linear velocity of the actor frame of the root rigid body frame with respect to the rigid body’s actor frame. 
 - property object_link_ang_vel_b: torch.Tensor#
- Object link angular velocity in base world frame. Shape is (num_instances, num_objects, 3). - This quantity is the angular velocity of the actor frame of the root rigid body frame with respect to the rigid body’s actor frame. 
 - property object_com_lin_vel_b: torch.Tensor#
- Object center of mass linear velocity in base frame. Shape is (num_instances, num_objects, 3). - This quantity is the linear velocity of the center of mass frame of the root rigid body frame with respect to the rigid body’s actor frame. 
 - property object_com_ang_vel_b: torch.Tensor#
- Object center of mass angular velocity in base world frame. Shape is (num_instances, num_objects, 3). - This quantity is the angular velocity of the center of mass frame of the root rigid body frame with respect to the rigid body’s actor frame. 
 - property object_link_pos_w: torch.Tensor#
- Object link position in simulation world frame. Shape is (num_instances, num_objects, 3). - This quantity is the position of the actor frame of the rigid bodies. 
 - property object_link_quat_w: torch.Tensor#
- Object link orientation (w, x, y, z) in simulation world frame. Shape is (num_instances, num_objects, 4). - This quantity is the orientation of the actor frame of the rigid bodies. 
 - property object_link_lin_vel_w: torch.Tensor#
- Object link linear velocity in simulation world frame. Shape is (num_instances, num_objects, 3). - This quantity is the linear velocity of the rigid bodies’ actor frame. 
 - property object_link_ang_vel_w: torch.Tensor#
- Object link angular velocity in simulation world frame. Shape is (num_instances, num_objects, 3). - This quantity is the angular velocity of the rigid bodies’ actor frame. 
 - property object_com_pos_w: torch.Tensor#
- Object center of mass position in simulation world frame. Shape is (num_instances, num_objects, 3). - This quantity is the position of the center of mass frame of the rigid bodies. 
 - property object_com_quat_w: torch.Tensor#
- Object center of mass orientation (w, x, y, z) in simulation world frame. Shape is (num_instances, num_objects, 4). - This quantity is the orientation of the center of mass frame of the rigid bodies. 
 - property object_com_lin_vel_w: torch.Tensor#
- Object center of mass linear velocity in simulation world frame. Shape is (num_instances, num_objects, 3). - This quantity is the linear velocity of the rigid bodies’ center of mass frame. 
 - property object_com_ang_vel_w: torch.Tensor#
- Object center of mass angular velocity in simulation world frame. Shape is (num_instances, num_objects, 3). - This quantity is the angular velocity of the rigid bodies’ center of mass frame. 
 - property object_com_lin_acc_w: torch.Tensor#
- Object center of mass linear acceleration in simulation world frame. Shape is (num_instances, num_objects, 3). - This quantity is the linear acceleration of the rigid bodies’ center of mass frame. 
 - property object_com_ang_acc_w: torch.Tensor#
- Object center of mass angular acceleration in simulation world frame. Shape is (num_instances, num_objects, 3). - This quantity is the angular acceleration of the rigid bodies’ center of mass frame. 
 - property object_com_pos_b: torch.Tensor#
- Center of mass of all of the bodies in their respective body’s link frame. Shape is (num_instances, num_objects, 3). - This quantity is the center of mass location relative to its body link frame. 
 - property object_com_quat_b: torch.Tensor#
- Orientation (w,x,y,z) of the principle axis of inertia of all of the bodies in simulation world frame. Shape is (num_instances, num_objects, 4). - This quantity is the orientation of the principles axes of inertia relative to its body link frame. The orientation is provided in (w, x, y, z) format. 
 - property object_pose_w: torch.Tensor#
- Same as - object_link_pose_w.
 - property object_pos_w: torch.Tensor#
- Same as - object_link_pos_w.
 - property object_quat_w: torch.Tensor#
- Same as - object_link_quat_w.
 - property object_vel_w: torch.Tensor#
- Same as - object_com_vel_w.
 - property object_lin_vel_w: torch.Tensor#
- Same as - object_com_lin_vel_w.
 - property object_ang_vel_w: torch.Tensor#
- Same as - object_com_ang_vel_w.
 - property object_lin_vel_b: torch.Tensor#
- Same as - object_com_lin_vel_b.
 - property object_ang_vel_b: torch.Tensor#
- Same as - object_com_ang_vel_b.
 - property object_acc_w: torch.Tensor#
- Same as - object_com_acc_w.
 - property object_lin_acc_w: torch.Tensor#
- Same as - object_com_lin_acc_w.
 - property object_ang_acc_w: torch.Tensor#
- Same as - object_com_ang_acc_w.
 - property com_pos_b: torch.Tensor#
- Same as - object_com_pos_b.
 - property com_quat_b: torch.Tensor#
- Same as - object_com_quat_b.
 
- class isaaclab.assets.RigidObjectCollectionCfg[源代码]#
- 基类: - object- Configuration parameters for a rigid object collection. - Attributes: - Dictionary of rigid object configurations to spawn. - rigid_objects: dict[str, isaaclab.assets.rigid_object.rigid_object_cfg.RigidObjectCfg]#
- Dictionary of rigid object configurations to spawn. - The keys are the names for the objects, which are used as unique identifiers throughout the code. 
 
Articulation#
- class isaaclab.assets.Articulation[源代码]#
- 基类: - AssetBase- An articulation asset class. - An articulation is a collection of rigid bodies connected by joints. The joints can be either fixed or actuated. The joints can be of different types, such as revolute, prismatic, D-6, etc. However, the articulation class has currently been tested with revolute and prismatic joints. The class supports both floating-base and fixed-base articulations. The type of articulation is determined based on the root joint of the articulation. If the root joint is fixed, then the articulation is considered a fixed-base system. Otherwise, it is considered a floating-base system. This can be checked using the - Articulation.is_fixed_baseattribute.- For an asset to be considered an articulation, the root prim of the asset must have the USD ArticulationRootAPI. This API is used to define the sub-tree of the articulation using the reduced coordinate formulation. On playing the simulation, the physics engine parses the articulation root prim and creates the corresponding articulation in the physics engine. The articulation root prim can be specified using the - AssetBaseCfg.prim_pathattribute.- The articulation class also provides the functionality to augment the simulation of an articulated system with custom actuator models. These models can either be explicit or implicit, as detailed in the - isaaclab.actuatorsmodule. The actuator models are specified using the- ArticulationCfg.actuatorsattribute. These are then parsed and used to initialize the corresponding actuator models, when the simulation is played.- During the simulation step, the articulation class first applies the actuator models to compute the joint commands based on the user-specified targets. These joint commands are then applied into the simulation. The joint commands can be either position, velocity, or effort commands. As an example, the following snippet shows how this can be used for position commands: - # an example instance of the articulation class my_articulation = Articulation(cfg) # set joint position targets my_articulation.set_joint_position_target(position) # propagate the actuator models and apply the computed commands into the simulation my_articulation.write_data_to_sim() # step the simulation using the simulation context sim_context.step() # update the articulation state, where dt is the simulation time step my_articulation.update(dt) - Attributes: - Configuration instance for the articulations. - Dictionary of actuator instances for the articulation. - Data related to the asset. - Number of instances of the asset. - Whether the articulation is a fixed-base or floating-base system. - Number of joints in articulation. - Number of fixed tendons in articulation. - Number of spatial tendons in articulation. - Number of bodies in articulation. - Ordered names of joints in articulation. - Ordered names of fixed tendons in articulation. - Ordered names of spatial tendons in articulation. - Ordered names of bodies in articulation. - Articulation view for the asset (PhysX). - Memory device for computation. - Whether the asset has a debug visualization implemented. - Whether the asset is initialized. - Methods: - __init__(cfg)- Initialize the articulation. - reset([env_ids])- Resets all internal buffers of selected environments. - Write external wrenches and joint commands to the simulation. - update(dt)- Update the internal buffers. - find_bodies(name_keys[, preserve_order])- Find bodies in the articulation based on the name keys. - find_joints(name_keys[, joint_subset, ...])- Find joints in the articulation based on the name keys. - find_fixed_tendons(name_keys[, ...])- Find fixed tendons in the articulation based on the name keys. - find_spatial_tendons(name_keys[, ...])- Find spatial tendons in the articulation based on the name keys. - write_root_state_to_sim(root_state[, env_ids])- Set the root state over selected environment indices into the simulation. - write_root_com_state_to_sim(root_state[, ...])- Set the root center of mass state over selected environment indices into the simulation. - write_root_link_state_to_sim(root_state[, ...])- Set the root link state over selected environment indices into the simulation. - write_root_pose_to_sim(root_pose[, env_ids])- Set the root pose over selected environment indices into the simulation. - write_root_link_pose_to_sim(root_pose[, env_ids])- Set the root link pose over selected environment indices into the simulation. - write_root_com_pose_to_sim(root_pose[, env_ids])- Set the root center of mass pose over selected environment indices into the simulation. - write_root_velocity_to_sim(root_velocity[, ...])- Set the root center of mass velocity over selected environment indices into the simulation. - write_root_com_velocity_to_sim(root_velocity)- Set the root center of mass velocity over selected environment indices into the simulation. - write_root_link_velocity_to_sim(root_velocity)- Set the root link velocity over selected environment indices into the simulation. - write_joint_state_to_sim(position, velocity)- Write joint positions and velocities to the simulation. - write_joint_position_to_sim(position[, ...])- Write joint positions to the simulation. - write_joint_velocity_to_sim(velocity[, ...])- Write joint velocities to the simulation. - write_joint_stiffness_to_sim(stiffness[, ...])- Write joint stiffness into the simulation. - write_joint_damping_to_sim(damping[, ...])- Write joint damping into the simulation. - write_joint_position_limit_to_sim(limits[, ...])- Write joint position limits into the simulation. - write_joint_velocity_limit_to_sim(limits[, ...])- Write joint max velocity to the simulation. - write_joint_effort_limit_to_sim(limits[, ...])- Write joint effort limits into the simulation. - write_joint_armature_to_sim(armature[, ...])- Write joint armature into the simulation. - Write joint static friction coefficients into the simulation. - set_external_force_and_torque(forces, torques)- Set external force and torque to apply on the asset's bodies in their local frame. - set_joint_position_target(target[, ...])- Set joint position targets into internal buffers. - set_joint_velocity_target(target[, ...])- Set joint velocity targets into internal buffers. - set_joint_effort_target(target[, joint_ids, ...])- Set joint efforts into internal buffers. - set_fixed_tendon_stiffness(stiffness[, ...])- Set fixed tendon stiffness into internal buffers. - set_fixed_tendon_damping(damping[, ...])- Set fixed tendon damping into internal buffers. - set_fixed_tendon_limit_stiffness(limit_stiffness)- Set fixed tendon limit stiffness efforts into internal buffers. - set_fixed_tendon_position_limit(limit[, ...])- Set fixed tendon limit efforts into internal buffers. - set_fixed_tendon_rest_length(rest_length[, ...])- Set fixed tendon rest length efforts into internal buffers. - set_fixed_tendon_offset(offset[, ...])- Set fixed tendon offset efforts into internal buffers. - Write fixed tendon properties into the simulation. - set_spatial_tendon_stiffness(stiffness[, ...])- Set spatial tendon stiffness into internal buffers. - set_spatial_tendon_damping(damping[, ...])- Set spatial tendon damping into internal buffers. - set_spatial_tendon_limit_stiffness(...[, ...])- Set spatial tendon limit stiffness into internal buffers. - set_spatial_tendon_offset(offset[, ...])- Set spatial tendon offset efforts into internal buffers. - Write spatial tendon properties into the simulation. - write_joint_friction_to_sim(joint_friction)- Write joint friction coefficients into the simulation. - set_debug_vis(debug_vis)- Sets whether to visualize the asset data. - set_visibility(visible[, env_ids])- Set the visibility of the prims corresponding to the asset. - write_joint_limits_to_sim(limits[, ...])- Write joint limits into the simulation. - set_fixed_tendon_limit(limit[, ...])- Set fixed tendon position limits into internal buffers. - cfg: ArticulationCfg#
- Configuration instance for the articulations. 
 - actuators: dict[str, ActuatorBase]#
- Dictionary of actuator instances for the articulation. - The keys are the actuator names and the values are the actuator instances. The actuator instances are initialized based on the actuator configurations specified in the - ArticulationCfg.actuatorsattribute. They are used to compute the joint commands during the- write_data_to_sim()function.
 - __init__(cfg: ArticulationCfg)[源代码]#
- Initialize the articulation. - 参数:
- cfg – A configuration instance. 
 
 - property data: ArticulationData#
- Data related to the asset. 
 - property num_instances: int#
- Number of instances of the asset. - This is equal to the number of asset instances per environment multiplied by the number of environments. 
 - property root_physx_view: omni.physics.tensors.impl.api.ArticulationView#
- Articulation view for the asset (PhysX). - 备注 - Use this view with caution. It requires handling of tensors in a specific way. 
 - reset(env_ids: Sequence[int] | None = None)[源代码]#
- Resets all internal buffers of selected environments. - 参数:
- env_ids – The indices of the object to reset. Defaults to None (all instances). 
 
 - write_data_to_sim()[源代码]#
- Write external wrenches and joint commands to the simulation. - If any explicit actuators are present, then the actuator models are used to compute the joint commands. Otherwise, the joint commands are directly set into the simulation. - 备注 - We write external wrench to the simulation here since this function is called before the simulation step. This ensures that the external wrench is applied at every simulation step. 
 - update(dt: float)[源代码]#
- Update the internal buffers. - The time step - dtis used to compute numerical derivatives of quantities such as joint accelerations which are not provided by the simulator.- 参数:
- dt – The amount of time passed from last - updatecall.
 
 - find_bodies(name_keys: str | Sequence[str], preserve_order: bool = False) tuple[list[int], list[str]][源代码]#
- Find bodies in the articulation based on the name keys. - Please check the - isaaclab.utils.string_utils.resolve_matching_names()function for more information on the name matching.- 参数:
- name_keys – A regular expression or a list of regular expressions to match the body names. 
- preserve_order – Whether to preserve the order of the name keys in the output. Defaults to False. 
 
- 返回:
- A tuple of lists containing the body indices and names. 
 
 - find_joints(name_keys: str | Sequence[str], joint_subset: list[str] | None = None, preserve_order: bool = False) tuple[list[int], list[str]][源代码]#
- Find joints in the articulation based on the name keys. - Please see the - isaaclab.utils.string.resolve_matching_names()function for more information on the name matching.- 参数:
- name_keys – A regular expression or a list of regular expressions to match the joint names. 
- joint_subset – A subset of joints to search for. Defaults to None, which means all joints in the articulation are searched. 
- preserve_order – Whether to preserve the order of the name keys in the output. Defaults to False. 
 
- 返回:
- A tuple of lists containing the joint indices and names. 
 
 - find_fixed_tendons(name_keys: str | Sequence[str], tendon_subsets: list[str] | None = None, preserve_order: bool = False) tuple[list[int], list[str]][源代码]#
- Find fixed tendons in the articulation based on the name keys. - Please see the - isaaclab.utils.string.resolve_matching_names()function for more information on the name matching.- 参数:
- name_keys – A regular expression or a list of regular expressions to match the joint names with fixed tendons. 
- tendon_subsets – A subset of joints with fixed tendons to search for. Defaults to None, which means all joints in the articulation are searched. 
- preserve_order – Whether to preserve the order of the name keys in the output. Defaults to False. 
 
- 返回:
- A tuple of lists containing the tendon indices and names. 
 
 - find_spatial_tendons(name_keys: str | Sequence[str], tendon_subsets: list[str] | None = None, preserve_order: bool = False) tuple[list[int], list[str]][源代码]#
- Find spatial tendons in the articulation based on the name keys. - Please see the - isaaclab.utils.string.resolve_matching_names()function for more information on the name matching.- 参数:
- name_keys – A regular expression or a list of regular expressions to match the tendon names. 
- tendon_subsets – A subset of tendons to search for. Defaults to None, which means all tendons in the articulation are searched. 
- preserve_order – Whether to preserve the order of the name keys in the output. Defaults to False. 
 
- 返回:
- A tuple of lists containing the tendon indices and names. 
 
 - write_root_state_to_sim(root_state: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root state over selected environment indices into the simulation. - The root state comprises of the cartesian position, quaternion orientation in (w, x, y, z), and linear and angular velocity. All the quantities are in the simulation frame. - 参数:
- root_state – Root state in simulation frame. Shape is (len(env_ids), 13). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_com_state_to_sim(root_state: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root center of mass state over selected environment indices into the simulation. - The root state comprises of the cartesian position, quaternion orientation in (w, x, y, z), and linear and angular velocity. All the quantities are in the simulation frame. - 参数:
- root_state – Root state in simulation frame. Shape is (len(env_ids), 13). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_link_state_to_sim(root_state: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root link state over selected environment indices into the simulation. - The root state comprises of the cartesian position, quaternion orientation in (w, x, y, z), and linear and angular velocity. All the quantities are in the simulation frame. - 参数:
- root_state – Root state in simulation frame. Shape is (len(env_ids), 13). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_pose_to_sim(root_pose: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root pose over selected environment indices into the simulation. - The root pose comprises of the cartesian position and quaternion orientation in (w, x, y, z). - 参数:
- root_pose – Root poses in simulation frame. Shape is (len(env_ids), 7). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_link_pose_to_sim(root_pose: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root link pose over selected environment indices into the simulation. - The root pose comprises of the cartesian position and quaternion orientation in (w, x, y, z). - 参数:
- root_pose – Root poses in simulation frame. Shape is (len(env_ids), 7). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_com_pose_to_sim(root_pose: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root center of mass pose over selected environment indices into the simulation. - The root pose comprises of the cartesian position and quaternion orientation in (w, x, y, z). The orientation is the orientation of the principle axes of inertia. - 参数:
- root_pose – Root center of mass poses in simulation frame. Shape is (len(env_ids), 7). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_velocity_to_sim(root_velocity: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root center of mass velocity over selected environment indices into the simulation. - The velocity comprises linear velocity (x, y, z) and angular velocity (x, y, z) in that order. NOTE: This sets the velocity of the root’s center of mass rather than the roots frame. - 参数:
- root_velocity – Root center of mass velocities in simulation world frame. Shape is (len(env_ids), 6). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_com_velocity_to_sim(root_velocity: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root center of mass velocity over selected environment indices into the simulation. - The velocity comprises linear velocity (x, y, z) and angular velocity (x, y, z) in that order. NOTE: This sets the velocity of the root’s center of mass rather than the roots frame. - 参数:
- root_velocity – Root center of mass velocities in simulation world frame. Shape is (len(env_ids), 6). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_root_link_velocity_to_sim(root_velocity: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the root link velocity over selected environment indices into the simulation. - The velocity comprises linear velocity (x, y, z) and angular velocity (x, y, z) in that order. NOTE: This sets the velocity of the root’s frame rather than the roots center of mass. - 参数:
- root_velocity – Root frame velocities in simulation world frame. Shape is (len(env_ids), 6). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_joint_state_to_sim(position: torch.Tensor, velocity: torch.Tensor, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | slice | None = None)[源代码]#
- Write joint positions and velocities to the simulation. - 参数:
- position – Joint positions. Shape is (len(env_ids), len(joint_ids)). 
- velocity – Joint velocities. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the targets for. Defaults to None (all joints). 
- env_ids – The environment indices to set the targets for. Defaults to None (all environments). 
 
 
 - write_joint_position_to_sim(position: torch.Tensor, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | slice | None = None)[源代码]#
- Write joint positions to the simulation. - 参数:
- position – Joint positions. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the targets for. Defaults to None (all joints). 
- env_ids – The environment indices to set the targets for. Defaults to None (all environments). 
 
 
 - write_joint_velocity_to_sim(velocity: torch.Tensor, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | slice | None = None)[源代码]#
- Write joint velocities to the simulation. - 参数:
- velocity – Joint velocities. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the targets for. Defaults to None (all joints). 
- env_ids – The environment indices to set the targets for. Defaults to None (all environments). 
 
 
 - write_joint_stiffness_to_sim(stiffness: torch.Tensor | float, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Write joint stiffness into the simulation. - 参数:
- stiffness – Joint stiffness. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the stiffness for. Defaults to None (all joints). 
- env_ids – The environment indices to set the stiffness for. Defaults to None (all environments). 
 
 
 - write_joint_damping_to_sim(damping: torch.Tensor | float, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Write joint damping into the simulation. - 参数:
- damping – Joint damping. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the damping for. Defaults to None (all joints). 
- env_ids – The environment indices to set the damping for. Defaults to None (all environments). 
 
 
 - write_joint_position_limit_to_sim(limits: torch.Tensor | float, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None, warn_limit_violation: bool = True)[源代码]#
- Write joint position limits into the simulation. - 参数:
- limits – Joint limits. Shape is (len(env_ids), len(joint_ids), 2). 
- joint_ids – The joint indices to set the limits for. Defaults to None (all joints). 
- env_ids – The environment indices to set the limits for. Defaults to None (all environments). 
- warn_limit_violation – Whether to use warning or info level logging when default joint positions exceed the new limits. Defaults to True. 
 
 
 - write_joint_velocity_limit_to_sim(limits: torch.Tensor | float, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Write joint max velocity to the simulation. - The velocity limit is used to constrain the joint velocities in the physics engine. The joint will only be able to reach this velocity if the joint’s effort limit is sufficiently large. If the joint is moving faster than this velocity, the physics engine will actually try to brake the joint to reach this velocity. - 参数:
- limits – Joint max velocity. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the max velocity for. Defaults to None (all joints). 
- env_ids – The environment indices to set the max velocity for. Defaults to None (all environments). 
 
 
 - write_joint_effort_limit_to_sim(limits: torch.Tensor | float, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Write joint effort limits into the simulation. - The effort limit is used to constrain the computed joint efforts in the physics engine. If the computed effort exceeds this limit, the physics engine will clip the effort to this value. - 参数:
- limits – Joint torque limits. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the joint torque limits for. Defaults to None (all joints). 
- env_ids – The environment indices to set the joint torque limits for. Defaults to None (all environments). 
 
 
 - write_joint_armature_to_sim(armature: torch.Tensor | float, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Write joint armature into the simulation. - The armature is directly added to the corresponding joint-space inertia. It helps improve the simulation stability by reducing the joint velocities. - 参数:
- armature – Joint armature. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the joint torque limits for. Defaults to None (all joints). 
- env_ids – The environment indices to set the joint torque limits for. Defaults to None (all environments). 
 
 
 - write_joint_friction_coefficient_to_sim(joint_friction_coeff: torch.Tensor | float, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Write joint static friction coefficients into the simulation. - The joint static friction is a unitless quantity. It relates the magnitude of the spatial force transmitted from the parent body to the child body to the maximal static friction force that may be applied by the solver to resist the joint motion. - Mathematically, this means that: \(F_{resist} \leq \mu F_{spatial}\), where \(F_{resist}\) is the resisting force applied by the solver and \(F_{spatial}\) is the spatial force transmitted from the parent body to the child body. The simulated static friction effect is therefore similar to static and Coulomb static friction. - 参数:
- joint_friction_coeff – Joint static friction coefficient. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the joint torque limits for. Defaults to None (all joints). 
- env_ids – The environment indices to set the joint torque limits for. Defaults to None (all environments). 
 
 
 - set_external_force_and_torque(forces: torch.Tensor, torques: torch.Tensor, positions: torch.Tensor | None = None, body_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None, is_global: bool = False)[源代码]#
- Set external force and torque to apply on the asset’s bodies in their local frame. - For many applications, we want to keep the applied external force on rigid bodies constant over a period of time (for instance, during the policy control). This function allows us to store the external force and torque into buffers which are then applied to the simulation at every step. Optionally, set the position to apply the external wrench at (in the local link frame of the bodies). - 小心 - If the function is called with empty forces and torques, then this function disables the application of external wrench to the simulation. - # example of disabling external wrench asset.set_external_force_and_torque(forces=torch.zeros(0, 3), torques=torch.zeros(0, 3)) - 小心 - If the function is called consecutively with and with different values for - is_global, then the all the external wrenches will be applied in the frame specified by the last call.- # example of setting external wrench in the global frame asset.set_external_force_and_torque(forces=torch.ones(1, 1, 3), env_ids=[0], is_global=True) # example of setting external wrench in the link frame asset.set_external_force_and_torque(forces=torch.ones(1, 1, 3), env_ids=[1], is_global=False) # Both environments will have the external wrenches applied in the link frame - 备注 - This function does not apply the external wrench to the simulation. It only fills the buffers with the desired values. To apply the external wrench, call the - write_data_to_sim()function right before the simulation step.- 参数:
- forces – External forces in bodies’ local frame. Shape is (len(env_ids), len(body_ids), 3). 
- torques – External torques in bodies’ local frame. Shape is (len(env_ids), len(body_ids), 3). 
- positions – Positions to apply external wrench. Shape is (len(env_ids), len(body_ids), 3). Defaults to None. 
- body_ids – Body indices to apply external wrench to. Defaults to None (all bodies). 
- env_ids – Environment indices to apply external wrench to. Defaults to None (all instances). 
- is_global – Whether to apply the external wrench in the global frame. Defaults to False. If set to False, the external wrench is applied in the link frame of the articulations’ bodies. 
 
 
 - set_joint_position_target(target: torch.Tensor, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set joint position targets into internal buffers. - This function does not apply the joint targets to the simulation. It only fills the buffers with the desired values. To apply the joint targets, call the - write_data_to_sim()function.- 参数:
- target – Joint position targets. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the targets for. Defaults to None (all joints). 
- env_ids – The environment indices to set the targets for. Defaults to None (all environments). 
 
 
 - set_joint_velocity_target(target: torch.Tensor, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set joint velocity targets into internal buffers. - This function does not apply the joint targets to the simulation. It only fills the buffers with the desired values. To apply the joint targets, call the - write_data_to_sim()function.- 参数:
- target – Joint velocity targets. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the targets for. Defaults to None (all joints). 
- env_ids – The environment indices to set the targets for. Defaults to None (all environments). 
 
 
 - set_joint_effort_target(target: torch.Tensor, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set joint efforts into internal buffers. - This function does not apply the joint targets to the simulation. It only fills the buffers with the desired values. To apply the joint targets, call the - write_data_to_sim()function.- 参数:
- target – Joint effort targets. Shape is (len(env_ids), len(joint_ids)). 
- joint_ids – The joint indices to set the targets for. Defaults to None (all joints). 
- env_ids – The environment indices to set the targets for. Defaults to None (all environments). 
 
 
 - set_fixed_tendon_stiffness(stiffness: torch.Tensor, fixed_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set fixed tendon stiffness into internal buffers. - This function does not apply the tendon stiffness to the simulation. It only fills the buffers with the desired values. To apply the tendon stiffness, call the - write_fixed_tendon_properties_to_sim()function.- 参数:
- stiffness – Fixed tendon stiffness. Shape is (len(env_ids), len(fixed_tendon_ids)). 
- fixed_tendon_ids – The tendon indices to set the stiffness for. Defaults to None (all fixed tendons). 
- env_ids – The environment indices to set the stiffness for. Defaults to None (all environments). 
 
 
 - set_fixed_tendon_damping(damping: torch.Tensor, fixed_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set fixed tendon damping into internal buffers. - This function does not apply the tendon damping to the simulation. It only fills the buffers with the desired values. To apply the tendon damping, call the - write_fixed_tendon_properties_to_sim()function.- 参数:
- damping – Fixed tendon damping. Shape is (len(env_ids), len(fixed_tendon_ids)). 
- fixed_tendon_ids – The tendon indices to set the damping for. Defaults to None (all fixed tendons). 
- env_ids – The environment indices to set the damping for. Defaults to None (all environments). 
 
 
 - set_fixed_tendon_limit_stiffness(limit_stiffness: torch.Tensor, fixed_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set fixed tendon limit stiffness efforts into internal buffers. - This function does not apply the tendon limit stiffness to the simulation. It only fills the buffers with the desired values. To apply the tendon limit stiffness, call the - write_fixed_tendon_properties_to_sim()function.- 参数:
- limit_stiffness – Fixed tendon limit stiffness. Shape is (len(env_ids), len(fixed_tendon_ids)). 
- fixed_tendon_ids – The tendon indices to set the limit stiffness for. Defaults to None (all fixed tendons). 
- env_ids – The environment indices to set the limit stiffness for. Defaults to None (all environments). 
 
 
 - set_fixed_tendon_position_limit(limit: torch.Tensor, fixed_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set fixed tendon limit efforts into internal buffers. - This function does not apply the tendon limit to the simulation. It only fills the buffers with the desired values. To apply the tendon limit, call the - write_fixed_tendon_properties_to_sim()function.- Args:
- limit: Fixed tendon limit. Shape is (len(env_ids), len(fixed_tendon_ids)). fixed_tendon_ids: The tendon indices to set the limit for. Defaults to None (all fixed tendons). env_ids: The environment indices to set the limit for. Defaults to None (all environments). 
 
 - set_fixed_tendon_rest_length(rest_length: torch.Tensor, fixed_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set fixed tendon rest length efforts into internal buffers. - This function does not apply the tendon rest length to the simulation. It only fills the buffers with the desired values. To apply the tendon rest length, call the - write_fixed_tendon_properties_to_sim()function.- 参数:
- rest_length – Fixed tendon rest length. Shape is (len(env_ids), len(fixed_tendon_ids)). 
- fixed_tendon_ids – The tendon indices to set the rest length for. Defaults to None (all fixed tendons). 
- env_ids – The environment indices to set the rest length for. Defaults to None (all environments). 
 
 
 - set_fixed_tendon_offset(offset: torch.Tensor, fixed_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set fixed tendon offset efforts into internal buffers. - This function does not apply the tendon offset to the simulation. It only fills the buffers with the desired values. To apply the tendon offset, call the - write_fixed_tendon_properties_to_sim()function.- 参数:
- offset – Fixed tendon offset. Shape is (len(env_ids), len(fixed_tendon_ids)). 
- fixed_tendon_ids – The tendon indices to set the offset for. Defaults to None (all fixed tendons). 
- env_ids – The environment indices to set the offset for. Defaults to None (all environments). 
 
 
 - write_fixed_tendon_properties_to_sim(fixed_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Write fixed tendon properties into the simulation. - 参数:
- fixed_tendon_ids – The fixed tendon indices to set the limits for. Defaults to None (all fixed tendons). 
- env_ids – The environment indices to set the limits for. Defaults to None (all environments). 
 
 
 - set_spatial_tendon_stiffness(stiffness: torch.Tensor, spatial_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set spatial tendon stiffness into internal buffers. - This function does not apply the tendon stiffness to the simulation. It only fills the buffers with the desired values. To apply the tendon stiffness, call the - write_spatial_tendon_properties_to_sim()function.- 参数:
- stiffness – Spatial tendon stiffness. Shape is (len(env_ids), len(spatial_tendon_ids)). 
- spatial_tendon_ids – The tendon indices to set the stiffness for. Defaults to None (all spatial tendons). 
- env_ids – The environment indices to set the stiffness for. Defaults to None (all environments). 
 
 
 - set_spatial_tendon_damping(damping: torch.Tensor, spatial_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set spatial tendon damping into internal buffers. - This function does not apply the tendon damping to the simulation. It only fills the buffers with the desired values. To apply the tendon damping, call the - write_spatial_tendon_properties_to_sim()function.- 参数:
- damping – Spatial tendon damping. Shape is (len(env_ids), len(spatial_tendon_ids)). 
- spatial_tendon_ids – The tendon indices to set the damping for. Defaults to None (all spatial tendons). 
- env_ids – The environment indices to set the damping for. Defaults to None (all environments). 
 
 
 - set_spatial_tendon_limit_stiffness(limit_stiffness: torch.Tensor, spatial_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set spatial tendon limit stiffness into internal buffers. - This function does not apply the tendon limit stiffness to the simulation. It only fills the buffers with the desired values. To apply the tendon limit stiffness, call the - write_spatial_tendon_properties_to_sim()function.- 参数:
- limit_stiffness – Spatial tendon limit stiffness. Shape is (len(env_ids), len(spatial_tendon_ids)). 
- spatial_tendon_ids – The tendon indices to set the limit stiffness for. Defaults to None (all spatial tendons). 
- env_ids – The environment indices to set the limit stiffness for. Defaults to None (all environments). 
 
 
 - set_spatial_tendon_offset(offset: torch.Tensor, spatial_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Set spatial tendon offset efforts into internal buffers. - This function does not apply the tendon offset to the simulation. It only fills the buffers with the desired values. To apply the tendon offset, call the - write_spatial_tendon_properties_to_sim()function.- 参数:
- offset – Spatial tendon offset. Shape is (len(env_ids), len(spatial_tendon_ids)). 
- spatial_tendon_ids – The tendon indices to set the offset for. Defaults to None (all spatial tendons). 
- env_ids – The environment indices to set the offset for. Defaults to None (all environments). 
 
 
 - write_spatial_tendon_properties_to_sim(spatial_tendon_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Write spatial tendon properties into the simulation. - 参数:
- spatial_tendon_ids – The spatial tendon indices to set the properties for. Defaults to None (all spatial tendons). 
- env_ids – The environment indices to set the properties for. Defaults to None (all environments). 
 
 
 - write_joint_friction_to_sim(joint_friction: torch.Tensor | float, joint_ids: Sequence[int] | slice | None = None, env_ids: Sequence[int] | None = None)[源代码]#
- Write joint friction coefficients into the simulation. - 自 2.1.0 版本弃用: Please use - write_joint_friction_coefficient_to_sim()instead.
 - property has_debug_vis_implementation: bool#
- Whether the asset has a debug visualization implemented. 
 - property is_initialized: bool#
- Whether the asset is initialized. - Returns True if the asset is initialized, False otherwise. 
 - set_debug_vis(debug_vis: bool) bool#
- Sets whether to visualize the asset data. - 参数:
- debug_vis – Whether to visualize the asset data. 
- 返回:
- Whether the debug visualization was successfully set. False if the asset does not support debug visualization. 
 
 - set_visibility(visible: bool, env_ids: Sequence[int] | None = None)#
- Set the visibility of the prims corresponding to the asset. - This operation affects the visibility of the prims corresponding to the asset in the USD stage. It is useful for toggling the visibility of the asset in the simulator. For instance, one can hide the asset when it is not being used to reduce the rendering overhead. - 备注 - This operation uses the PXR API to set the visibility of the prims. Thus, the operation may have an overhead if the number of prims is large. - 参数:
- visible – Whether to make the prims visible or not. 
- env_ids – The indices of the object to set visibility. Defaults to None (all instances). 
 
 
 
- class isaaclab.assets.ArticulationData[源代码]#
- 基类: - object- Data container for an articulation. - This class contains the data for an articulation in the simulation. The data includes the state of the root rigid body, the state of all the bodies in the articulation, and the joint state. The data is stored in the simulation world frame unless otherwise specified. - An articulation is comprised of multiple rigid bodies or links. For a rigid body, there are two frames of reference that are used: - Actor frame: The frame of reference of the rigid body prim. This typically corresponds to the Xform prim with the rigid body schema. 
- Center of mass frame: The frame of reference of the center of mass of the rigid body. 
 - Depending on the settings, the two frames may not coincide with each other. In the robotics sense, the actor frame can be interpreted as the link frame. - Attributes: - Body names in the order parsed by the simulation view. - Joint names in the order parsed by the simulation view. - Fixed tendon names in the order parsed by the simulation view. - Spatial tendon names in the order parsed by the simulation view. - Default root state - [pos, quat, lin_vel, ang_vel]in the local environment frame.- Default joint positions of all joints. - Default joint velocities of all joints. - Default mass for all the bodies in the articulation. - Default inertia for all the bodies in the articulation. - Default joint stiffness of all joints. - Default joint damping of all joints. - Default joint armature of all joints. - Default joint static friction coefficient of all joints. - Default joint dynamic friction coefficient of all joints. - Default joint viscous friction coefficient of all joints. - Default joint position limits of all joints. - Default tendon stiffness of all fixed tendons. - Default tendon damping of all fixed tendons. - Default tendon limit stiffness of all fixed tendons. - Default tendon rest length of all fixed tendons. - Default tendon offset of all fixed tendons. - Default tendon position limits of all fixed tendons. - Default tendon stiffness of all spatial tendons. - Default tendon damping of all spatial tendons. - Default tendon limit stiffness of all spatial tendons. - Default tendon offset of all spatial tendons. - Joint position targets commanded by the user. - Joint velocity targets commanded by the user. - Joint effort targets commanded by the user. - Joint torques computed from the actuator model (before clipping). - Joint torques applied from the actuator model (after clipping). - Joint stiffness provided to the simulation. - Joint damping provided to the simulation. - Joint armature provided to the simulation. - Joint static friction coefficient provided to the simulation. - Joint dynamic friction coefficient provided to the simulation. - Joint viscous friction coefficient provided to the simulation. - Joint position limits provided to the simulation. - Joint maximum velocity provided to the simulation. - Joint maximum effort provided to the simulation. - Soft joint positions limits for all joints. - Soft joint velocity limits for all joints. - Gear ratio for relating motor torques to applied Joint torques. - Fixed tendon stiffness provided to the simulation. - Fixed tendon damping provided to the simulation. - Fixed tendon limit stiffness provided to the simulation. - Fixed tendon rest length provided to the simulation. - Fixed tendon offset provided to the simulation. - Fixed tendon position limits provided to the simulation. - Spatial tendon stiffness provided to the simulation. - Spatial tendon damping provided to the simulation. - Spatial tendon limit stiffness provided to the simulation. - Spatial tendon offset provided to the simulation. - Root link pose - [pos, quat]in simulation world frame.- Root link velocity - [lin_vel, ang_vel]in simulation world frame.- Root center of mass pose - [pos, quat]in simulation world frame.- Root center of mass velocity - [lin_vel, ang_vel]in simulation world frame.- Root state - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Root state - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Root center of mass state - [pos, quat, lin_vel, ang_vel]in simulation world frame.- Body link pose - [pos, quat]in simulation world frame.- Body link velocity - [lin_vel, ang_vel]in simulation world frame.- Body center of mass pose - [pos, quat]in simulation world frame.- Body center of mass velocity - [lin_vel, ang_vel]in simulation world frame.- State of all bodies [pos, quat, lin_vel, ang_vel] in simulation world frame. - State of all bodies' link frame`[pos, quat, lin_vel, ang_vel]` in simulation world frame. - State of all bodies center of mass [pos, quat, lin_vel, ang_vel] in simulation world frame. - Acceleration of all bodies center of mass - [lin_acc, ang_acc].- Center of mass pose - [pos, quat]of all bodies in their respective body's link frames.- Joint reaction wrench applied from body parent to child body in parent body frame. - Joint positions of all joints. - Joint velocities of all joints. - Joint acceleration of all joints. - Projection of the gravity direction on base frame. - Yaw heading of the base frame (in radians). - Root link linear velocity in base frame. - Root link angular velocity in base world frame. - Root center of mass linear velocity in base frame. - Root center of mass angular velocity in base world frame. - Root link position in simulation world frame. - Root link orientation (w, x, y, z) in simulation world frame. - Root linear velocity in simulation world frame. - Root link angular velocity in simulation world frame. - Root center of mass position in simulation world frame. - Root center of mass orientation (w, x, y, z) in simulation world frame. - Root center of mass linear velocity in simulation world frame. - Root center of mass angular velocity in simulation world frame. - Positions of all bodies in simulation world frame. - Orientation (w, x, y, z) of all bodies in simulation world frame. - Linear velocity of all bodies in simulation world frame. - Angular velocity of all bodies in simulation world frame. - Positions of all bodies in simulation world frame. - Orientation (w, x, y, z) of the principle axis of inertia of all bodies in simulation world frame. - Linear velocity of all bodies in simulation world frame. - Angular velocity of all bodies in simulation world frame. - Linear acceleration of all bodies in simulation world frame. - Angular acceleration of all bodies in simulation world frame. - Center of mass position of all of the bodies in their respective link frames. - Orientation (w, x, y, z) of the principle axis of inertia of all of the bodies in their respective link frames. - Same as - root_link_pose_w.- Same as - root_link_pos_w.- Same as - root_link_quat_w.- Same as - root_com_vel_w.- Same as - root_com_lin_vel_w.- Same as - root_com_ang_vel_w.- Same as - root_com_lin_vel_b.- Same as - root_com_ang_vel_b.- Same as - body_link_pose_w.- Same as - body_link_pos_w.- Same as - body_link_quat_w.- Same as - body_com_vel_w.- Same as - body_com_lin_vel_w.- Same as - body_com_ang_vel_w.- Same as - body_com_acc_w.- Same as - body_com_lin_acc_w.- Same as - body_com_ang_acc_w.- Same as - body_com_pos_b.- Same as - body_com_quat_b.- Deprecated property. - Deprecated property. - Deprecated property. - Deprecated property. - Deprecated property. - Deprecated property. - Deprecated property. - fixed_tendon_names: list[str] = None#
- Fixed tendon names in the order parsed by the simulation view. 
 - spatial_tendon_names: list[str] = None#
- Spatial tendon names in the order parsed by the simulation view. 
 - default_root_state: torch.Tensor = None#
- Default root state - [pos, quat, lin_vel, ang_vel]in the local environment frame. Shape is (num_instances, 13).- The position and quaternion are of the articulation root’s actor frame. Meanwhile, the linear and angular velocities are of its center of mass frame. - This quantity is configured through the - isaaclab.assets.ArticulationCfg.init_stateparameter.
 - default_joint_pos: torch.Tensor = None#
- Default joint positions of all joints. Shape is (num_instances, num_joints). - This quantity is configured through the - isaaclab.assets.ArticulationCfg.init_stateparameter.
 - default_joint_vel: torch.Tensor = None#
- Default joint velocities of all joints. Shape is (num_instances, num_joints). - This quantity is configured through the - isaaclab.assets.ArticulationCfg.init_stateparameter.
 - default_mass: torch.Tensor = None#
- Default mass for all the bodies in the articulation. Shape is (num_instances, num_bodies). - This quantity is parsed from the USD schema at the time of initialization. 
 - default_inertia: torch.Tensor = None#
- Default inertia for all the bodies in the articulation. Shape is (num_instances, num_bodies, 9). - The inertia tensor should be given with respect to the center of mass, expressed in the articulation links’ actor frame. The values are stored in the order \([I_{xx}, I_{yx}, I_{zx}, I_{xy}, I_{yy}, I_{zy}, I_{xz}, I_{yz}, I_{zz}]\). However, due to the symmetry of inertia tensors, row- and column-major orders are equivalent. - This quantity is parsed from the USD schema at the time of initialization. 
 - default_joint_stiffness: torch.Tensor = None#
- Default joint stiffness of all joints. Shape is (num_instances, num_joints). - This quantity is configured through the actuator model’s - isaaclab.actuators.ActuatorBaseCfg.stiffnessparameter. If the parameter’s value is None, the value parsed from the USD schema, at the time of initialization, is used.- 注意 - The default stiffness is the value configured by the user or the value parsed from the USD schema. It should not be confused with - joint_stiffness, which is the value set into the simulation.
 - default_joint_damping: torch.Tensor = None#
- Default joint damping of all joints. Shape is (num_instances, num_joints). - This quantity is configured through the actuator model’s - isaaclab.actuators.ActuatorBaseCfg.dampingparameter. If the parameter’s value is None, the value parsed from the USD schema, at the time of initialization, is used.- 注意 - The default stiffness is the value configured by the user or the value parsed from the USD schema. It should not be confused with - joint_damping, which is the value set into the simulation.
 - default_joint_armature: torch.Tensor = None#
- Default joint armature of all joints. Shape is (num_instances, num_joints). - This quantity is configured through the actuator model’s - isaaclab.actuators.ActuatorBaseCfg.armatureparameter. If the parameter’s value is None, the value parsed from the USD schema, at the time of initialization, is used.
 - default_joint_friction_coeff: torch.Tensor = None#
- Default joint static friction coefficient of all joints. Shape is (num_instances, num_joints). - This quantity is configured through the actuator model’s - isaaclab.actuators.ActuatorBaseCfg.frictionparameter. If the parameter’s value is None, the value parsed from the USD schema, at the time of initialization, is used.
 - default_joint_dynamic_friction_coeff: torch.Tensor = None#
- Default joint dynamic friction coefficient of all joints. Shape is (num_instances, num_joints). - This quantity is configured through the actuator model’s - isaaclab.actuators.ActuatorBaseCfg.dynamic_frictionparameter. If the parameter’s value is None, the value parsed from the USD schema, at the time of initialization, is used.
 - default_joint_viscous_friction_coeff: torch.Tensor = None#
- Default joint viscous friction coefficient of all joints. Shape is (num_instances, num_joints). - This quantity is configured through the actuator model’s - isaaclab.actuators.ActuatorBaseCfg.viscous_frictionparameter. If the parameter’s value is None, the value parsed from the USD schema, at the time of initialization, is used.
 - default_joint_pos_limits: torch.Tensor = None#
- Default joint position limits of all joints. Shape is (num_instances, num_joints, 2). - The limits are in the order \([lower, upper]\). They are parsed from the USD schema at the time of initialization. 
 - default_fixed_tendon_stiffness: torch.Tensor = None#
- Default tendon stiffness of all fixed tendons. Shape is (num_instances, num_fixed_tendons). - This quantity is parsed from the USD schema at the time of initialization. 
 - default_fixed_tendon_damping: torch.Tensor = None#
- Default tendon damping of all fixed tendons. Shape is (num_instances, num_fixed_tendons). - This quantity is parsed from the USD schema at the time of initialization. 
 - default_fixed_tendon_limit_stiffness: torch.Tensor = None#
- Default tendon limit stiffness of all fixed tendons. Shape is (num_instances, num_fixed_tendons). - This quantity is parsed from the USD schema at the time of initialization. 
 - default_fixed_tendon_rest_length: torch.Tensor = None#
- Default tendon rest length of all fixed tendons. Shape is (num_instances, num_fixed_tendons). - This quantity is parsed from the USD schema at the time of initialization. 
 - default_fixed_tendon_offset: torch.Tensor = None#
- Default tendon offset of all fixed tendons. Shape is (num_instances, num_fixed_tendons). - This quantity is parsed from the USD schema at the time of initialization. 
 - default_fixed_tendon_pos_limits: torch.Tensor = None#
- Default tendon position limits of all fixed tendons. Shape is (num_instances, num_fixed_tendons, 2). - The position limits are in the order \([lower, upper]\). They are parsed from the USD schema at the time of initialization. 
 - default_spatial_tendon_stiffness: torch.Tensor = None#
- Default tendon stiffness of all spatial tendons. Shape is (num_instances, num_spatial_tendons). - This quantity is parsed from the USD schema at the time of initialization. 
 - default_spatial_tendon_damping: torch.Tensor = None#
- Default tendon damping of all spatial tendons. Shape is (num_instances, num_spatial_tendons). - This quantity is parsed from the USD schema at the time of initialization. 
 - default_spatial_tendon_limit_stiffness: torch.Tensor = None#
- Default tendon limit stiffness of all spatial tendons. Shape is (num_instances, num_spatial_tendons). - This quantity is parsed from the USD schema at the time of initialization. 
 - default_spatial_tendon_offset: torch.Tensor = None#
- Default tendon offset of all spatial tendons. Shape is (num_instances, num_spatial_tendons). - This quantity is parsed from the USD schema at the time of initialization. 
 - joint_pos_target: torch.Tensor = None#
- Joint position targets commanded by the user. Shape is (num_instances, num_joints). - For an implicit actuator model, the targets are directly set into the simulation. For an explicit actuator model, the targets are used to compute the joint torques (see - applied_torque), which are then set into the simulation.
 - joint_vel_target: torch.Tensor = None#
- Joint velocity targets commanded by the user. Shape is (num_instances, num_joints). - For an implicit actuator model, the targets are directly set into the simulation. For an explicit actuator model, the targets are used to compute the joint torques (see - applied_torque), which are then set into the simulation.
 - joint_effort_target: torch.Tensor = None#
- Joint effort targets commanded by the user. Shape is (num_instances, num_joints). - For an implicit actuator model, the targets are directly set into the simulation. For an explicit actuator model, the targets are used to compute the joint torques (see - applied_torque), which are then set into the simulation.
 - computed_torque: torch.Tensor = None#
- Joint torques computed from the actuator model (before clipping). Shape is (num_instances, num_joints). - This quantity is the raw torque output from the actuator mode, before any clipping is applied. It is exposed for users who want to inspect the computations inside the actuator model. For instance, to penalize the learning agent for a difference between the computed and applied torques. 
 - applied_torque: torch.Tensor = None#
- Joint torques applied from the actuator model (after clipping). Shape is (num_instances, num_joints). - These torques are set into the simulation, after clipping the - computed_torquebased on the actuator model.
 - joint_stiffness: torch.Tensor = None#
- Joint stiffness provided to the simulation. Shape is (num_instances, num_joints). - In the case of explicit actuators, the value for the corresponding joints is zero. 
 - joint_damping: torch.Tensor = None#
- Joint damping provided to the simulation. Shape is (num_instances, num_joints) - In the case of explicit actuators, the value for the corresponding joints is zero. 
 - joint_armature: torch.Tensor = None#
- Joint armature provided to the simulation. Shape is (num_instances, num_joints). 
 - joint_friction_coeff: torch.Tensor = None#
- Joint static friction coefficient provided to the simulation. Shape is (num_instances, num_joints). 
 - joint_dynamic_friction_coeff: torch.Tensor = None#
- Joint dynamic friction coefficient provided to the simulation. Shape is (num_instances, num_joints). 
 - joint_viscous_friction_coeff: torch.Tensor = None#
- Joint viscous friction coefficient provided to the simulation. Shape is (num_instances, num_joints). 
 - joint_pos_limits: torch.Tensor = None#
- Joint position limits provided to the simulation. Shape is (num_instances, num_joints, 2). - The limits are in the order \([lower, upper]\). 
 - joint_vel_limits: torch.Tensor = None#
- Joint maximum velocity provided to the simulation. Shape is (num_instances, num_joints). 
 - joint_effort_limits: torch.Tensor = None#
- Joint maximum effort provided to the simulation. Shape is (num_instances, num_joints). 
 - soft_joint_pos_limits: torch.Tensor = None#
- Soft joint positions limits for all joints. Shape is (num_instances, num_joints, 2). - The limits are in the order \([lower, upper]\).The soft joint position limits are computed as a sub-region of the - joint_pos_limitsbased on the- soft_joint_pos_limit_factorparameter.- Consider the joint position limits \([lower, upper]\) and the soft joint position limits \([soft_lower, soft_upper]\). The soft joint position limits are computed as: \[soft\_lower = (lower + upper) / 2 - factor * (upper - lower) / 2 soft\_upper = (lower + upper) / 2 + factor * (upper - lower) / 2\]- The soft joint position limits help specify a safety region around the joint limits. It isn’t used by the simulation, but is useful for learning agents to prevent the joint positions from violating the limits. 
 - soft_joint_vel_limits: torch.Tensor = None#
- Soft joint velocity limits for all joints. Shape is (num_instances, num_joints). - These are obtained from the actuator model. It may differ from - joint_vel_limitsif the actuator model has a variable velocity limit model. For instance, in a variable gear ratio actuator model.
 - gear_ratio: torch.Tensor = None#
- Gear ratio for relating motor torques to applied Joint torques. Shape is (num_instances, num_joints). 
 - fixed_tendon_stiffness: torch.Tensor = None#
- Fixed tendon stiffness provided to the simulation. Shape is (num_instances, num_fixed_tendons). 
 - fixed_tendon_damping: torch.Tensor = None#
- Fixed tendon damping provided to the simulation. Shape is (num_instances, num_fixed_tendons). 
 - fixed_tendon_limit_stiffness: torch.Tensor = None#
- Fixed tendon limit stiffness provided to the simulation. Shape is (num_instances, num_fixed_tendons). 
 - fixed_tendon_rest_length: torch.Tensor = None#
- Fixed tendon rest length provided to the simulation. Shape is (num_instances, num_fixed_tendons). 
 - fixed_tendon_offset: torch.Tensor = None#
- Fixed tendon offset provided to the simulation. Shape is (num_instances, num_fixed_tendons). 
 - fixed_tendon_pos_limits: torch.Tensor = None#
- Fixed tendon position limits provided to the simulation. Shape is (num_instances, num_fixed_tendons, 2). 
 - spatial_tendon_stiffness: torch.Tensor = None#
- Spatial tendon stiffness provided to the simulation. Shape is (num_instances, num_spatial_tendons). 
 - spatial_tendon_damping: torch.Tensor = None#
- Spatial tendon damping provided to the simulation. Shape is (num_instances, num_spatial_tendons). 
 - spatial_tendon_limit_stiffness: torch.Tensor = None#
- Spatial tendon limit stiffness provided to the simulation. Shape is (num_instances, num_spatial_tendons). 
 - spatial_tendon_offset: torch.Tensor = None#
- Spatial tendon offset provided to the simulation. Shape is (num_instances, num_spatial_tendons). 
 - property root_link_pose_w: torch.Tensor#
- Root link pose - [pos, quat]in simulation world frame. Shape is (num_instances, 7).- This quantity is the pose of the articulation root’s actor frame relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property root_link_vel_w: torch.Tensor#
- Root link velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 6).- This quantity contains the linear and angular velocities of the articulation root’s actor frame relative to the world. 
 - property root_com_pose_w: torch.Tensor#
- Root center of mass pose - [pos, quat]in simulation world frame. Shape is (num_instances, 7).- This quantity is the pose of the articulation root’s center of mass frame relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property root_com_vel_w: torch.Tensor#
- Root center of mass velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 6).- This quantity contains the linear and angular velocities of the articulation root’s center of mass frame relative to the world. 
 - property root_state_w#
- Root state - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 13).- The position and quaternion are of the articulation root’s actor frame relative to the world. Meanwhile, the linear and angular velocities are of the articulation root’s center of mass frame. 
 - property root_link_state_w#
- Root state - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 13).- The position, quaternion, and linear/angular velocity are of the articulation root’s actor frame relative to the world. 
 - property root_com_state_w#
- Root center of mass state - [pos, quat, lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, 13).- The position, quaternion, and linear/angular velocity are of the articulation root link’s center of mass frame relative to the world. Center of mass frame is assumed to be the same orientation as the link rather than the orientation of the principle inertia. 
 - property body_link_pose_w: torch.Tensor#
- Body link pose - [pos, quat]in simulation world frame. Shape is (num_instances, num_bodies, 7).- This quantity is the pose of the articulation links’ actor frame relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property body_link_vel_w: torch.Tensor#
- Body link velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, num_bodies, 6).- This quantity contains the linear and angular velocities of the articulation links’ actor frame relative to the world. 
 - property body_com_pose_w: torch.Tensor#
- Body center of mass pose - [pos, quat]in simulation world frame. Shape is (num_instances, num_bodies, 7).- This quantity is the pose of the center of mass frame of the articulation links relative to the world. The orientation is provided in (w, x, y, z) format. 
 - property body_com_vel_w: torch.Tensor#
- Body center of mass velocity - [lin_vel, ang_vel]in simulation world frame. Shape is (num_instances, num_bodies, 6).- This quantity contains the linear and angular velocities of the articulation links’ center of mass frame relative to the world. 
 - property body_state_w#
- State of all bodies [pos, quat, lin_vel, ang_vel] in simulation world frame. Shape is (num_instances, num_bodies, 13). - The position and quaternion are of all the articulation links’ actor frame. Meanwhile, the linear and angular velocities are of the articulation links’s center of mass frame. 
 - property body_link_state_w#
- State of all bodies’ link frame`[pos, quat, lin_vel, ang_vel]` in simulation world frame. Shape is (num_instances, num_bodies, 13). - The position, quaternion, and linear/angular velocity are of the body’s link frame relative to the world. 
 - property body_com_state_w#
- State of all bodies center of mass [pos, quat, lin_vel, ang_vel] in simulation world frame. Shape is (num_instances, num_bodies, 13). - The position, quaternion, and linear/angular velocity are of the body’s center of mass frame relative to the world. Center of mass frame is assumed to be the same orientation as the link rather than the orientation of the principle inertia. 
 - property body_com_acc_w#
- Acceleration of all bodies center of mass - [lin_acc, ang_acc]. Shape is (num_instances, num_bodies, 6).- All values are relative to the world. 
 - property body_com_pose_b: torch.Tensor#
- Center of mass pose - [pos, quat]of all bodies in their respective body’s link frames. Shape is (num_instances, 1, 7).- This quantity is the pose of the center of mass frame of the rigid body relative to the body’s link frame. The orientation is provided in (w, x, y, z) format. 
 - property body_incoming_joint_wrench_b: torch.Tensor#
- Joint reaction wrench applied from body parent to child body in parent body frame. - Shape is (num_instances, num_bodies, 6). All body reaction wrenches are provided including the root body to the world of an articulation. - For more information on joint wrenches, please check the`PhysX documentation <https://nvidia-omniverse.github.io/PhysX/physx/5.5.1/docs/Articulations.html#link-incoming-joint-force>`__ and the underlying PhysX Tensor API . 
 - property joint_pos#
- Joint positions of all joints. Shape is (num_instances, num_joints). 
 - property joint_vel#
- Joint velocities of all joints. Shape is (num_instances, num_joints). 
 - property joint_acc#
- Joint acceleration of all joints. Shape is (num_instances, num_joints). 
 - property projected_gravity_b#
- Projection of the gravity direction on base frame. Shape is (num_instances, 3). 
 - property heading_w#
- Yaw heading of the base frame (in radians). Shape is (num_instances,). - 备注 - This quantity is computed by assuming that the forward-direction of the base frame is along x-direction, i.e. \((1, 0, 0)\). 
 - property root_link_lin_vel_b: torch.Tensor#
- Root link linear velocity in base frame. Shape is (num_instances, 3). - This quantity is the linear velocity of the articulation root’s actor frame with respect to the its actor frame. 
 - property root_link_ang_vel_b: torch.Tensor#
- Root link angular velocity in base world frame. Shape is (num_instances, 3). - This quantity is the angular velocity of the articulation root’s actor frame with respect to the its actor frame. 
 - property root_com_lin_vel_b: torch.Tensor#
- Root center of mass linear velocity in base frame. Shape is (num_instances, 3). - This quantity is the linear velocity of the articulation root’s center of mass frame with respect to the its actor frame. 
 - property root_com_ang_vel_b: torch.Tensor#
- Root center of mass angular velocity in base world frame. Shape is (num_instances, 3). - This quantity is the angular velocity of the articulation root’s center of mass frame with respect to the its actor frame. 
 - property root_link_pos_w: torch.Tensor#
- Root link position in simulation world frame. Shape is (num_instances, 3). - This quantity is the position of the actor frame of the root rigid body relative to the world. 
 - property root_link_quat_w: torch.Tensor#
- Root link orientation (w, x, y, z) in simulation world frame. Shape is (num_instances, 4). - This quantity is the orientation of the actor frame of the root rigid body. 
 - property root_link_lin_vel_w: torch.Tensor#
- Root linear velocity in simulation world frame. Shape is (num_instances, 3). - This quantity is the linear velocity of the root rigid body’s actor frame relative to the world. 
 - property root_link_ang_vel_w: torch.Tensor#
- Root link angular velocity in simulation world frame. Shape is (num_instances, 3). - This quantity is the angular velocity of the actor frame of the root rigid body relative to the world. 
 - property root_com_pos_w: torch.Tensor#
- Root center of mass position in simulation world frame. Shape is (num_instances, 3). - This quantity is the position of the actor frame of the root rigid body relative to the world. 
 - property root_com_quat_w: torch.Tensor#
- Root center of mass orientation (w, x, y, z) in simulation world frame. Shape is (num_instances, 4). - This quantity is the orientation of the actor frame of the root rigid body relative to the world. 
 - property root_com_lin_vel_w: torch.Tensor#
- Root center of mass linear velocity in simulation world frame. Shape is (num_instances, 3). - This quantity is the linear velocity of the root rigid body’s center of mass frame relative to the world. 
 - property root_com_ang_vel_w: torch.Tensor#
- Root center of mass angular velocity in simulation world frame. Shape is (num_instances, 3). - This quantity is the angular velocity of the root rigid body’s center of mass frame relative to the world. 
 - property body_link_pos_w: torch.Tensor#
- Positions of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 3). - This quantity is the position of the articulation bodies’ actor frame relative to the world. 
 - property body_link_quat_w: torch.Tensor#
- Orientation (w, x, y, z) of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 4). - This quantity is the orientation of the articulation bodies’ actor frame relative to the world. 
 - property body_link_lin_vel_w: torch.Tensor#
- Linear velocity of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 3). - This quantity is the linear velocity of the articulation bodies’ center of mass frame relative to the world. 
 - property body_link_ang_vel_w: torch.Tensor#
- Angular velocity of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 3). - This quantity is the angular velocity of the articulation bodies’ center of mass frame relative to the world. 
 - property body_com_pos_w: torch.Tensor#
- Positions of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 3). - This quantity is the position of the articulation bodies’ actor frame. 
 - property body_com_quat_w: torch.Tensor#
- Orientation (w, x, y, z) of the principle axis of inertia of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 4). - This quantity is the orientation of the articulation bodies’ actor frame. 
 - property body_com_lin_vel_w: torch.Tensor#
- Linear velocity of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 3). - This quantity is the linear velocity of the articulation bodies’ center of mass frame. 
 - property body_com_ang_vel_w: torch.Tensor#
- Angular velocity of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 3). - This quantity is the angular velocity of the articulation bodies’ center of mass frame. 
 - property body_com_lin_acc_w: torch.Tensor#
- Linear acceleration of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 3). - This quantity is the linear acceleration of the articulation bodies’ center of mass frame. 
 - property body_com_ang_acc_w: torch.Tensor#
- Angular acceleration of all bodies in simulation world frame. Shape is (num_instances, num_bodies, 3). - This quantity is the angular acceleration of the articulation bodies’ center of mass frame. 
 - property body_com_pos_b: torch.Tensor#
- Center of mass position of all of the bodies in their respective link frames. Shape is (num_instances, num_bodies, 3). - This quantity is the center of mass location relative to its body’slink frame. 
 - property body_com_quat_b: torch.Tensor#
- Orientation (w, x, y, z) of the principle axis of inertia of all of the bodies in their respective link frames. Shape is (num_instances, num_bodies, 4). - This quantity is the orientation of the principles axes of inertia relative to its body’s link frame. 
 - property root_pose_w: torch.Tensor#
- Same as - root_link_pose_w.
 - property root_pos_w: torch.Tensor#
- Same as - root_link_pos_w.
 - property root_quat_w: torch.Tensor#
- Same as - root_link_quat_w.
 - property root_vel_w: torch.Tensor#
- Same as - root_com_vel_w.
 - property root_lin_vel_w: torch.Tensor#
- Same as - root_com_lin_vel_w.
 - property root_ang_vel_w: torch.Tensor#
- Same as - root_com_ang_vel_w.
 - property root_lin_vel_b: torch.Tensor#
- Same as - root_com_lin_vel_b.
 - property root_ang_vel_b: torch.Tensor#
- Same as - root_com_ang_vel_b.
 - property body_pose_w: torch.Tensor#
- Same as - body_link_pose_w.
 - property body_pos_w: torch.Tensor#
- Same as - body_link_pos_w.
 - property body_quat_w: torch.Tensor#
- Same as - body_link_quat_w.
 - property body_vel_w: torch.Tensor#
- Same as - body_com_vel_w.
 - property body_lin_vel_w: torch.Tensor#
- Same as - body_com_lin_vel_w.
 - property body_ang_vel_w: torch.Tensor#
- Same as - body_com_ang_vel_w.
 - property body_acc_w: torch.Tensor#
- Same as - body_com_acc_w.
 - property body_lin_acc_w: torch.Tensor#
- Same as - body_com_lin_acc_w.
 - property body_ang_acc_w: torch.Tensor#
- Same as - body_com_ang_acc_w.
 - property com_pos_b: torch.Tensor#
- Same as - body_com_pos_b.
 - property com_quat_b: torch.Tensor#
- Same as - body_com_quat_b.
 - property joint_limits: torch.Tensor#
- Deprecated property. Please use - joint_pos_limitsinstead.
 - property default_joint_limits: torch.Tensor#
- Deprecated property. Please use - default_joint_pos_limitsinstead.
 - property joint_velocity_limits: torch.Tensor#
- Deprecated property. Please use - joint_vel_limitsinstead.
 - property joint_friction: torch.Tensor#
- Deprecated property. Please use - joint_friction_coeffinstead.
 - property default_joint_friction: torch.Tensor#
- Deprecated property. Please use - default_joint_friction_coeffinstead.
 - property fixed_tendon_limit: torch.Tensor#
- Deprecated property. Please use - fixed_tendon_pos_limitsinstead.
 - property default_fixed_tendon_limit: torch.Tensor#
- Deprecated property. Please use - default_fixed_tendon_pos_limitsinstead.
 
- class isaaclab.assets.ArticulationCfg[源代码]#
- 基类: - AssetBaseCfg- Configuration parameters for an articulation. - Classes: - Initial state of the articulation. - Attributes: - Prim path (or expression) to the asset. - Spawn configuration for the asset. - Collision group of the asset. - Whether to enable debug visualization for the asset. - Path to the articulation root prim under the - prim_path.- Initial state of the articulated object. - Fraction specifying the range of joint position limits (parsed from the asset) to use. - Actuators for the robot with corresponding joint names. - Print the resolution of actuator final value when input cfg is different from USD value, Defaults to False - class InitialStateCfg[源代码]#
- 
Initial state of the articulation. Attributes: Linear velocity of the root in simulation world frame. Angular velocity of the root in simulation world frame. Joint positions of the joints. Joint velocities of the joints. Position of the root in simulation world frame. Quaternion rotation (w, x, y, z) of the root in simulation world frame. - lin_vel: tuple[float, float, float]#
- Linear velocity of the root in simulation world frame. Defaults to (0.0, 0.0, 0.0). 
 - ang_vel: tuple[float, float, float]#
- Angular velocity of the root in simulation world frame. Defaults to (0.0, 0.0, 0.0). 
 
 - prim_path: str#
- Prim path (or expression) to the asset. - 备注 - The expression can contain the environment namespace regex - {ENV_REGEX_NS}which will be replaced with the environment namespace.- Example: - {ENV_REGEX_NS}/Robotwill be replaced with- /World/envs/env_.*/Robot.
 - spawn: SpawnerCfg | None#
- Spawn configuration for the asset. Defaults to None. - If None, then no prims are spawned by the asset class. Instead, it is assumed that the asset is already present in the scene. 
 - collision_group: Literal[0, -1]#
- Collision group of the asset. Defaults to - 0.- -1: global collision group (collides with all assets in the scene).
- 0: local collision group (collides with other assets in the same environment).
 
 - articulation_root_prim_path: str | None#
- Path to the articulation root prim under the - prim_path. Defaults to None, in which case the class will search for a prim with the USD ArticulationRootAPI on it.- This path should be relative to the - prim_pathof the asset. If the asset is loaded from a USD file, this path should be relative to the root of the USD stage. For instance, if the loaded USD file at- prim_pathcontains two articulations, one at /robot1 and another at /robot2, and you want to use robot2, then you should set this to /robot2.- The path must start with a slash (/). 
 - init_state: InitialStateCfg#
- Initial state of the articulated object. Defaults to identity pose with zero velocity and zero joint state. 
 - soft_joint_pos_limit_factor: float#
- Fraction specifying the range of joint position limits (parsed from the asset) to use. Defaults to 1.0. - The soft joint position limits are scaled by this factor to specify a safety region within the simulated joint position limits. This isn’t used by the simulation, but is useful for learning agents to prevent the joint positions from violating the limits, such as for termination conditions. - The soft joint position limits are accessible through the - ArticulationData.soft_joint_pos_limitsattribute.
 - actuators: dict[str, isaaclab.actuators.actuator_cfg.ActuatorBaseCfg]#
- Actuators for the robot with corresponding joint names. 
 
Deformable Object#
- class isaaclab.assets.DeformableObject[源代码]#
- 基类: - AssetBase- A deformable object asset class. - Deformable objects are assets that can be deformed in the simulation. They are typically used for soft bodies, such as stuffed animals and food items. - Unlike rigid object assets, deformable objects have a more complex structure and require additional handling for simulation. The simulation of deformable objects follows a finite element approach, where the object is discretized into a mesh of nodes and elements. The nodes are connected by elements, which define the material properties of the object. The nodes can be moved and deformed, and the elements respond to these changes. - The state of a deformable object comprises of its nodal positions and velocities, and not the object’s root position and orientation. The nodal positions and velocities are in the simulation frame. - Soft bodies can be partially kinematic, where some nodes are driven by kinematic targets, and the rest are simulated. The kinematic targets are the desired positions of the nodes, and the simulation drives the nodes towards these targets. This is useful for partial control of the object, such as moving a stuffed animal’s head while the rest of the body is simulated. - 注意 - This class is experimental and subject to change due to changes on the underlying PhysX API on which it depends. We will try to maintain backward compatibility as much as possible but some changes may be necessary. - Attributes: - Configuration instance for the deformable object. - Data related to the asset. - Number of instances of the asset. - Number of bodies in the asset. - Deformable body view for the asset (PhysX). - Deformable material view for the asset (PhysX). - The maximum number of simulation mesh elements per deformable body. - The maximum number of collision mesh elements per deformable body. - The maximum number of simulation mesh vertices per deformable body. - The maximum number of collision mesh vertices per deformable body. - Memory device for computation. - Whether the asset has a debug visualization implemented. - Whether the asset is initialized. - Methods: - __init__(cfg)- Initialize the deformable object. - reset([env_ids])- Resets all internal buffers of selected environments. - Writes data to the simulator. - update(dt)- Update the internal buffers. - write_nodal_state_to_sim(nodal_state[, env_ids])- Set the nodal state over selected environment indices into the simulation. - write_nodal_pos_to_sim(nodal_pos[, env_ids])- Set the nodal positions over selected environment indices into the simulation. - write_nodal_velocity_to_sim(nodal_vel[, env_ids])- Set the nodal velocity over selected environment indices into the simulation. - write_nodal_kinematic_target_to_sim(targets)- Set the kinematic targets of the simulation mesh for the deformable bodies indicated by the indices. - transform_nodal_pos(nodal_pos[, pos, quat])- Transform the nodal positions based on the pose transformation. - set_debug_vis(debug_vis)- Sets whether to visualize the asset data. - set_visibility(visible[, env_ids])- Set the visibility of the prims corresponding to the asset. - cfg: DeformableObjectCfg#
- Configuration instance for the deformable object. 
 - __init__(cfg: DeformableObjectCfg)[源代码]#
- Initialize the deformable object. - 参数:
- cfg – A configuration instance. 
 
 - property data: DeformableObjectData#
- Data related to the asset. 
 - property num_instances: int#
- Number of instances of the asset. - This is equal to the number of asset instances per environment multiplied by the number of environments. 
 - property num_bodies: int#
- Number of bodies in the asset. - This is always 1 since each object is a single deformable body. 
 - property root_physx_view: omni.physics.tensors.impl.api.SoftBodyView#
- Deformable body view for the asset (PhysX). - 备注 - Use this view with caution. It requires handling of tensors in a specific way. 
 - property material_physx_view: physx.SoftBodyMaterialView | None#
- Deformable material view for the asset (PhysX). - This view is optional and may not be available if the material is not bound to the deformable body. If the material is not available, then the material properties will be set to default values. - 备注 - Use this view with caution. It requires handling of tensors in a specific way. 
 - property max_sim_elements_per_body: int#
- The maximum number of simulation mesh elements per deformable body. 
 - property max_collision_elements_per_body: int#
- The maximum number of collision mesh elements per deformable body. 
 - property max_sim_vertices_per_body: int#
- The maximum number of simulation mesh vertices per deformable body. 
 - property max_collision_vertices_per_body: int#
- The maximum number of collision mesh vertices per deformable body. 
 - reset(env_ids: Sequence[int] | None = None)[源代码]#
- Resets all internal buffers of selected environments. - 参数:
- env_ids – The indices of the object to reset. Defaults to None (all instances). 
 
 - update(dt: float)[源代码]#
- Update the internal buffers. - The time step - dtis used to compute numerical derivatives of quantities such as joint accelerations which are not provided by the simulator.- 参数:
- dt – The amount of time passed from last - updatecall.
 
 - write_nodal_state_to_sim(nodal_state: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the nodal state over selected environment indices into the simulation. - The nodal state comprises of the nodal positions and velocities. Since these are nodes, the velocity only has a translational component. All the quantities are in the simulation frame. - 参数:
- nodal_state – Nodal state in simulation frame. Shape is (len(env_ids), max_sim_vertices_per_body, 6). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_nodal_pos_to_sim(nodal_pos: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the nodal positions over selected environment indices into the simulation. - The nodal position comprises of individual nodal positions of the simulation mesh for the deformable body. The positions are in the simulation frame. - 参数:
- nodal_pos – Nodal positions in simulation frame. Shape is (len(env_ids), max_sim_vertices_per_body, 3). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_nodal_velocity_to_sim(nodal_vel: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the nodal velocity over selected environment indices into the simulation. - The nodal velocity comprises of individual nodal velocities of the simulation mesh for the deformable body. Since these are nodes, the velocity only has a translational component. The velocities are in the simulation frame. - 参数:
- nodal_vel – Nodal velocities in simulation frame. Shape is (len(env_ids), max_sim_vertices_per_body, 3). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - write_nodal_kinematic_target_to_sim(targets: torch.Tensor, env_ids: Sequence[int] | None = None)[源代码]#
- Set the kinematic targets of the simulation mesh for the deformable bodies indicated by the indices. - The kinematic targets comprise of individual nodal positions of the simulation mesh for the deformable body and a flag indicating whether the node is kinematically driven or not. The positions are in the simulation frame. - 备注 - The flag is set to 0.0 for kinematically driven nodes and 1.0 for free nodes. - 参数:
- targets – The kinematic targets comprising of nodal positions and flags. Shape is (len(env_ids), max_sim_vertices_per_body, 4). 
- env_ids – Environment indices. If None, then all indices are used. 
 
 
 - transform_nodal_pos(nodal_pos: torch.tensor, pos: torch.Tensor | None = None, quat: torch.Tensor | None = None) torch.Tensor[源代码]#
- Transform the nodal positions based on the pose transformation. - This function computes the transformation of the nodal positions based on the pose transformation. It multiplies the nodal positions with the rotation matrix of the pose and adds the translation. Internally, it calls the - isaaclab.utils.math.transform_points()function.- 参数:
- nodal_pos – The nodal positions in the simulation frame. Shape is (N, max_sim_vertices_per_body, 3). 
- pos – The position transformation. Shape is (N, 3). Defaults to None, in which case the position is assumed to be zero. 
- quat – The orientation transformation as quaternion (w, x, y, z). Shape is (N, 4). Defaults to None, in which case the orientation is assumed to be identity. 
 
- 返回:
- The transformed nodal positions. Shape is (N, max_sim_vertices_per_body, 3). 
 
 - property has_debug_vis_implementation: bool#
- Whether the asset has a debug visualization implemented. 
 - property is_initialized: bool#
- Whether the asset is initialized. - Returns True if the asset is initialized, False otherwise. 
 - set_debug_vis(debug_vis: bool) bool#
- Sets whether to visualize the asset data. - 参数:
- debug_vis – Whether to visualize the asset data. 
- 返回:
- Whether the debug visualization was successfully set. False if the asset does not support debug visualization. 
 
 - set_visibility(visible: bool, env_ids: Sequence[int] | None = None)#
- Set the visibility of the prims corresponding to the asset. - This operation affects the visibility of the prims corresponding to the asset in the USD stage. It is useful for toggling the visibility of the asset in the simulator. For instance, one can hide the asset when it is not being used to reduce the rendering overhead. - 备注 - This operation uses the PXR API to set the visibility of the prims. Thus, the operation may have an overhead if the number of prims is large. - 参数:
- visible – Whether to make the prims visible or not. 
- env_ids – The indices of the object to set visibility. Defaults to None (all instances). 
 
 
 
- class isaaclab.assets.DeformableObjectData[源代码]#
- 基类: - object- Data container for a deformable object. - This class contains the data for a deformable object in the simulation. The data includes the nodal states of the root deformable body in the object. The data is stored in the simulation world frame unless otherwise specified. - A deformable object in PhysX uses two tetrahedral meshes to represent the object: - Simulation mesh: This mesh is used for the simulation and is the one that is deformed by the solver. 
- Collision mesh: This mesh only needs to match the surface of the simulation mesh and is used for collision detection. 
 - The APIs exposed provides the data for both the simulation and collision meshes. These are specified by the sim and collision prefixes in the property names. - The data is lazily updated, meaning that the data is only updated when it is accessed. This is useful when the data is expensive to compute or retrieve. The data is updated when the timestamp of the buffer is older than the current simulation timestamp. The timestamp is updated whenever the data is updated. - Methods: - update(dt)- Updates the data for the deformable object. - Attributes: - Default nodal state - [nodal_pos, nodal_vel]in simulation world frame.- Simulation mesh kinematic targets for the deformable bodies. - Nodal positions in simulation world frame. - Nodal velocities in simulation world frame. - Nodal state - [nodal_pos, nodal_vel]in simulation world frame.- Simulation mesh element-wise rotations as quaternions for the deformable bodies in simulation world frame. - Collision mesh element-wise rotations as quaternions for the deformable bodies in simulation world frame. - Simulation mesh element-wise second-order deformation gradient tensors for the deformable bodies in simulation world frame. - Collision mesh element-wise second-order deformation gradient tensors for the deformable bodies in simulation world frame. - Simulation mesh element-wise second-order Cauchy stress tensors for the deformable bodies in simulation world frame. - Collision mesh element-wise second-order Cauchy stress tensors for the deformable bodies in simulation world frame. - Root position from nodal positions of the simulation mesh for the deformable bodies in simulation world frame. - Root velocity from vertex velocities for the deformable bodies in simulation world frame. - update(dt: float)[源代码]#
- Updates the data for the deformable object. - 参数:
- dt – The time step for the update. This must be a positive value. 
 
 - default_nodal_state_w: torch.Tensor = None#
- Default nodal state - [nodal_pos, nodal_vel]in simulation world frame. Shape is (num_instances, max_sim_vertices_per_body, 6).
 - nodal_kinematic_target: torch.Tensor = None#
- Simulation mesh kinematic targets for the deformable bodies. Shape is (num_instances, max_sim_vertices_per_body, 4). - The kinematic targets are used to drive the simulation mesh vertices to the target positions. The targets are stored as (x, y, z, is_not_kinematic) where “is_not_kinematic” is a binary flag indicating whether the vertex is kinematic or not. The flag is set to 0 for kinematic vertices and 1 for non-kinematic vertices. 
 - property nodal_pos_w#
- Nodal positions in simulation world frame. Shape is (num_instances, max_sim_vertices_per_body, 3). 
 - property nodal_vel_w#
- Nodal velocities in simulation world frame. Shape is (num_instances, max_sim_vertices_per_body, 3). 
 - property nodal_state_w#
- Nodal state - [nodal_pos, nodal_vel]in simulation world frame. Shape is (num_instances, max_sim_vertices_per_body, 6).
 - property sim_element_quat_w#
- Simulation mesh element-wise rotations as quaternions for the deformable bodies in simulation world frame. Shape is (num_instances, max_sim_elements_per_body, 4). - The rotations are stored as quaternions in the order (w, x, y, z). 
 - property collision_element_quat_w#
- Collision mesh element-wise rotations as quaternions for the deformable bodies in simulation world frame. Shape is (num_instances, max_collision_elements_per_body, 4). - The rotations are stored as quaternions in the order (w, x, y, z). 
 - property sim_element_deform_gradient_w#
- Simulation mesh element-wise second-order deformation gradient tensors for the deformable bodies in simulation world frame. Shape is (num_instances, max_sim_elements_per_body, 3, 3). 
 - property collision_element_deform_gradient_w#
- Collision mesh element-wise second-order deformation gradient tensors for the deformable bodies in simulation world frame. Shape is (num_instances, max_collision_elements_per_body, 3, 3). 
 - property sim_element_stress_w#
- Simulation mesh element-wise second-order Cauchy stress tensors for the deformable bodies in simulation world frame. Shape is (num_instances, max_sim_elements_per_body, 3, 3). 
 - property collision_element_stress_w#
- Collision mesh element-wise second-order Cauchy stress tensors for the deformable bodies in simulation world frame. Shape is (num_instances, max_collision_elements_per_body, 3, 3). 
 - property root_pos_w: torch.Tensor#
- Root position from nodal positions of the simulation mesh for the deformable bodies in simulation world frame. Shape is (num_instances, 3). - This quantity is computed as the mean of the nodal positions. 
 - property root_vel_w: torch.Tensor#
- Root velocity from vertex velocities for the deformable bodies in simulation world frame. Shape is (num_instances, 3). - This quantity is computed as the mean of the nodal velocities. 
 
- class isaaclab.assets.DeformableObjectCfg[源代码]#
- 基类: - AssetBaseCfg- Configuration parameters for a deformable object. - Classes: - Initial state of the asset. - Attributes: - Prim path (or expression) to the asset. - Spawn configuration for the asset. - Initial state of the rigid object. - Collision group of the asset. - Whether to enable debug visualization for the asset. - The configuration object for the visualization markers. - class InitialStateCfg#
- 基类: - object- Initial state of the asset. - This defines the default initial state of the asset when it is spawned into the simulation, as well as the default state when the simulation is reset. - After parsing the initial state, the asset class stores this information in the - dataattribute of the asset class. This can then be accessed by the user to modify the state of the asset during the simulation, for example, at resets.- Attributes: - Position of the root in simulation world frame. - Quaternion rotation (w, x, y, z) of the root in simulation world frame. 
 - prim_path: str#
- Prim path (or expression) to the asset. - 备注 - The expression can contain the environment namespace regex - {ENV_REGEX_NS}which will be replaced with the environment namespace.- Example: - {ENV_REGEX_NS}/Robotwill be replaced with- /World/envs/env_.*/Robot.
 - spawn: SpawnerCfg | None#
- Spawn configuration for the asset. Defaults to None. - If None, then no prims are spawned by the asset class. Instead, it is assumed that the asset is already present in the scene. 
 - init_state: InitialStateCfg#
- Initial state of the rigid object. Defaults to identity pose. 
 - collision_group: Literal[0, -1]#
- Collision group of the asset. Defaults to - 0.- -1: global collision group (collides with all assets in the scene).
- 0: local collision group (collides with other assets in the same environment).
 
 - visualizer_cfg: VisualizationMarkersCfg#
- The configuration object for the visualization markers. Defaults to DEFORMABLE_TARGET_MARKER_CFG. - 备注 - This attribute is only used when debug visualization is enabled. 
 
 
    