The present invention relates to a method for evaluating video quality of a video stream, in particular to a method for detecting defective video frames within a video stream.
In the past, such methods have not received much attention from developers of video equipment, although they have various useful applications. For example, such a quality evaluation may be employed in order to detect disturbances in a transmission channel for video data or for detecting defective scans of individual frames in a video stream generated by scanning analog video material. If a bad frame is detected in a video stream, the quality of the stream may be improved e.g. by discarding the bad frame, by retransmitting or rescanning it, or, if retransmitting or rescanning is unsuccessful, by restoring the bad frame based on e.g. frames preceding or succeeding it.
A useful method for evaluating video quality should be able to adapt to the type of video material which forms the stream. If a video stream is derived from an old black and white movie, its frames are bound to comprise much more salt and pepper noise than the frames of a video stream comprising e.g. modern HDTV material. A quality evaluation method which is to identify individual bad frames in a video stream must be able to adapt to such differences, otherwise it would frequently fail to detect quality defects that would strike a human viewer in high resolution low noise video material, whereas in noisy material it would object to many frames which, to a human viewer, would not appear substantially worse than the unobjected ones.
The object of the present invention is to provide such an adaptive method for evaluating video quality.
The object is achieved by a method comprising the steps of
a) calculating, for at least a first frame of a series of frames from said video stream, a true value of at least one video quality-related parameter associated to said first frame;
b) calculating a predicted value of said video quality-related parameter for at least a second frame from said series of frames based on said true value associated to said first frame;
c) calculating the true value of said video quality-related parameter associated to said second frame; and
d) judging the video quality of said second frame based on a difference between true and predicted values of the at least one video quality-related parameter associated to said second frame.
In the simplest case, the predicted value might be a plain and simple average or an extrapolated value obtained from the true value or values associated to said one or more first frames. It was found, however, that a highly reliable detection of existing quality defects is possible if the predicted value is calculated using a Kalman Filter.
In practice, above steps b), c) and d) are iterated for the frames of the series, and a frame used as a second frame in one of said iterations is used as one of said first frames in a subsequent iteration. In this way, the amount of data on which the calculation of the predicted value is based increases from one iteration to the next, and so does the reliability of the quality judgment.
If the series of frames does not comprise any scene cuts, image information tends to change gradually from one frame to the next. Therefore, the prediction of step b) is most reliable if the second frame is a successor or a predecessor of said at least one first frame in said series of frames.
The video quality-related parameter may be one of
Quality defects of different types are most reliably detected if above steps a) to c) are carried out for a plurality of said video quality-related parameters, and the judging step d) is based on the differences between true and predicted values of all said parameters.
When the quality is judged based on a plurality of parameters, care should be taken to weight the influence of each parameter appropriately. To this effect, it is useful to normalize the differences between true and predicted values of said various parameters and to calculate a sum representative of the overall quality of a frame based on said normalized differences.
It is easily understood that the reliability of the prediction of step b) is the higher, the larger the number of first frames is on which the prediction is based. If it is too small, there is a high risk of a second frame being erroneously judged as bad. It was found, however, that the risk of an erroneous judgment is small if it is based on at least five and preferably at least ten first frames.
In step d) the second frame may be judged to be defective if the difference between true and predicted values or, if the judgement is based on more than one video quality-related parameters, the sum of these differences exceeds a predetermined threshold. Such a judgment may be final; according to an advanced embodiment of the invention it is only provisional, and a frame is definitively judged to be defective only if the provisional judgment is confirmed at least once.
Such a confirmation may be obtained by
aa) defining a first series of frames and a second series of frames;
bb) carrying out the above-defined method for said first series of frames,
cc) carrying out the above method for said second series of frames, and
dd) definitely judging a frame belonging to both said first and second series to be defective if it was provisionally judged to be defective in step bb) and in step cc).
The first and second series of frames may be different but overlapping, or they may be identical. At least in the latter case, the order in which the frames are judged in steps bb) and cc) should be different.
Further features and advantages of the invention will become apparent from the subsequent description of embodiments thereof referring to the appended drawings.
A variety of techniques can be employed (or a variety of parameters evaluated) for judging different aspects of image quality. According to an embodiment of the invention discussed in detail here, four such techniques or parameters are used, but it will be readily apparent to a skilled person that a larger or smaller number of techniques or parameters might also yield useful results.
A first technique which is employed in the method of the invention is the determination of edge change ratio, abbreviated ECR. ECR detection allows to quantify the amount of change which occurs between two successive frames. Conventionally, ECR detection is used for detecting scene cuts; i.e. it might be used for breaking up a long video stream comprising e.g. an entire movie or TV program into series of frames, each of which corresponds to a single scene and comprises only frames which smoothly blend into one another.
The edge contrast ratio ECRn of a frame Fn is defined by
ECR
n=max(Xnin/δn,Xn-1out/δn-1) (1)
wherein δn is the number of edge pixels in frame Fn, δn-1 is the number of edge pixels in preceding frame Fn−1, and Xnin
and Xn-1out are numbers of entering and exiting edge pixels, respectively. An edge pixel can be defined to be any pixel having a grey level which differs from the grey levels of neighbouring pixels by more than a predetermined threshold. An entering edge pixel is a pixel which is determined to be an edge pixel in frame n, but which neither was an edge pixel in frame Fn−1 nor had an edge pixel in its vicinity in frame Fn−1. Conversely, an exiting edge pixel is a pixel which was determined to be an edge pixel in frame Fn−1 but which neither is nor has an edge pixel in its vicinity in frame Fn. To illustrate the concept, reference is made to
Although an evaluation of ECR proves useful for finding some of the defective frames of the test series, it is not sufficient for finding all of them. Therefore, it is appropriate to evaluate other quality-related parameters of the frames of the test series, too. One of these other parameters is contrast. Various different definitions of contrast and methods for computing it exist. One of the first definitions was given by Michelson in 1927:
where Lmax and Lmin are respectively the maximum and minimum intensity of the pixels present in an image.
Although the Michelson contrast might be used in the context of the present invention, it is not a preferred definition, because it is a global contrast, i.e. a frame showing a smooth transition from black on one side to white on the other would yield a maximum value of Michelson contrast although it would not be regarded as particularly rich in contrast by a human viewer. Therefore, a preferred definition of contrast is one which takes account not only of the total intensity difference but also of the distance between pixels having different intensities. A preferred definition of contrast and a method for computing it can be found in a paper by Gabriele Simone et. al. in SCIA2009, LNCS5575, pages 597 to 606, 2009, Springer Verlag Berlin, Heidelberg 2009 (http::\\colorlab.no/content\download/25420/270558/file/S imone2009b.pdf). The general concept of Simone's is to compute, for each pixel of a frame, the pixel being identified by row and column coordinates x, y, a local intensity of said pixel x,y and its immediate vicinity
and of surroundings of said pixel
wherein I(i,j) is the intensity of a pixel at position (i,j) while centre(x,y) and surround(x,y) are bidimensional Gaussian functions:
rc and rs are set between 1 and 3 and between 2 and 4, respectively.
Evaluation of contrast can be done based on overall luminosity or, preferably, separately for each colour channel. If the evaluation of contrast is done by channel, a total measure of contrast can be computed as a weighted sum of the contrasts in each colour channel.
The result of contrast computations for the frames of the sample series are shown in
A third quality-related parameter which is evaluated in the method of the present invention is the histogram difference. A histogram of a frame indicates, for each grey level of a predetermined scale, the number of pixels of the frame having said grey level. A distance between histograms of consecutive frames is conventionally used to detect scene changes, but it can also be used to detect frames which differ remarkably from preceding or succeeding frames due to defects. A suitable definition of the distance between histograms H(Fn−1), H(Fn) of frames Fn−1, Fn is
wherein H(F)(i) is the number of pixels in frame F having a grey level equal to i.
Histogram distances between consecutive frames from the test series computed using eq. (7) are shown in
In a video stream, a pixel which does not have the value it should have, is regarded as noise. Detection of noise is based on redundancy, either spatial or temporal, i.e. based on an analysis of adjacent pixels in the same frame or of pixels in consecutive frames. Both approaches are applicable here, although the latter, also referred to as dynamic noise estimation or motion estimation, is preferred. Typically, motion estimation is carried out as follows: A frame, e.g. Fn−1, is divided into a plurality of blocks of a predetermined size, e.g. 8 by 8 pixels. For each of these blocks, in the subsequent frame Fn, a window is defined which comprises the location of the selected block and the vicinity thereof. The window may have e.g. 24 by 24 pixels. The motion of the selected block is determined, e.g. by finding the most similar block in the window of frame Fn. A mean square error is computed by subtracting the two blocks pixel by pixel and averaging the squared differences. A noise signal ratio is then derived from this mean square error. Noise values thus obtained for the test series are shown in
Although the experimental data of
This general concept is implemented in a simple and efficient way using a Kalman filter. The principle of operation of the Kalman Filter does not depend on the type of parameter to which it is applied. Accordingly, the parameter z to which the following description refers can be any of the above mentioned parameters ECR, contrast, histogram distance, noise, or some other appropriate parameter.
The behaviour of a Kalman Filter is governed by the following equations
Prediction equations:
{circumflex over (x)}k−={circumflex over (x)}k-1, (8)
P
k
−
=P
k-1
+Q. (9)
Update equations:
In these equations {circumflex over (x)}k− is a value of the parameter z predicted based on measured data of said parameter obtained from frames Fk−1, Fk−1 previous to frame Fk. zk is the true value of the parameter z obtained from frame Fk. When this true value zk has been computed, the prediction of the parameter is updated using eq. (11), wherein the coefficient Kk is referred to as the Kalman gain, and {circumflex over (x)}k is the updated predicted value. The Kalman gain Kk is computed using equations 10, 12 and 9. For starting the Kalman Filter, the terms R, Q, {circumflex over (x)}0 and P0 must be initialized. For {circumflex over (x)}0 and P0 the mean value and the variance of the parameter z obtained for the first 10 frames of the test series (i.e. the average and variance of z1, z2, . . . , z10) can be used. The influence of these initializing values on the final result of the Kalman filter is not particularly significant. What is more important is the choice of an initializing value for R. It has proved practical to set R equal to the variance of the first 10 frames. Q may be set to R/100. Drawn-out lines in
The convergence velocity of the Kalman Filter is given by the covariance Pk, shown in
The numerical ranges of the parameters are all different. In order to compute a scalar parameter which quantifies image quality based on all of the above-considered parameters, it is necessary to normalize them. Each parameter is assumed to have a Gaussian distribution. Its density probability function f then is:
wherein zk is the parameter value for frame Fk, μ is a mean value of the parameter z and σ2 its variance.
For μ and σ2, the mean value and variance obtained after the Kalman algorithm has been carried out, i.e. μ={circumflex over (x)}m and σ2=Pm, may be used, m being the number of the last frame of the test series.
Each parameter z can then be normalized using the formula
i.e. the normalized parameter zknorm has zero average and unity variance.
As an alternative, it might be considered to use current values {circumflex over (x)}k and Pk for μ and σ2. Normalization according to eq. (14) might then not be absolutely exact, i.e. it might yield an average which is not exactly zero and a variance which is not exactly 1, but the normalization could be carried out in real time, as soon as frame Fk has been received and its parameter value zk computed.
Let zi,knorm be the normalized value of parameter ziε{ECR, contrast, histogram distance, noise, . . . } for frame Fk. A combined quality parameter is then defined by
In this equation ci is a weighting coefficient associated to each parameter. If all coefficients ci are set equal to 1, eq. (15) yields the combined quality parameter zc plotted in
It is conceivable that a judicious choice of weighting coefficients ci, the use of other parameters than the ones described above or the use of modified definitions of contrast, edge change ratio etc. might make the defective frames stand out still more clearly.
It is easily understandable that the quality of prediction, in particular in an initial phase of the Kalman filtering process, depends on the quality of the frames from which the initial values of R, Q, {circumflex over (x)}0, P0 are obtained. The risk of using bad frames for an initialization is reduced by the method illustrated referring to
Of course, the distance between groups 10 and 11 within the series of frames is completely arbitrary, and it is conceivable to place group 11 at the very end of the series. In that case, most frames of series 9 are filtered by both Kalman filters and one may be used to corroborate the results of the other, i.e. a frame is regarded as defective if it scores an excessively high value of the combined quality parameter zc in both filters.
Number | Date | Country | Kind |
---|---|---|---|
10305172.8 | Feb 2010 | EP | regional |