00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037 import roslib; roslib.load_manifest('pr2_plugs_actions')
00038 import rospy
00039 import actionlib
00040
00041 from pr2_controllers_msgs.msg import *
00042 from pr2_plugs_msgs.msg import *
00043 from actionlib_msgs.msg import *
00044 from trajectory_msgs.msg import JointTrajectoryPoint
00045 from geometry_msgs.msg import *
00046 import dynamic_reconfigure.client
00047 from stereo_wall_detection.srv import *
00048
00049
00050 class DetectWallNormServer:
00051 def __init__(self, name):
00052 self.name = name
00053
00054 self.head_client = actionlib.SimpleActionClient('head_traj_controller/point_head_action', PointHeadAction)
00055 self.head_client.wait_for_server()
00056
00057 rospy.wait_for_service('stereo_wall_detection/detect_wall')
00058 rospy.loginfo('detect wall service found')
00059 self.detect_wall_srv = rospy.ServiceProxy('stereo_wall_detection/detect_wall', DetectWall)
00060 self.server = actionlib.simple_action_server.SimpleActionServer(self.name, DetectWallNormAction, self.execute_cb)
00061
00062 self.projector_client = dynamic_reconfigure.client.Client('camera_synchronizer_node')
00063 self.projector_on = {'narrow_stereo_trig_mode': 3}
00064 self.projector_off = {'narrow_stereo_trig_mode': 4}
00065 self.projector_sub = rospy.Subscriber("projector_controller/rising_edge_timestamps", rospy.Header, self.projector_cb)
00066
00067
00068
00069 def execute_cb(self, goal):
00070 rospy.loginfo('detect wall norm')
00071
00072
00073 point_head_goal = PointHeadGoal()
00074 point_head_goal.target.header.frame_id = goal.look_point.header.frame_id
00075 point_head_goal.target.point.x = goal.look_point.point.x
00076 point_head_goal.target.point.y = goal.look_point.point.y
00077 point_head_goal.target.point.z = goal.look_point.point.z
00078 point_head_goal.pointing_frame = 'head_tilt_link'
00079 point_head_goal.pointing_axis.x = 1
00080 point_head_goal.pointing_axis.y = 0
00081 point_head_goal.pointing_axis.z = 0
00082
00083 self.head_client.send_goal(point_head_goal)
00084 self.head_client.wait_for_result(rospy.Duration(20.0))
00085 if self.head_client.get_state() != GoalStatus.SUCCEEDED:
00086 rospy.logerr('%s: Failed to move the head', self.name)
00087 self.server.set_aborted()
00088 return
00089
00090
00091 rospy.loginfo('turn on projector')
00092 self.projector_ready = False
00093 while not self.turn_projector_on():
00094 rospy.loginfo('still trying to turn on projector')
00095 rospy.sleep(1.0)
00096 while not self.projector_ready:
00097 rospy.sleep(1.0)
00098 rospy.loginfo('waiting for projector to be ready')
00099 rospy.loginfo('projector truned on')
00100
00101
00102 try:
00103 rospy.loginfo('Call stereo wall detector')
00104 wall = self.detect_wall_srv(DetectWallRequest())
00105 rospy.loginfo('Call stereo wall detector succeeded')
00106 except rospy.ServiceException, e:
00107 rospy.logerr("Service call to wall detector failed")
00108 while not self.turn_projector_off():
00109 rospy.loginfo('still trying to turn off projector')
00110 rospy.sleep(1.0)
00111 self.server.set_aborted()
00112 return
00113
00114
00115 rospy.loginfo('turn off projector')
00116 while not self.turn_projector_off():
00117 rospy.loginfo('still trying to turn off projector')
00118 rospy.sleep(1.0)
00119 result = DetectWallNormResult()
00120 result.wall_norm = wall.wall_norm
00121 result.wall_point = wall.wall_point
00122 self.server.set_succeeded(result)
00123
00124 def projector_cb(self, data):
00125 if(not self.server.is_active()):
00126 self.projector_ready = False
00127 return
00128
00129 self.projector_ready = True
00130
00131 def turn_projector_on(self):
00132 try:
00133 self.projector_client.update_configuration(self.projector_on)
00134 return True
00135 except rospy.ServiceException, e:
00136 rospy.logerr('Failed to turn projector on')
00137 return False
00138
00139 def turn_projector_off(self):
00140 try:
00141 self.projector_client.update_configuration(self.projector_off)
00142 return True
00143 except rospy.ServiceException, e:
00144 rospy.logerr('Failed to turn projector off')
00145 return False
00146
00147
00148
00149 if __name__ == '__main__':
00150
00151
00152
00153 name ='detect_wall_norm'
00154 rospy.init_node(name)
00155 detect_wall_norm_server = DetectWallNormServer(name)
00156 rospy.loginfo('%s: Action server running', name)
00157 rospy.spin()