From 766776eeb2fac939647b3fbefa73e4061ec7bed2 Mon Sep 17 00:00:00 2001 From: cremebrule <84cremebrule@gmail.com> Date: Sat, 5 Oct 2024 18:16:32 -0700 Subject: [PATCH 1/3] fix robot disabled self collisions, standardize all to have self_collisions=True by default --- omnigibson/robots/a1.py | 6 ++--- omnigibson/robots/articulated_trunk_robot.py | 2 +- omnigibson/robots/fetch.py | 2 +- omnigibson/robots/holonomic_base_robot.py | 2 +- omnigibson/robots/locobot.py | 12 +++++++++ omnigibson/robots/manipulation_robot.py | 2 +- .../robots/mobile_manipulation_robot.py | 2 +- omnigibson/robots/r1.py | 5 +++- omnigibson/robots/robot_base.py | 2 +- omnigibson/robots/stretch.py | 7 +++++ omnigibson/robots/tiago.py | 2 +- omnigibson/robots/turtlebot.py | 26 +++++++++++++++++++ omnigibson/robots/untucked_arm_pose_robot.py | 2 +- 13 files changed, 60 insertions(+), 12 deletions(-) diff --git a/omnigibson/robots/a1.py b/omnigibson/robots/a1.py index d9a6c8faf..b226bd3e5 100644 --- a/omnigibson/robots/a1.py +++ b/omnigibson/robots/a1.py @@ -218,7 +218,7 @@ def assisted_grasp_end_points(self): @property def disabled_collision_pairs(self): # some dexhand has self collisions that needs to be filtered out + pairs = [["base_link", "connector"]] if self.end_effector == "inspire": - return [["base_link", "link12"]] - else: - return [] + pairs.append(["base_link", "link12"]) + return pairs diff --git a/omnigibson/robots/articulated_trunk_robot.py b/omnigibson/robots/articulated_trunk_robot.py index 78be01aa0..628cd6cbd 100644 --- a/omnigibson/robots/articulated_trunk_robot.py +++ b/omnigibson/robots/articulated_trunk_robot.py @@ -34,7 +34,7 @@ def __init__( scale=None, visible=True, visual_only=False, - self_collisions=False, + self_collisions=True, load_config=None, fixed_base=False, # Unique to USDObject hierarchy diff --git a/omnigibson/robots/fetch.py b/omnigibson/robots/fetch.py index ad1e15aad..ec706bc36 100644 --- a/omnigibson/robots/fetch.py +++ b/omnigibson/robots/fetch.py @@ -32,7 +32,7 @@ def __init__( scale=None, visible=True, visual_only=False, - self_collisions=False, + self_collisions=True, load_config=None, fixed_base=False, # Unique to USDObject hierarchy diff --git a/omnigibson/robots/holonomic_base_robot.py b/omnigibson/robots/holonomic_base_robot.py index d93abc5b2..da8d9ac2a 100644 --- a/omnigibson/robots/holonomic_base_robot.py +++ b/omnigibson/robots/holonomic_base_robot.py @@ -40,7 +40,7 @@ def __init__( visible=True, fixed_base=False, visual_only=False, - self_collisions=False, + self_collisions=True, load_config=None, # Unique to USDObject hierarchy abilities=None, diff --git a/omnigibson/robots/locobot.py b/omnigibson/robots/locobot.py index 67a1b57c1..ff753c6fa 100644 --- a/omnigibson/robots/locobot.py +++ b/omnigibson/robots/locobot.py @@ -35,3 +35,15 @@ def usd_path(self): @property def urdf_path(self): return os.path.join(gm.ASSET_PATH, "models/locobot/locobot.urdf") + + @property + def disabled_collision_pairs(self): + # badly modeled gripper collision meshes + return [ + ["base_link", "arm_base_link"], + ["base_link", "plate_2"], + ["cam_mount", "forearm_link"], + ["cam_mount", "elbow_link"], + ["cam_mount", "plate_1"], + ["cam_mount", "plate_2"], + ] diff --git a/omnigibson/robots/manipulation_robot.py b/omnigibson/robots/manipulation_robot.py index de8b6d954..527334b12 100644 --- a/omnigibson/robots/manipulation_robot.py +++ b/omnigibson/robots/manipulation_robot.py @@ -70,7 +70,7 @@ def __init__( visible=True, fixed_base=False, visual_only=False, - self_collisions=False, + self_collisions=True, load_config=None, # Unique to USDObject hierarchy abilities=None, diff --git a/omnigibson/robots/mobile_manipulation_robot.py b/omnigibson/robots/mobile_manipulation_robot.py index 9a9cec5c3..957abf26d 100644 --- a/omnigibson/robots/mobile_manipulation_robot.py +++ b/omnigibson/robots/mobile_manipulation_robot.py @@ -33,7 +33,7 @@ def __init__( scale=None, visible=True, visual_only=False, - self_collisions=False, + self_collisions=True, load_config=None, fixed_base=False, # Unique to USDObject hierarchy diff --git a/omnigibson/robots/r1.py b/omnigibson/robots/r1.py index 94c5559df..b687fd7d4 100644 --- a/omnigibson/robots/r1.py +++ b/omnigibson/robots/r1.py @@ -27,7 +27,7 @@ def __init__( scale=None, visible=True, visual_only=False, - self_collisions=False, + self_collisions=True, load_config=None, # Unique to USDObject hierarchy abilities=None, @@ -254,4 +254,7 @@ def disabled_collision_pairs(self): return [ ["left_gripper_link1", "left_gripper_link2"], ["right_gripper_link1", "right_gripper_link2"], + ["base_link", "wheel_link1"], + ["base_link", "wheel_link2"], + ["base_link", "wheel_link3"], ] diff --git a/omnigibson/robots/robot_base.py b/omnigibson/robots/robot_base.py index 2feb288f6..c03253e7f 100644 --- a/omnigibson/robots/robot_base.py +++ b/omnigibson/robots/robot_base.py @@ -56,7 +56,7 @@ def __init__( visible=True, fixed_base=False, visual_only=False, - self_collisions=False, + self_collisions=True, load_config=None, # Unique to USDObject hierarchy abilities=None, diff --git a/omnigibson/robots/stretch.py b/omnigibson/robots/stretch.py index a8e8bf39b..bb48eabc0 100644 --- a/omnigibson/robots/stretch.py +++ b/omnigibson/robots/stretch.py @@ -117,9 +117,14 @@ def disabled_collision_pairs(self): ["link_arm_l4", "link_arm_l3"], ["link_arm_l4", "link_arm_l2"], ["link_arm_l4", "link_arm_l1"], + ["link_arm_l4", "link_aruco_inner_wrist"], ["link_arm_l3", "link_arm_l2"], ["link_arm_l3", "link_arm_l1"], + ["link_arm_l3", "link_aruco_top_wrist"], + ["link_arm_l3", "link_aruco_inner_wrist"], ["link_arm_l2", "link_arm_l1"], + ["link_arm_l2", "link_aruco_top_wrist"], + ["link_arm_l2", "link_aruco_inner_wrist"], ["link_arm_l0", "link_arm_l1"], ["link_arm_l0", "link_arm_l2"], ["link_arm_l0", "link_arm_l3"], @@ -131,6 +136,8 @@ def disabled_collision_pairs(self): ["link_arm_l0", "link_wrist_yaw_bottom"], ["link_arm_l0", "link_wrist_pitch"], ["link_wrist_yaw_bottom", "link_wrist_pitch"], + ["link_wrist_yaw_bottom", "link_arm_l4"], + ["link_wrist_yaw_bottom", "link_arm_l3"], ["gripper_camera_link", "link_gripper_s3_body"], ["link_gripper_s3_body", "link_aruco_d405"], ["link_gripper_s3_body", "link_gripper_finger_left"], diff --git a/omnigibson/robots/tiago.py b/omnigibson/robots/tiago.py index 92abfe3c1..970d6c2fe 100644 --- a/omnigibson/robots/tiago.py +++ b/omnigibson/robots/tiago.py @@ -31,7 +31,7 @@ def __init__( scale=None, visible=True, visual_only=False, - self_collisions=False, + self_collisions=True, load_config=None, # Unique to USDObject hierarchy abilities=None, diff --git a/omnigibson/robots/turtlebot.py b/omnigibson/robots/turtlebot.py index f6bac0fde..f545103c4 100644 --- a/omnigibson/robots/turtlebot.py +++ b/omnigibson/robots/turtlebot.py @@ -36,3 +36,29 @@ def usd_path(self): @property def urdf_path(self): return os.path.join(gm.ASSET_PATH, "models/turtlebot/turtlebot.urdf") + + @property + def disabled_collision_pairs(self): + # badly modeled gripper collision meshes + return [ + ["plate_bottom_link", "pole_middle_0_link"], + ["plate_bottom_link", "pole_middle_2_link"], + ["plate_middle_link", "pole_top_3_link"], + ["plate_middle_link", "pole_kinect_0_link"], + ["plate_middle_link", "pole_kinect_1_link"], + ["plate_middle_link", "pole_top_1_link"], + ["plate_middle_link", "pole_middle_0_link"], + ["plate_middle_link", "pole_middle_1_link"], + ["plate_middle_link", "pole_middle_2_link"], + ["plate_middle_link", "pole_middle_3_link"], + ["plate_top_link", "pole_top_0_link"], + ["plate_top_link", "pole_top_1_link"], + ["plate_top_link", "pole_top_2_link"], + ["plate_top_link", "pole_top_3_link"], + ["pole_top_0_link", "pole_middle_0_link"], + ["pole_top_0_link", "plate_middle_link"], + ["pole_top_1_link", "pole_middle_1_link"], + ["pole_top_2_link", "pole_middle_2_link"], + ["pole_top_2_link", "plate_middle_link"], + ["pole_top_3_link", "pole_middle_3_link"], + ] diff --git a/omnigibson/robots/untucked_arm_pose_robot.py b/omnigibson/robots/untucked_arm_pose_robot.py index ba96089f6..8acbb3d7c 100644 --- a/omnigibson/robots/untucked_arm_pose_robot.py +++ b/omnigibson/robots/untucked_arm_pose_robot.py @@ -28,7 +28,7 @@ def __init__( scale=None, visible=True, visual_only=False, - self_collisions=False, + self_collisions=True, load_config=None, fixed_base=False, # Unique to USDObject hierarchy From bba6d88f68c70b21385760f4c2bcda2371a300d1 Mon Sep 17 00:00:00 2001 From: cremebrule <84cremebrule@gmail.com> Date: Sat, 5 Oct 2024 18:16:45 -0700 Subject: [PATCH 2/3] update robot control example for consistent controller ordering --- omnigibson/examples/robots/robot_control_example.py | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/omnigibson/examples/robots/robot_control_example.py b/omnigibson/examples/robots/robot_control_example.py index 35747cd92..92a664e81 100644 --- a/omnigibson/examples/robots/robot_control_example.py +++ b/omnigibson/examples/robots/robot_control_example.py @@ -44,15 +44,19 @@ def choose_controllers(robot, random_selection=False): default_config = robot._default_controller_config # Iterate over all components in robot - for component, controller_options in default_config.items(): + controller_names = robot.controller_order + for controller_name in controller_names: + controller_options = default_config[controller_name] # Select controller options = list(sorted(controller_options.keys())) choice = choose_from_options( - options=options, name="{} controller".format(component), random_selection=random_selection + options=options, + name=f"{controller_name} controller", + random_selection=random_selection, ) # Add to user responses - controller_choices[component] = choice + controller_choices[controller_name] = choice return controller_choices From 5b6ac5ae84471c37f65b61ae49f843b0a7213c2c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cem=20G=C3=B6kmen?= Date: Thu, 10 Oct 2024 16:24:29 -0700 Subject: [PATCH 3/3] Make following arm targets in empty_action optional --- .../starter_semantic_action_primitives.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/omnigibson/action_primitives/starter_semantic_action_primitives.py b/omnigibson/action_primitives/starter_semantic_action_primitives.py index 7bd5e6878..05fa48131 100644 --- a/omnigibson/action_primitives/starter_semantic_action_primitives.py +++ b/omnigibson/action_primitives/starter_semantic_action_primitives.py @@ -1450,17 +1450,20 @@ def _get_head_goal_q(self, target_obj_pose): return [head1_joint_goal, head2_joint_goal] - def _empty_action(self): + def _empty_action(self, follow_arm_targets=True): """ Generate a no-op action that will keep the robot still but aim to move the arms to the saved pose targets, if possible + Args: + follow_arm_targets (bool): Whether to move the arms to the saved pose targets or keep them still. + Returns: th.tensor or None: Action array for one step for the robot to do nothing """ action = th.zeros(self.robot.action_dim) for name, controller in self.robot._controllers.items(): # if desired arm targets are available, generate an action that moves the arms to the saved pose targets - if name in self._arm_targets: + if follow_arm_targets and name in self._arm_targets: if isinstance(controller, InverseKinematicsController): arm = name.replace("arm_", "") target_pos, target_orn_axisangle = self._arm_targets[name]