Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/guarded motion added distance until edge up #1199

Open
wants to merge 6 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
#!/usr/bin/env python
import rospy

from robot_skills.util.robot_constructor import robot_constructor
from robot_skills.get_robot import get_robot

rospy.init_node('test_mode_down_until_force_sensor_edge_up', anonymous=True)
robot = robot_constructor("hero")
robot = get_robot("hero")
arm = robot.get_arm(force_sensor_required=True)

arm.move_down_until_force_sensor_edge_up()
5 changes: 3 additions & 2 deletions robot_skills/src/robot_skills/arm/arms.py
Original file line number Diff line number Diff line change
Expand Up @@ -174,10 +174,11 @@ def has_force_sensor(self):
"Specify get_arm(..., force_sensor_required=True)")
return hasattr(self._arm, "force_sensor")

def move_down_until_force_sensor_edge_up(self, timeout=10, retract_distance=0.01):
def move_down_until_force_sensor_edge_up(self, timeout=10, retract_distance=0.01, distance_move_down=2.0):
P-ict0 marked this conversation as resolved.
Show resolved Hide resolved
self._test_die(self.has_force_sensor, 'has_force_sensor=' + str(self.has_force_sensor),
"Specify get_arm(..., force_sensor_required=True)")
return self._arm.move_down_until_force_sensor_edge_up(timeout=timeout, retract_distance=retract_distance)
return self._arm.move_down_until_force_sensor_edge_up(timeout=timeout, retract_distance=retract_distance,
distance_move_down=distance_move_down)

# salvaged deprecated functionality
def send_gripper_goal(self, state, timeout=5.0, gripper_type=None, max_torque=0.1):
Expand Down
52 changes: 39 additions & 13 deletions robot_skills/src/robot_skills/functionalities/arm/guarded_motion.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,55 +11,81 @@ class GuardedMotionFunc(RobotFunc):
def __init__(self):
super(GuardedMotionFunc, self).__init__("guarded_motion",
Arm,
{"move_down_until_force_sensor_edge_up": move_down_until_force_sensor_edge_up,
"_create_lower_force_sensing_goal": _create_lower_force_sensing_goal,
"_create_retract_force_sensing_goal": _create_retract_force_sensing_goal})
{
"move_down_until_force_sensor_edge_up": move_down_until_force_sensor_edge_up,
"_create_lower_force_sensing_goal": _create_lower_force_sensing_goal,
"_create_retract_force_sensing_goal": _create_retract_force_sensing_goal
})

def check_requirements(self, arm):
"Check that the arm has at least one force sensor"
"""
Check that the arm has at least one force sensor
"""
for part in arm.parts:
if isinstance(arm.parts[part], ForceSensor):
return True
return False


def move_down_until_force_sensor_edge_up(self, force_sensor=None, timeout=10, retract_distance=0.01):
def move_down_until_force_sensor_edge_up(self, force_sensor=None, timeout=10, retract_distance=0.01,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think the final position is more interesting than the distance to move down.

Copy link
Contributor Author

@P-ict0 P-ict0 Jun 22, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree, I thought of adding the distance to move down first before working on the final position since this requires to calculate at what height the force sensor is. I think the final point is an interesting feature for me to work on in the future

distance_move_down=None):
"""
Move down the arm (hero specific, only joint arm_lift_joint) until the force sensor detects an edge up
Move down the arm (hero specific, only joint arm_lift_joint) until one of 3 things:
- Force sensor detects an edge up
- Timeout
- Force sensor has moved down the distance specified

A 'force_sensor.TimeOutException' will be raised if no edge up is detected within timeout

:param force_sensor: ForceSensor of the arm
:param timeout: Max duration for edge up detection
:param retract_distance: How much to retract if we have reached a surface
:param distance_move_down: How much to move down until we reach a surface
"""
if not force_sensor:
if force_sensor is None:
force_sensor = self.parts["force_sensor"]

# Fill with required joint names (desired in hardware / gazebo impl)
goal = self._create_lower_force_sensing_goal(timeout)
goal = self._create_lower_force_sensing_goal(distance_move_down, timeout)
self._ac_joint_traj.send_goal(goal)

force_sensor.wait_for_edge_up(timeout)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The behaviour we currently create will wait for the timeout if its end goal is reached. So it might be waiting at the lower position without continuing.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think this is acceptable

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Isn't this the same behaviour as before? but with a different distance to move down.

self.cancel_goals()

goal = self._create_retract_force_sensing_goal(0.5, timeout)
goal = self._create_retract_force_sensing_goal(retract_distance, timeout)
self._ac_joint_traj.send_goal(goal)


def _create_lower_force_sensing_goal(self, timeout):
def _create_lower_force_sensing_goal(self, distance_move_down, timeout):
# Gets current joint state
P-ict0 marked this conversation as resolved.
Show resolved Hide resolved
current_joint_state = self.get_joint_states()
current_joint_state['arm_lift_joint'] = 0 # TODO make this function not HERO-specific

# Sets the joint state to move down a certain distance (or 0 if distance is not set)
if distance_move_down is not None:
current_joint_state['arm_lift_joint'] = max(0, current_joint_state['arm_lift_joint'] - distance_move_down)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

0 should be the lower limit of the joint.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

0 is the lowest the arm lift joint state value can be. With the distance_move_down it can be greater than 0

else:
current_joint_state['arm_lift_joint'] = 0 # TODO make this function not HERO-specific
P-ict0 marked this conversation as resolved.
Show resolved Hide resolved

# Creates goal for force_sensor
return create_force_sensing_goal(self.joint_names, current_joint_state, timeout)


def _create_retract_force_sensing_goal(self, retract_distance, timeout):
# Gets current joint states
P-ict0 marked this conversation as resolved.
Show resolved Hide resolved
current_joint_state = self.get_joint_states()
current_joint_state['arm_lift_joint'] += retract_distance # TODO make this function not HERO-specific

# Changes state to retract arm after force sensor edge up
current_joint_state['arm_lift_joint'] += retract_distance # TODO make this function not HERO-specific

# Creates joint states goal
return create_force_sensing_goal(self.joint_names, current_joint_state, timeout)


def create_force_sensing_goal(joint_names, current_joint_state, timeout):
positions = [current_joint_state[n] for n in joint_names]
positions = []
P-ict0 marked this conversation as resolved.
Show resolved Hide resolved
for name in joint_names:
positions.append(current_joint_state[name])

points = [JointTrajectoryPoint(
positions=positions,
time_from_start=rospy.Duration.from_sec(timeout))
Expand Down