Пример #1
0
	def run(self):

		req = TriggerRequest()

		if self.sensor_states[self.BUTTON_G1] == True:
			self.trigger_button_g1(req)
		
		if self.sensor_states[self.BUTTON_R1] == True:
			self.trigger_button_r1(req)

		if self.sensor_states[self.BUTTON_G2] == True:
			self.trigger_button_g2(req)
		
		if self.sensor_states[self.BUTTON_R2] == True:
			self.trigger_button_r2(req)


		req_state = SetBoolRequest()

		req_state.data = self.sensor_states[self.CELL_1]
		self.state_cell_1(req_state)

		req_state.data = self.sensor_states[self.CELL_2]
		self.state_cell_2(req_state)

		req_state.data = self.sensor_states[self.CELL_3]
		self.state_cell_3(req_state)	
Пример #2
0
 def joy_cb(self, msg):
     if msg.buttons[5] == 1:  # Autonomous control
         req = SetBoolRequest()
         req.data = False
         resp = self.anto_srv(req)
     elif msg.buttons[4] == 1:  # Human control
         req = SetBoolRequest()
         req.data = True
         resp = self.anto_srv(req)
Пример #3
0
 def joy_cb(self, msg):
     if msg.buttons[1] == 1:
         req = SetBoolRequest()
         req.data = False
         resp = self.anto_srv(req)
     elif msg.buttons[3] == 1:
         req = SetBoolRequest()
         req.data = True
         resp = self.anto_srv(req)
Пример #4
0
    def execute(self, userdata):
        arbitrary = input("pressToContinue")
        realsense_request = SetBoolRequest()
        kinect_request = String()
        kinfu_reset_request = Empty()
        kinfu_change_camera_request = EmptyRequest()

        if self.action_ == 'realsense_off_kinect_on':
            realsense_request.data = False
            kinect_request.data = 'on'
            rospy.set_param('/ros_kinfu/depth_image_topic',
                            '/kinect2/qhd/image_depth_rect')
            rospy.set_param('/ros_kinfu/rgb_image_topic',
                            '/kinect2/qhd/image_color')
            rospy.set_param('/ros_kinfu/camera_info_topic',
                            '/kinect2/qhd/camera_info')
            rospy.set_param('/ros_kinfu/camera_frame_id',
                            '/kinect2_rgb_optical_frame')
            rospy.set_param('/ros_kinfu/volume_size', 1.0)

        elif self.action_ == 'realsense_on_kinect_off':
            realsense_request.data = True
            kinect_request.data = 'off'
            rospy.set_param('/ros_kinfu/depth_image_topic',
                            '/realsense/depth/image_raw')
            rospy.set_param('/ros_kinfu/rgb_image_topic',
                            '/realsense/rgb_depth_aligned/image_raw')
            rospy.set_param('/ros_kinfu/camera_info_topic',
                            '/realsense/depth/camera_info')
            rospy.set_param('/ros_kinfu/camera_frame_id',
                            '/camera_depth_optical_frame')
            rospy.set_param('/ros_kinfu/volume_size', 0.85)

        else:
            return 'failed'

        try:
            response_realsense = self.realsense_service.call(realsense_request)
        except:
            return 'failed'

        self.kinect_pub.publish(kinect_request)
        while not self.camera_info_received:
            print "Waiting for CameraInfo"
        print self.camera_info_msg
        self.objprop_change_camera_srv.call(self.camera_info_msg)
        self.kinfu_reset_pub.publish(kinfu_reset_request)
        # self.kinfu_change_camera_srv(kinfu_change_camera_request)
        self.camera_info_received = False

        if response_realsense.success:
            return 'succeeded'
        else:
            return 'failed'
Пример #5
0
 def start_navigation(self, isTrue):
     set_bool = SetBoolRequest()
     if isTrue:
         set_bool.data = True
     else:
         set_bool.data = False
     try:
         srv = rospy.ServiceProxy('start_navigation', SetBool)
         resp = srv(set_bool)
         return resp
     except rospy.ServiceException, e:
         print "Service call failed: %s" % e
 def set_ring_light(self, value=True):
     req = SetBoolRequest()
     req.data = value
     try:
         self.ring_light_srv.call(req)
     except:
         rospy.logwarn('ring_light_switch not available')
    def execute_toggle_lip(self):
        # try to call the service
        req = SetBoolRequest()
        if self.action_ is 'lip_on':
            req.data = True
        elif self.action_ is 'lip_off':
            req.data = False

        try:
            response = self.service.call(req)
            rospy.loginfo('Lip has been toggled on/off')
            return 'succeeded'
        except Exception, e:
            rospy.logerr('Service call to toggle_lip failed. Reason: \n %s' %
                         e)
            return 'failed'
 def execute(self,userdata):
     userdata.slaves=dict()     
     for base in self.__base_namespaces:            
         userdata.slaves[base]=dict()
         #Load reference vectors as poses
         try:
             ref=rospy.get_param(base+"/slave_controller/reference")
             ref_pose=PoseStamped()
             ref_pose.pose.position.x=ref[0]
             ref_pose.pose.position.y=ref[1]
             ref_pose.pose.position.z=0.0
             quat=transformations.quaternion_from_euler(0.0,0.0,ref[2])
             ref_pose.pose.orientation.x=quat[0]
             ref_pose.pose.orientation.y=quat[1]
             ref_pose.pose.orientation.z=quat[2]
             ref_pose.pose.orientation.w=quat[3]
             userdata.slaves[base]["reference"]=ref_pose
         except:
             return "references_error"
     if self.__enable_manipulator:
         req=SetBoolRequest()
         req.data=False
         self.__gripper_clients.call(req)
         self.__formation_disabler.call(EmptyRequest())
         self.__arm_controller.call(self.__arm_request)
     return "startup_done"
Пример #9
0
 def set_joint_torque(self, state):
     req = SetBoolRequest()
     req.data = state
     try:
         self.set_joint_torque_client(req)
     except rospy.ServiceException, e:
         print "Service call failed: %s"%e
    def step(self):
        msg_str = self.recvStrFromProcessing()
        if msg_str != "none":
            msg_str = msg_str.split(',')
            print msg_str
            if msg_str[0] == 'GOALS_READY':
                self.send_autonomy_goals_to_processing_service()
                self.send_human_goals_to_processing_service()
            elif msg_str[0] == 'GOALS_RESET':
                msg = String("goals_reset")
                self.goals_reset_pub.publish(msg)
                #reset all goals.
                self.reset_num_goals()
                self.reset_autonomy_goals()
                self.reset_human_goals()
                self.send_autonomy_goals_to_processing_service()
                self.send_human_goals_to_processing_service()

                #reset autonomy and human robot pose.
                self.reset_autonomy_robot()
                self.reset_human_robot()
                self.send_autonomy_robot_pose_to_processing_service()
                self.send_human_robot_pose_to_processing_service()

            elif msg_str[0] == 'BEGIN_TRIAL':
                msg = String("begin_trial")
                self.begin_trial_pub.publish(msg)

                trigger_msg = SetBoolRequest()
                trigger_msg.data = True
                self.autonomy_node_trigger_trial(trigger_msg)

            elif msg_str[0] == 'END_TRIAL':
                trigger_msg = SetBoolRequest()
                trigger_msg.data = False
                self.autonomy_node_trigger_trial(trigger_msg)

                msg = String("end_trial")
                self.end_trial_pub.publish(msg)

            elif msg_str[0] == 'ROBOT_READY':
                msg = String("session_init")
                self.session_init_pub.publish(msg)

                self.send_autonomy_robot_pose_to_processing_service()
                self.send_human_robot_pose_to_processing_service()
Пример #11
0
    def click_led_open(self):
        client = rospy.ServiceProxy("/zxcar/led", SetBool)
        client.wait_for_service()

        request = SetBoolRequest()
        request.data = True
        client.call(request)

        client.close()
Пример #12
0
    def click_buzzer_close(self):
        client = rospy.ServiceProxy("/zxcar/buzzer", SetBool)
        client.wait_for_service()

        request = SetBoolRequest()
        request.data = False
        client.call(request)

        client.close()
    def stop_mission(self):
        try:
            req = SetBoolRequest()
            req.data = False
            self.activate_planner_service(req)
            print "Mission has been stopped!"

        except rospy.ServiceException, e:
            print("Failed calling stop_mission service")
Пример #14
0
 def start_navigation(self):
     rospy.loginfo("SRV: Start Navigation")
     set_bool = SetBoolRequest()
     set_bool.data = True
     try:
         srv = rospy.ServiceProxy('start_navigation', SetBool)
         resp = srv(set_bool)
         return resp
     except rospy.ServiceException, e:
         print "Service call failed: %s" % e
 def set(self, data):
     req = SetBoolRequest()
     req.data = data
     success = False
     resp = None
     while not success:
         resp =  self.proxy(req)
         success = resp.success
         self.rate.sleep()
     return resp
    def start_mission(self):
        if self.state == State.FLYING_AUTO:
            try:
                req = SetBoolRequest()
                req.data = True
                self.activate_planner_service(req)
                print "Mission has started!"

            except rospy.ServiceException, e:
                print("Failed calling start_mission service")
Пример #17
0
 def resetNavigation(self):
     self.start_navigation = False
     self.set_path_succ = False
     set_bool = SetBoolRequest()
     set_bool.data = True
     try:
         srv = rospy.ServiceProxy('reset_goals', SetBool)
         resp = srv(set_bool)
         return resp
     except rospy.ServiceException, e:
         print "Service call failed: %s" % e
Пример #18
0
    def _handle_foodload(self, req):
        rospy.logdebug("Request of LoadFood Recieved..Processing")
        calibration_req = SetBoolRequest()
        calibration_req.data = req.data
        cal_response = self._calibrate_load_sensor_client(calibration_req)

        rospy.logdebug("Calibration complete!")
        response = SetBoolResponse()
        response.success = cal_response.success
        response.message = cal_response.message
        return response
Пример #19
0
 def srv_dive(self):
     #rospy.wait_for_service('/set_path')
     rospy.loginfo("SRV: Send diving")
     set_bool = SetBoolRequest()
     set_bool.data = True
     try:
         srv = rospy.ServiceProxy('dive', SetBool)
         resp = srv(set_bool)
         return resp
     except rospy.ServiceException, e:
         print "Service call failed: %s" % e
Пример #20
0
async def main() -> None:
    async with aioros.init_node("set_bool_client"):
        async with aioros.create_client(
            "/set_bool", SetBool, persistent=True
        ) as client:
            request = SetBoolRequest(True)
            while True:
                result = await client.call(request)
                request.data = not request.data

                logger.info("Result: %s", result)
                await anyio.sleep(1)
Пример #21
0
 def srv_got_signal(self):
     #rospy.wait_for_service('/set_path')
     rospy.loginfo("SRV: Got signal")
     set_bool = SetBoolRequest()
     set_bool.data = False
     try:
         srv = rospy.ServiceProxy('no_signal', SetBool)
         resp = srv(set_bool)
         self.send_no_signal = False
         return resp
     except rospy.ServiceException, e:
         print "Service call failed: %s"%e
Пример #22
0
	def finish_diving(self):
		#rospy.wait_for_service('/set_path')
		rospy.loginfo("SRV: Send finish diving")
		set_bool = SetBoolRequest()
		set_bool.data = True
		try:
			srv = rospy.ServiceProxy('finish_diving', SetBool)
			resp = srv(set_bool)
			self.start_diving = False
			return resp
		except rospy.ServiceException, e:
			print "Service call failed: %s"%e
Пример #23
0
    def execute(self, userdata):
        if self.__enable_orientation_ff:
            self.__orientation_init.call(EmptyRequest())

        req = SwitchControllerRequest()
        req.stop_controllers = []
        req.start_controllers = ["compliance_controller"]
        req.strictness = 2
        self.__switcher.call(req)

        grip_req = SetBoolRequest()
        grip_req.data = True
        self.__clients.call(grip_req)
        return "linked"
Пример #24
0
    def execute(self, userdata):
        grip_req = SetBoolRequest()
        grip_req.data = False
        self.__clients.call(grip_req)
        rospy.sleep(2)

        req = SwitchControllerRequest()
        req.stop_controllers = ["compliance_controller"]
        req.start_controllers = ["position_joint_controller"]
        req.strictness = 2
        self.__switcher.call(req)
        if self.__enable_orientation_ff:
            self.__orientation_init.call(EmptyRequest())

        return "released"
Пример #25
0
    def activate_joystick(self, activate):
        """Requests joystick activation/deactivation from joystick_guidance

        Args:
            activate (bool): True activates joystick, False deactivates
        """
        request = SetBoolRequest()
        request.data = activate

        try:
            self.activate_joystick_service(request)
            return True
        except rospy.ServiceException as exc:
            rospy.logerr(
                "Joystick activation service did not process request: " +
                str(exc))
            return False
    def go_home_cb(self, req):
        resp = SetBoolResponse()
        torque_require = SetBoolRequest()
        torque_require.data = True
        self.torque_enable_cb(torque_require)

        self.action_client.wait_for_server()
        self.action_goal.trajectory.header.stamp.secs = 0
        self.action_goal.trajectory.header.stamp.nsecs = 0

        point_tmp = JointTrajectoryPoint()
        position_tmp = []
        for i in xrange(len(self.controller_names)):
            position_tmp.append(0)
        point_tmp.positions = position_tmp
        point_tmp.time_from_start.secs = int(self.go_home_time)
        print len(self.action_goal.trajectory.points)
        self.action_goal.trajectory.points.append(point_tmp)
        self.action_client.send_goal(self.action_goal)
        self.action_client.wait_for_result()
        self.action_goal.trajectory.points = []

        resp.success = True
        return resp
Пример #27
0
 def enable_eStop(self):
     eStop_req = SetBoolRequest()
     eStop_req.data = True
     self.trigger_service(eStop_req)
Пример #28
0
 def disable_eStop(self):
     eStop_req = SetBoolRequest()
     eStop_req.data = False
     self.trigger_service(eStop_req)
Пример #29
0
    def __init__(self, name=None):

        moveit_commander.roscpp_initialize(sys.argv)

        self.robot = moveit_commander.RobotCommander()

        # Init moveit group
        self.group = moveit_commander.MoveGroupCommander('robot')
        self.arm_group = moveit_commander.MoveGroupCommander('arm')
        self.base_group = moveit_commander.MoveGroupCommander('base')

        self.scene = moveit_commander.PlanningSceneInterface()

        self.sce = moveit_python.PlanningSceneInterface('odom')
        self.pub_co = rospy.Publisher('collision_object',
                                      CollisionObject,
                                      queue_size=100)

        self.msg_print = SetBoolRequest()

        self.request_fk = rospy.ServiceProxy('/compute_fk', GetPositionFK)

        self.pub_co = rospy.Publisher('collision_object',
                                      CollisionObject,
                                      queue_size=100)

        sub_waypoint_status = rospy.Subscriber('execute_trajectory/status',
                                               GoalStatusArray,
                                               self.waypoint_execution_cb)
        sub_movegroup_status = rospy.Subscriber('execute_trajectory/status',
                                                GoalStatusArray,
                                                self.move_group_execution_cb)
        # sub_movegroup_status = rospy.Subscriber('move_group/status', GoalStatusArray, self.move_group_execution_cb)
        rospy.Subscriber("joint_states", JointState, self.further_ob_printing)

        #########################################################################
        rospy.Subscriber("/joint_states", JointState, self.joint_callback)
        rospy.Subscriber("/joint_states", JointState, self.eef_callback)
        self.tf_buffer = tf2_ros.Buffer()
        self.tf_listener = tf2_ros.TransformListener(self.tf_buffer)
        self.base_position_x = []
        self.base_position_y = []
        self.base_position_z = []
        self.eef_position_x = []
        self.eef_position_y = []
        self.eef_position_z = []
        self.position_time = []
        self.name = name
        self.js_0 = []
        self.js_1 = []
        self.js_2 = []
        self.js_time = []
        self.startime = datetime.datetime.now()
        self.mkdir('experiment_data' + '/' + name)
        #############################################################################
        msg_print = SetBoolRequest()
        msg_print.data = True

        self.re_position_x = []
        self.re_position_y = []

        self.waypoint_execution_status = 0
        self.move_group_execution_status = 0
        self.further_printing_number = 0
        self.pre_further_printing_number = 0

        # initial printing number
        self._printing_number = 0
        self._further_printing_number = 0
        self.future_printing_status = False

        self.current_printing_pose = None
        self.previous_printing_pose = None

        self.target_list = None

        self.group.allow_looking(1)
        self.group.allow_replanning(1)
        self.group.set_planning_time(10)

        # Initialize time record
        self.travel_time = 0
        self.planning_time = 0
        self.printing_time = 0

        # Initialize extruder

        extruder_publisher = rospy.Publisher('set_extruder_rate',
                                             Float32,
                                             queue_size=20)
        msg_extrude = Float32()
        msg_extrude = 5.0
        extruder_publisher.publish(msg_extrude)
        self.pub_rviz_marker = rospy.Publisher('/visualization_marker',
                                               Marker,
                                               queue_size=100)
        self.remove_all_rviz_marker()
        self.printing_number_rviz = 0
 def _call(self, monitoring_on_off_flag):
     req = SetBoolRequest()
     req.data = monitoring_on_off_flag
     resp = self._set_catesian_speed_srv(req)
     return resp.success