The technical field of this invention is image processing, particularly to detect if the view of a fixed focus camera lens is obstructed by surface deposits (dust, road dirt, etc).
The fixed focus cameras used for Advanced Driver Assistance Systems (ADAS) are subject to many external conditions that may make the lens dirty from time to time. Car manufacturers are starting to design intelligent self-cleaning cameras that can detect dirt and automatically clean the lens using air or water.
One of the difficulties encountered in the prior art is the reliable detection of foreign objects such as dust, road dirt, snow, etc., obscuring the lens while ignoring large objects that are part of the scene being viewed by the cameras.
The solution shown applies to fixed focus cameras, widely used in automotive for ADAS applications. The problem solved by this invention is distinguishing a scene obscured by an obstruction, such as illustrated in
A machine-learning algorithm is used to implement classification of the scene in this invention.
These and other aspects of this invention are illustrated in the drawings, in which:
The steps required to implement the invention are shown in
In step 302 the high frequency content of each block is computed by using horizontal and vertical high pass filters. This produces a total of 2×M×N values.
The reason for separately processing 3×3 (9) different regions of the image instead of the entire image is to calculate the standard deviation of the values across the image. The classified of this invention uses both mean and standard deviation values. Employing only the mean value could be sufficient to detect scenarios where the entire view is blocked but cannot prevent false-positive cases where one part of the image is obstructed and other parts are perfectly fine. The mean value cannot measure the high-frequency's contrast between different regions whereas the standard deviation can.
Step 303 then calculates the mean and the standard deviation for each high pass filter, across M×N values to form a 4 dimensional feature vector. Step 304 is an optional step that may augment the features vector an additional P component. This additional component may be meta information such as image brightness, temporal differences, etc.
Step 305 then classifies the scene as obscured or not obscured using a logistic regression algorithm having the feature vector as its input. This algorithm is well suited for binary classifications such as pass/fail, win/lose, or in this case blocked/not blocked.
This algorithm performs well where the two classes can be separated by a decision boundary in the form of a linear equation. Classification is shown in
If θ0+θ1·x1+θ2·x2≧0
If θ0+θ1·x1+θ2·x2<0
In this invention the line is parametrized by θ=[θ0, θ1, θ2] since the feature vector has two components x1 and x2. The task of the logistic regression is to find the optimal θ, which will minimize the classification error for the images used for training. In the case of scene obstruction detection, the feature vectors have 4 components [x1, x2, x3, x4] and thus the decision boundary is in form of an hyperplane with parameters [θ0, θ1, θ2, θ3, θ4].
The training algorithm determines the parameter θ=[θ0,θ1,θ2 . . . ] by performing the following tasks:
Gather all feature vectors into a matrix X and the corresponding classes into a vector Y.
Find θ=[θ0, θ1, θ2, θ3, θ4] that minimizes the cost function:
Gradient descent is one of the techniques to find the optimum θmin which minimizes J(θ).
If for θmin we have Jθmin=0, this means the error rate for the classifier, when applied to the training data set, is 0%. However most of the time J(θmin)>0, which means there is some miss-classification error that can be quantified.
Next the algorithm's miss-classification error (also called accuracy) is calculated by applying the classifier rule to every feature vector of the dataset and comparing the results with the true result.
The final classification is done as follows:
If θ0+θ1·x1+θ2·x2≧0
If θ0+θ1·x1+θ2·x2<0
A typical embodiment of this invention would include non-volatile memory as a part of external memory 710. The instructions to control SOC 700 to practice this invention are stored the non-volatile memory part of external memory 710. As an alternate, these instruction could be permanently stored in non-volatile memory part of external memory 710.
This application claims priority under 35 U.S.C 119(e)(1) to Provisional Application No. 62274525 filed Jan. 4, 2016.
Number | Date | Country | |
---|---|---|---|
62274525 | Jan 2016 | US |