Пример #1
0
 def waypoints_cb(self, waypoints):
     if self.waypoints is None:
         self.waypoints = Waypoints(waypoints.waypoints)
         # List of positions that correspond to the line to stop in front of for a given intersection
         stop_line_positions = self.config['stop_line_positions']
         i = 0
         for line in stop_line_positions:
             idx = self.waypoints.find_closest_waypoint([line[0], line[1]])
             self.traffic_light_waypoints.append([i, idx])
             i = i + 1
Пример #2
0
 def waypoints_cb(self, waypoints):
     if self.waypoints is None:
         self.waypoints = Waypoints(waypoints.waypoints)
         # List of positions that correspond to the line to stop in front of for a given intersection
         stop_line_positions = self.config['stop_line_positions']
         all_lights_msg = AllTrafficLights()
         all_lights_msg.indices = []
         i = 0
         for line in stop_line_positions:
             idx = self.waypoints.find_closest_waypoint([line[0], line[1]])
             self.traffic_light_waypoints.append([i, idx])
             all_lights_msg.indices.append(idx)
             i = i + 1
         self.traffic_lights_pub.publish(all_lights_msg)
Пример #3
0
class TLDetector(object):
    def __init__(self):
        '''
        /vehicle/traffic_lights provides you with the location of the traffic light in 3D map space and
        helps you acquire an accurate ground truth data source for the traffic light
        classifier by sending the current color state of all traffic lights in the
        simulator. When testing on the vehicle, the color state will not be available. You'll need to
        rely on the position of the light and the camera image to predict it.
        '''
        config_string = rospy.get_param("/traffic_light_config")

        rospy.init_node('tl_detector')

        self.loglevel = rospy.get_param('/loglevel', 3)
        self.state_count_threshold = rospy.get_param('~state_count_threshold',
                                                     3)

        self.traffic_light_lookahead_wps = rospy.get_param(
            '/traffic_light_lookahead_wps', 50)
        self.traffic_light_over_waypoints = rospy.get_param(
            'traffic_light_over_waypoints', 10)
        self.traffic_light_detection_interval = rospy.get_param(
            '~traffic_light_detection_interval', 0.05)
        self.traffic_light_off_idle_interval = rospy.get_param(
            '~traffic_light_off_idle_interval', 3.0)

        self.pose = None
        self.car_wpidx = None
        self.waypoints = None
        self.traffic_light_waypoints = []
        self.camera_image = None
        self.lights = []

        self.config = yaml.load(config_string)

        self.bridge = CvBridge()
        self.light_classifier = TLClassifier()
        self.listener = tf.TransformListener()

        self.state = TrafficLight.UNKNOWN
        self.last_state = TrafficLight.UNKNOWN
        self.last_wp = -1
        self.last_msg = None
        self.state_count = 0
        self.last_detection_time = -1
        self.last_tl_off_time = -1

        sub1 = rospy.Subscriber('/current_pose',
                                PoseStamped,
                                self.pose_cb,
                                queue_size=1)
        sub2 = rospy.Subscriber('/base_waypoints', Lane, self.waypoints_cb)
        sub3 = rospy.Subscriber('/vehicle/traffic_lights', TrafficLightArray,
                                self.traffic_cb)
        sub6 = rospy.Subscriber('/image_color',
                                Image,
                                self.image_cb,
                                queue_size=1)

        self.upcoming_red_light_pub = rospy.Publisher('/traffic_waypoint',
                                                      TrafficLightStatus,
                                                      queue_size=1)

        rospy.spin()

    def pose_cb(self, msg):
        self.pose = msg

    def waypoints_cb(self, waypoints):
        if self.waypoints is None:
            self.waypoints = Waypoints(waypoints.waypoints)
            # List of positions that correspond to the line to stop in front of for a given intersection
            stop_line_positions = self.config['stop_line_positions']
            i = 0
            for line in stop_line_positions:
                idx = self.waypoints.find_closest_waypoint([line[0], line[1]])
                self.traffic_light_waypoints.append([i, idx])
                i = i + 1

    def traffic_cb(self, msg):
        self.lights = msg.lights

    def image_cb(self, msg):
        """Identifies red lights in the incoming camera image and publishes the index
            of the waypoint closest to the red light's stop line to /traffic_waypoint

        Args:
            msg (Image): image from car-mounted camera

        """
        if self.waypoints is None:
            return
        if self.state_count >= self.state_count_threshold and time.time(
        ) - self.last_detection_time < self.traffic_light_detection_interval:
            return
        if time.time(
        ) - self.last_tl_off_time < self.traffic_light_off_idle_interval:
            if self.loglevel >= 5:
                rospy.logdebug("No detection %f %f %f", time.time(),
                               self.last_tl_off_time,
                               self.traffic_light_off_idle_interval)
            return

        self.last_detection_time = time.time()
        self.has_image = True
        self.camera_image = msg
        light_wp, state = self.process_traffic_lights()
        '''
        Publish upcoming red lights at camera frequency.
        Each predicted state has to occur `STATE_COUNT_THRESHOLD` number
        of times till we start using it. Otherwise the previous stable state is
        used.
        '''
        if self.state != state:
            self.state_count = 1
            self.state = state
        else:
            self.state_count += 1
            if self.state_count >= self.state_count_threshold:
                if state == TrafficLight.GREEN and self.last_state in (
                        TrafficLight.RED, TrafficLight.YELLOW):
                    self.last_tl_off_time = time.time()
                self.last_state = self.state
                self.last_wp = light_wp
                self.last_msg = state_msg = TrafficLightStatus()
                state_msg.tlwpidx = light_wp
                state_msg.state = state
                self.upcoming_red_light_pub.publish(state_msg)
            elif self.last_msg:  # have not reached the threshold
                if self.car_wpidx < self.last_msg.tlwpidx + self.traffic_light_over_waypoints:
                    # keep sending previous message when we are still close to the current traffic light
                    self.upcoming_red_light_pub.publish(self.last_msg)
                else:  # for other locations, clear traffic light status
                    self.last_msg.tlwpidx = -1
                    self.last_msg.state = TrafficLight.UNKNOWN
                    self.upcoming_red_light_pub.publish(self.last_msg)
                    self.last_msg = None
        if self.loglevel >= 4:
            rospy.loginfo(
                "Curr Light_wp: %d, state: %d, global state: %d, last Light_wp: %d, state count: %d",
                light_wp, state, self.state, self.last_wp, self.state_count)

    def get_light_state(self, light):
        """Determines the current color of the traffic light

        Args:
            light (TrafficLight): light to classify

        Returns:
            int: ID of traffic light color (specified in styx_msgs/TrafficLight)

        """
        if (not self.has_image):
            return light.state, 1.0, None if light else TrafficLight.UNKNOWN, 0, None
        cv_image = self.bridge.imgmsg_to_cv2(self.camera_image, "rgb8")
        #Get classification
        return self.light_classifier.get_classification(cv_image)

    def process_traffic_lights(self):
        """Finds closest visible traffic light, if one exists, and determines its
            location and color

        Returns:
            int: index of waypoint closes to the upcoming stop line for a traffic light (-1 if none exists)
            int: ID of traffic light color (specified in styx_msgs/TrafficLight)

        """
        light = None

        if self.waypoints and self.pose:
            self.car_wpidx = self.waypoints.find_closest_waypoint(
                [self.pose.pose.position.x, self.pose.pose.position.y])
            for traffic_light_wp in self.traffic_light_waypoints:
                #           rospy.loginfo("Traffic Waypoiny: %d", traffic_light_wp[1])
                #           rospy.loginfo("Car position: %d", self.car_wpidx)
                if traffic_light_wp[1] > self.car_wpidx:
                    light = True
                    light_id = traffic_light_wp[0]
                    light_wp = traffic_light_wp[1]
                    break

            if light and light_wp - self.car_wpidx < self.traffic_light_lookahead_wps:
                state, max_output_score, _ = self.get_light_state(
                    self.lights[light_id])
                if self.loglevel >= 4:
                    rospy.loginfo("Traffic state: %d, score: %f", state,
                                  max_output_score)
                return light_wp, state
            if light:
                return light_wp, TrafficLight.UNKNOWN
        return -1, TrafficLight.UNKNOWN
Пример #4
0
 def waypoints_cb(self, waypoints):
     self.waypoints = Waypoints(waypoints.waypoints)
     self.waypoints_header = waypoints.header
     self.set_road_velocity()