The present invention generally relates to vehicle detection, and more particularly relates to vehicle detection system in low light conditions, such as night time.
Advanced driver assistance solutions are gaining market day by day. Forward collision warning is one of the application which warns the driver when the host vehicle is about to collide with the preceding target vehicle. The vision application detects the preceding vehicle in day and night time and generates warning based on a calculated time to collision. Forward collision warning systems and other vision based automotive applications use different algorithms to detect vehicles in day and night time conditions.
However, the existing vehicle detection systems are not very efficient, are not convenient and are costly. There is a need for a method and system for vision based night time vehicle detection which is efficient and economical. There is a need for a system that provides a robust detection of vehicles in low light conditions in various real time scenarios and also eliminates false objects.
The conventional visual processing system lacks under a wide range of visibility conditions including country conditions (dark) and city conditions (bright). Additionally, the class of vehicles detection is particularly challenging for a number of reasons including:
Therefore, there is a need for a vehicle detection system for detecting one or more vehicles on roads at night time. There is a need for a robust system that can identify and remove false objects that closely resemble vehicle light shapes such as street lights, traffic cones, and miscellaneous light sources; thus, providing high level of accuracy.
An embodiment of the present invention describes a vehicle detection system. The vehicle detection system comprises a scene recognition module configured, for receiving one of a high exposure image and low exposure image for identifying condition of one or more scenes in a dynamically varying region of interest (ROI), a road topology estimation module configured for receiving one of the high exposure and low exposure images for determining at least one of a curve, slope and vanishing point of a road in the dynamically varying region of interest (ROI), and a vehicle detecting module, coupled with the scene recognition module and road topology module, configured for detecting one or more vehicles on the road.
Another embodiment of the present invention describes a method for detecting one or more vehicles by a vehicle detection system. The method comprises receiving one of a high exposure image and low exposure image by at least one of a scene recognition module and a road topology estimation module, identifying condition of one or more images scenes in a dynamically varying region of interest (ROI) by the scene recognition module, determining at least one of a curve, slope and vanishing point of a road in the dynamically varying region of interest (ROI), and processing the one or more images for detecting one or more vehicles in the dynamically varying region of interest (ROI).
The step of processing the one or more images for detecting one or more vehicles in the dynamically varying region of interest (ROI) comprises getting probable light sources through segmentation module, removing noise and unwanted information by a filtering module, identifying one or more blobs in a filtered image, determining properties of each identified blob, identifying one or more objects from the identified one or more blobs in the dynamically varying ROI using at least one pairing logic, and validating and verifying the one or more identified pairs of blobs.
In one embodiment, the one or more identified blobs between two or more identified pairs of blobs are verified by performing at least one method steps which comprises removing a pair of the identified blobs having smaller width out of two pairs of the identified blobs sharing the same blob, wherein column overlap of the two pairs is one of a very high and very low, removing a pair of identified blobs having larger width out of two pairs of the identified blobs sharing the same blob, wherein column overlap of the two pairs is not one of a very high and very low, and middle blob is not symmetrically located, removing a pair of identified blobs having width and height less than another pair of identified blobs, wherein the two pairs are having column overlap and zero row overlap, removing a pair of identified blobs having less strength, height and wider width than another pair of identified blobs, removing a pair of identified blobs having less strength than another pair of identified blobs, wherein the two pairs having equal width and height, and very high column overlap, removing a pair of identified blobs having larger width than another pair of identified blobs, wherein two pairs are having column and row overlap and are non-symmetric, removing a pair of identified blobs having smaller width than another pair of identified blobs, wherein two pairs having column and are symmetric, removing a pair of identified blobs placed within another pair of identified blobs, wherein two pairs having very less column overlap, and removing a pair of identified blobs placed below another pair of identified blobs, wherein two pairs having very less column overlap.
The aforementioned aspects and other features of the present invention will be explained in the following description, taken in conjunction with the accompanying drawings, wherein:
The embodiments of the present invention will now be described in detail with reference to the accompanying drawings. However, the present invention is not limited to the present embodiments. The size, shape, position, number and the composition of various elements of the device of the invention is exemplary only and various modifications are possible to a person skilled in the art without departing from the scope of the invention. Thus, the embodiments of the present invention are only provided to explain more clearly the present invention to the ordinarily skilled in the art of the present invention. In the accompanying drawings, like reference numerals are used to indicate like components.
The specification may refer to “an”, “one” or “some” embodiment(s) in several locations. This does not necessarily imply that each such reference is to the same embodiment(s), or that the feature only applies to a single embodiment. Single features of different embodiments may also be combined to provide other embodiments.
As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless expressly stated otherwise. It will be further understood that the terms “includes”, “comprises”, “including” and/or “comprising” when used in this specification, specify the presence of stated features, integers, steps, operations, elements and/or components, but do not preclude the presence or addition of one or more other features integers, steps, operations, elements, components, and/or groups thereof. It will be understood that when an element is referred to as being “connected” or “coupled” to another element, it can be directly connected or coupled to the other element or intervening elements may be present. Furthermore, “connected” or “coupled” as used herein may include operatively connected or coupled. As used herein, the term “and/or” includes any and all combinations and arrangements of one or more of the associated listed items.
Unless otherwise defined, all terms (including technical and scientific terms) used herein have the same meaning as commonly understood by one of ordinary skill in the art to which this disclosure pertains. It will be further understood that terms, such as those defined in commonly used dictionaries, should be interpreted as having a meaning that is consistent with their meaning in the context of the relevant art and will not be interpreted in an idealized or overly formal sense unless expressly so defined herein.
The present invention describes a vehicle detection system and method of detecting vehicles in low light conditions occurring at night time. The detection of vehicle is required for multiple applications such forward collision warning system, dynamic high beam assistance, intelligent headlight control systems, etc. The system detects vehicles at night time using vehicle lights such as tail light as the primary feature. The system provides a robust detection of vehicles using different classifiers and identifies and eliminates false objects.
The images in the dynamically varying ROI are captured by an image capturing unit for providing the same (such as high & low exposure/Channels with different gains/Exposure) to the system 100. The image capturing unit maybe a vehicle camera. The input images are then converted to gray image & hue image and provided as input to the system 100. The system 100 works on Region of Interest (ROI). The scene recognition module 101 identifies the scene conditions such as Day v/s Night, in Night time Dark v/s Bright, Fog, and Rain. The road topology estimation module 102 identifies the road scenarios such as curve, slope etc. In one embodiment, the dynamic ROI is the ROI which changes with respect to change in curve and slope of the road. The road topology estimation module 102 and the scene recognition modules 101 are receiving and processing alternate set of High Exposure/gain of frames and Low Exposure/gain of frames. The system 100 is connected to an electronic control unit 104 for providing the output signal processed by the vehicle detecting module 103. The electronic control unit 104 processes the received signals for displaying or alerting the user or driver of the vehicle.
In one embodiment, the dynamically varying ROI is being calculated by the road topology estimation module 102 based on the following parameters:
In one embodiment, the scene/image in the dynamically varying region is classified as Bright if the above parameters spreads across the ROI is high.
The image segmentation module 201 is configured for receiving an input data from either the scene recognition module 101 or the road topology estimation module 102, for providing binary image data. The binary image data includes tail lights, head lights, noise, and unwanted information.
The filtering module 202 is coupled to the image segmentation module 201, and configured for removing noise and unwanted information which are very small objects, false positives, and similar other information.
The blob identification module 203 is coupled to the filtering module 202, and is configured for identifying one or more blobs in the filtered image and subsequently determining properties of each identified blob. The blob identification module 203 is configured to perform the steps, which includes assigning an unique label to each of the one or more blobs, determining properties of each of the one or more labeled blobs, the properties comprises blob origin, width, height, box area, pixel area, number of red pixels, aspect ratio, and blob profile, determining one or more fusions of the one or more labeled blobs in one of a dark frames and bright frames based on the determined properties, and classifying the one or more labeled blobs into at least one of a head light, tail light, merged light and invalid light.
The object identification module 204 is coupled to the blob identification module 203 and configured for identifying the object based on one or more pairing logics. The object identification module 204 is configured to perform at least one of a step comprising determining horizontal overlap of the one or more blobs, determining aspect ratio of the one or more blobs, determining pixel area ratio of the one or more blobs, determining width ratio of the one or more blobs, and determining the pixel to box area ratio of the one or more blobs.
The pair validating and verifying module 205 is coupled to the object identification module 204, and is configured for validating and verifying the one or more identified pairs of blobs. The pair validating and verifying module 205 is configured for performing one or more steps which includes validating a pair of identified blobs, validating the one or more identified blobs between row of lights, verifying the one or more identified blobs between two or more identified pairs of blobs, and validating merged light by identifying one or more merged blobs. The pair of identified blobs is validated by performing steps comprises determining pair width and aspect ratio, determining number of non-paired blobs between the pair, and determining paired and non-paired blobs area as percentage of pair width. In one embodiment, the one or more identified blobs is validated between row of lights in the ROI by executing a step comprises performing a line fit algorithm across the row of lights in the ROI.
The tracking module 207 is coupled to the pair validating and verifying module 205, and is configured for tracking the one or more validated and verified pairs of blobs in one or more stages. The one or more stages include idle stage, pre track stage, track stage and cancel track stage.
The two wheeler identification module 206 is configured for determining the identified object in the ROI as a two wheeler which is based on the one or more blobs information received from the blob identification module 203 and the pair validating and verifying module 205. The one or more blobs information comprises the blobs that are either classified head light or tail light in blob identification module & passed through rider shape profile classifier in near distance. In one embodiment, the blob identification module 203 identifies a single blob in the region of interest (ROI) in order to determine a two wheeler.
The tracking module 207 is coupled to the pair validating and verifying module 205 & two wheeler identification module 206, and configured for tracking the one or more validated and verified pairs of blobs/blob in one or more stages. The one or more stages include idle stage, pre track stage, track stage and/or cancel track stage.
The distance estimating module 208 is configured to calculate the distance between one or more detected vehicles and a host vehicle based on ratio of the product of physical width of the detected vehicle size and focal length of the lens, and the product of width of the detected vehicle in image and factor for converting from pixels to meters for a camera.
For curve estimation, the road topology estimating module 102 uses host vehicle yaw rate and speed in order to estimate curvature ahead.
For slope estimation, the vehicle detection system uses following cues to identify slope ahead
Following are the advantages of using dynamic ROI:
Image Segmentation
For hue image segmentation, the hue image and segmented input image (obtained using grayscale image) are taken as the inputs. Based on the color information of the hue image, the size of the region is increased around segmented light region. Decision of the pixel value around segmented light pixel is decided based on 8 neighborhood red color hue threshold such that low light condition or far region tail light size will be increased. For example, a 3×3 matrix as shown in
Filtering
The segmented binary images as shown in
Separating Merged Blobs:
The system 100 additionally comprises a sub-module to separate the two merged blobs—two tail/head lights, tail/head light with other lights, tail/head light with reflection, etc.—in the filtered image. The system 100 applies two level of erosion with 3×3 kernel to the segmented image to determine and separate the two merged blobs. Following process is performed on the filtered images to separate the two merged blobs as shown in
Blob Identification
The blob identification module 203 identifies different types of blobs in the filtered image and also calculates their properties. The following steps are performed to identify the blob:
Blob Labeling
Blob Properties
After assigning label to each blob, the following properties are calculated:
Blob Fusion
Based on following criteria blob list is prepared:
Blob Classification
After tail light and head light classification, all headlights having low red score and which are small in size are removed from the list by labeling them as invalid blobs. Further, if any blob has more than one blob below it then it is also labeled as invalid blob.
To classify above blob as merged blob, the patterns such as 101 and 111 is checked where 0 is corresponding to minima position and 1 is for maxima position. To determine patterns, a blob is divided into three sections and for each section min and max position are determined using the filtered image. Using these values, ratio of center to left and right section is determined to check 101 patterns. For 111 patterns, ratio of left and right section to center section is determined.
In one embodiment, the blob identification module 203 identifies a single blob in the region of interest (ROI) for determining a two wheeler.
Pairing Logic
Cosine Similarity: It measures the similarity between the vectors of the blobs.
Cosine Similarity=A. B/∥A∥∥B∥.
Where
∥A∥ magnitude of vector A
∥B∥ magnitude of vector B
Final confidence score is calculated based on the weighted scores obtained from above checks. The pairing is performed as per score matrix with score above the threshold. The pairing is very basic with very low threshold to allow uneven tail light, side light ON and slightly out of place blobs pairing as well.
The pairs as determined above are subjected to allow vehicle width check based on dynamic ROI. Central to this entire logic is dynamic triangle which is pre-calculated & loaded at the time of System Initialization (the ROI keeps on updating as per camera & vehicle parameters).
The centroid row width of the pair should lie in between minimum and maximum triangular shape (Dynamic ROI) row width as shown in
Pair Validation and Verification (V&V)
The pair validating and verifying module 205 validates and verifies pairs and merged blobs. Inputs to the module 205 are all the probable pairs as shown in
Pair Validation
Single Pair Verification:
Pair Validation in Between Row of Lights:
In one embodiment, a pair of blobs is required to be validated for a scenario of row of lights such as reflectors or street lights. In most of the cases either the reflectors or street lights are in a row. A line fit algorithm is checked across the row of lights. If the row of lights is in a line & cross ratio between pair of successive blob is same then the pair formed with those lights is not valid.
Between Pair Validation:
Merged Light Validation
Two Wheeler Detection
Tracker
In tracking state 2203, continuous prediction and update occurs for the tracked object using Kalman filter. Any other suitable filters, known in the art, may be used.
If the tracked object is found missing in a particular frame, Kalman prediction is used to display the bounding box. Also, at the same time the tracker is moved from the tracking state 2203 to CancelTrack state 2204. In the CancelTrack state 2204, object is validated for ‘m’ frames. Additionally, the CancelTrack state 2204 tries to improve the continuity of the good Tracker (which are being tracked for good number of frames) through
For the Cancel Track state 2204, the pair confidence for ‘m’ frames is obtained to decide whether to move tracker back into the tracking state 2203 or to the Idle state 2201 (not a valid pair).
Thus, in the tracking procedure, the pre-tracking and multi-frame validation reject the spurious detections, while the tracking and the Cancel Track states tend to fill the detection gaps of the corresponding objects.
In PreTrack state ‘n’ frames observation time window & in CancelTrack state ‘m’ frame observation time window is a variable. Different conditions like pair/blob class, pair/blob score & movement across the time, pair width, blinking pair/blob, curve/slope conditions makes the tracker state change decision dynamic.
Distance Estimation
In one embodiment, the distance is estimated using perspective geometry. Two triangles are perspective from a point if their three pairs of corresponding vertices are joined by lines which meet in a point of concurrence.
In perspective method, the distance between the detected vehicle and the host vehicle is estimated using below formula and which is diagrammatically shown in
Although the invention of the system and method has been described in connection with the embodiments of the present invention illustrated in the accompanying drawings, it is not limited thereto. It will be apparent to those skilled in the art that various substitutions, modifications and changes may be made in blob identification, blob classification, pairing logic and pair validation and verification without departing from the scope and spirit of the invention.
Number | Date | Country | Kind |
---|---|---|---|
159/MUM/2014 | Jan 2014 | IN | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/IN2015/000028 | 1/16/2015 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2015/114654 | 8/6/2015 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
9278644 | Lee | Mar 2016 | B2 |
9398270 | Liken | Jul 2016 | B2 |
9434382 | Prokhorov | Sep 2016 | B1 |
9713979 | Imaeda | Jul 2017 | B2 |
20070255480 | Southall | Nov 2007 | A1 |
20080069400 | Zhu | Mar 2008 | A1 |
20090021581 | Sun | Jan 2009 | A1 |
20090072124 | Schofield | Mar 2009 | A1 |
20100086211 | Kuehnle | Apr 2010 | A1 |
20100214791 | Schofield | Aug 2010 | A1 |
20110164789 | Robert | Jul 2011 | A1 |
20110280026 | Higgins-Luthman | Nov 2011 | A1 |
20120287276 | Dwivedi | Nov 2012 | A1 |
20130018547 | Ogata | Jan 2013 | A1 |
20130235257 | Kaida | Sep 2013 | A1 |
20130322697 | Grindstaff | Dec 2013 | A1 |
20140002654 | Irie | Jan 2014 | A1 |
20140071702 | Faber | Mar 2014 | A1 |
20140163703 | Chang | Jun 2014 | A1 |
20140232631 | Fleischmann | Aug 2014 | A1 |
20150061493 | Jeromin | Mar 2015 | A1 |
20150310286 | Nakanishi | Oct 2015 | A1 |
20160012348 | Johnson | Jan 2016 | A1 |
20160240085 | Otsuka | Aug 2016 | A1 |
20160267333 | Jung | Sep 2016 | A1 |
20160280229 | Kasahara | Sep 2016 | A1 |
20160320181 | Foltin | Nov 2016 | A1 |
20170064175 | Furutake | Mar 2017 | A1 |
20170162055 | Lehner | Jun 2017 | A1 |
20170372176 | Hibino | Dec 2017 | A1 |
20180137375 | Takemura | May 2018 | A1 |
Entry |
---|
Alcantarilla, P. F., Bergasa, L. M., Jiménez, P., Sotelo, M. A., Parra, I., Fernandez, D., & Mayoral, S. S. (Jun. 2008). Night time vehicle detection for driving assistance lightbeam controller. In Intelligent Vehicles Symposium, 2008 IEEE (pp. 291-296). IEEE. |
Eum, S., & Jung, H. G. (2013). Enhancing light blob detection for intelligent headlight control using lane detection. IEEE transactions on intelligent transportation systems, 14(2), 1003-1011. |
International Search Report regarding Application No. PCT/IN2015/000028 dated Jul. 21, 2015. |
Sungmin Eum et al; “Enhancing Light Blob Detection for Intelligent Headlight Control Using Lane Detection” Piscataway, NJ; vol. 14, No. 2, Jun. 1, 2013; sections I-V; Figs. 1-8, 11-5. |
Alcantarilla P. F. Et Al; “Night Time Vehicle Detection for Driving Assistance Lightbeam Controller”; Intelligent Vehicles Symposium; Jun. 4, 2008; pp. 291-296. |
Number | Date | Country | |
---|---|---|---|
20160335508 A1 | Nov 2016 | US |