The present invention relates generally to a method and a device for detecting differences between two digital images.
In parallel with the explosion of paper media and the number of information support, media monitoring companies grown in importance. Media monitoring companies aggregate, structure and measure the available information.
However, despite the volume explosion, monitoring tasks are poorly automated. In the print monitoring field, most of the work is still made by operators who manually browse freshly printed newspapers and magazines. The data operators collect are of different nature.
For example, the operators identify each ad printed in the magazines. For each of them, the operators record the concerned society, the concerned product, the ad format as well as the exact version of the ad.
For a given ad campaign, the posters are often declined in numerous variants. For example, the price may vary, the general conditions of sale may change, or the advertiser may propose a promotion for a limited duration or the brand may change. The operators have to accurately and visually identify each of the differences.
The recorded data are very valuable to the advertisers as the recorded data allow advertisers to check if their communication campaign is performed as they expect.
The recorded data are also interesting for competitors as the recorded data may allow them to estimate the communication budget of one competitor.
In order to reduce costs and inaccurate manual browsing, monitoring companies are automating the browsing process. Image recognition technology may be a solution for automating the browsing process. Image detection algorithms are able to find an image in a large collection of images. Image detection algorithms may find all the images related to a given ad campaign but are not able to detect small differences between images. The operators are still required to manually select the appropriate record.
The present invention aims at providing a method and a device which enable to detect fine differences between two digital images.
To that end, the present invention concerns a method for detecting differences between two digital images, characterized in that the method comprises the steps of:
The present invention concerns also a device for detecting differences between two digital images, characterized in that the device comprises:
Thus, it is possible to detect fine differences between two images.
By resizing the images in order to get identical image sizes, by aligning pixels of the images and by normalizing colours of the images, the present invention minimizes geometric transformations, such as rotation, scaling or perspective transformations that may occur during digitization process, colours artefacts that may come from the image printing and digitization process.
According to a particular feature, the method comprises further steps of:
Thus, if the score is null it is possible to declare that the images have no difference. Otherwise the score provides a cue of the amount of difference between the two images. Using the maximum score of the connected component as the final score let the user discriminate images with high intensity differences, even if very small from the images with low intensity differences. This is interesting since low intensity differences often come from artifacts while high intensity differences are most of the time the result of a change in content.
According to a particular feature, the method comprises the step of displaying information enabling a visual identification of the differences between the two images.
Thus, it is possible, for example to a user, to clearly identify which parts of the images are different.
According to a particular feature, the first term is determined according to the following formula:
With
wherein L is the set of all the pixel locations in transformed images, where IN1(x, y) is the pixel value at position (x,y) of a transformed image and IN2′(x,y) is the pixel value at position (x,y) of the other transformed image, M(x,y) is the element value of the binary mask at position (x,y), d is a predetermined scalar value, μ is a predetermined scalar value, IN1(x,y) (i) is the ith element of the triplet of colour of IN1(x,y) and IN2′(x,y) (i) is the ith element of the triplet of colours of IN2′(x,y), i is an indicia of a channel colour.
Thus, all the colour channel values are taken into account in the distance computation. Moreover, the normalization of the pixel distance by the sum of absolute pixel values prevents strongly saturated colour channels from disproportionally affecting the pixel distance value.
According to a particular feature, d=0.8 and μ=0.4.
Thus, the detection of differences is improved.
According to a particular feature, the second term is determined according to the following formula:
With
Wherein N(x,y) is the 4-neighborhood of position (x,y) and ε is a predetermined value.
This smoothing constraint thus prevents the appearance of very small difference regions that might typically be caused by image noise, such as jpeg compression noise or paper texture.
According to a particular feature, ε=0.4.
Thus, the detection of differences is improved.
According to a particular feature, for each of the determined connected components, the score is determined according to the following formula:
Wherein CCk is the k-th connected component.
This means that we consider connected or neighbouring pixels as belonging to the same difference region. The more pixels in this region is, the greater the score is.
Thus, a higher score means a greater likelihood of a difference region.
The present invention also concerns, in at least one embodiment, a computer program that can be downloaded from a communication network and/or stored on a medium that can be read by a computer or processing device. This computer program comprises instructions for causing implementation of the aforementioned method, or any of its embodiments, when said program is run by a processor.
The present invention also concerns an information storage means, storing a computer program comprising a set of instructions causing implementation of the aforementioned method, or any of its embodiments, when the stored information is read from said information storage means and run by a processor.
The characteristics of the invention will emerge more clearly from a reading of the following description of an example embodiment, the said description being produced with reference to the accompanying drawings, among which:
According to the shown architecture, the device 10 comprises the following components interconnected by a communication bus 101: a processor, microprocessor, microcontroller or CPU (Central Processing Unit) 100; a RAM (Random-Access Memory) 103; a ROM (Read-Only Memory) 102; a hard disk 104 or any other device adapted to store images, a display 106 and an input interface 105.
CPU 100 is capable of executing instructions loaded into RAM 103 from ROM 102 or from an external memory, such as an SD card. After the device 10 has been powered on, CPU 100 is capable of reading instructions from RAM 103 and executing these instructions. The instructions form one computer program that causes CPU 100 to perform some or all of the steps of the algorithm described hereafter with regard to
Any and all steps of the algorithm described hereafter with regard to
In other words, the device 10 includes circuitry, or a device including circuitry, causing the device 10 to perform the steps of the algorithm described hereafter with regard to
From the input interface 105, the CPU 100 receives images to be compared. The input interface may be connected to a scanner, or to a data base.
It has to be noted here that the display 106 may not be included in the device 10 and may be linked to the device 10 through a communication link.
According to the invention, the device 10 comprises:
At step S200, the CPU 100 performs on each image noted I1 and I2 to be compared an image resizing. Images Im1 and Im2 are resized in order to bring them to the same dimensions, measured in number of pixels. For example, images Im1 and Im2 are resized such that the larger dimension of each image is equal to a predefined number of pixels. For example, the predefined number of pixels is equal to 400.
The resized image of Im1 is noted IR1 and the resized image of Im2 is noted IR2. The image resizing that transforms Im1 into IR1 is named R1. The image resizing that transforms Im2 into IR2 is named R2.
At next step S201, the CPU 100 performs an image registration in order to transform images IR1 and IR2 into one coordinate system. Image registration can be done with any kind of image registration technique. In a preferred implementation, the algorithm uses feature based techniques as described in the paper of Zitova, entitled “Image Registration Methods: a survey,” published Image and Vision Computing, 2003. The CPU 100, detects interest point in the images, computes robust region descriptors from them. For instance, robust region descriptors are as the one mentioned in the paper of K. Mikolajczyk, C. Schmid, entitled “A performance evaluation of local descriptors” published in IEEE Pattern Anal. Mach. Intell. (PAMI) 27, 10 (2005), pages 1615-1630. Then the CPU 100 executes a RANdom SAmple Consensus method in order to determine a transformation noted H that maps the image IR2 into the image IR1. The CPU 100 applies the transformation H to IR2 in order to get the registered image IR2′.
The image registration removes misalignment artifacts and rotation due to image scanning.
At next step S202, the CPU 100 performs a colour normalization to the images IR1 and IR2′.
For example, if IR1,1, IR1,2, IR1,3 are the three RGB colour channels of image IR1, IR2′,1, IR2′,2, IR2′,3 are the three RGB colour channels of image IR2′. It should be noted that the normalization step is independent of the number of image channels.
The colour normalized version IN1 of IR1 is the image which colour channels are colorNorm(IR1,1), colorNorm(IR1,2), colorNorm(IR1,3).
where mean(IR1,1) is the mean pixel value of the channel IR1,1, IR1,1(x,y) is the pixel value of IR1,1 at position (x,y), colorNorm(IR1,1)(x,y) is the colour channel value at position (x,y) and stdev(IR1,1) is the standard deviation of the pixel values of IR1,1. This normalization is also called z-score normalization.
where mean(IR1,2) is the mean pixel value of the channel IR1,2, IR1,2(x,y) is the pixel value of IR1,2 at position (x,y), colorNorm(IR1,2)(x,y)) is the colour channel value at position (x,y) and stdev(IR1,2) is the standard deviation of the pixel values of IR1,2.
where mean(IR1,3) is the mean pixel value of the channel IR1,3, IR1,3(x,y) is the pixel value of IR1,3 at position (x,y), colorNorm(IR1,3)(x,y) is the colour channel value at position (x,y) and stdev(IR1,3) is the standard deviation of the pixel values of IR1,3.
In a similar way we compute the colour normalized version IN2′ from IR2′.
The colour normalized version IN2′ of IR2′ is the image which colour channels are colorNorm(IR2′,1), colorNorm(IR2′,2), colorNorm(IR2′,3).
where mean(IR2′,1) is the mean pixel value of the channel IR2′,1, IR2′,1(x,y) is the pixel value of IR2′,1 at position (x,y) is the colour channel value at position (x,y) and stdev(IR2′,1) is the standard deviation of the pixel values of IR2′,1.
where mean(IR2′,2) is the mean pixel value of the channel IR2′,2, IR2′,2(x,y) is the pixel value of IR2′,2 at position (x,y), colorNorm(IR2′,2)(x,y) is the colour channel value at position (x,y) and stdev(IR2′,2) is the standard deviation of the pixel values of IR2′,2.
where mean(IR2′,3) is the mean pixel value of the channel IR2′,3, IR2′,3(x,y) is the pixel value of IR2′,3 at position (x,y), colorNorm(IR2′,3)(x,y) is the colour channel value at position (x,y) and stdev(IR2′,3) is the standard deviation of the pixel values of IR2′,3.
The colour normalization minimizes the colour artifacts that may come from the image printing and digitalization processes. At output of colour normalization, two images are obtained IN1 from IR1 and IN2′ from IR2′.
IN1 and IN2′ have the same dimensions, are registered and colour normalized.
At step S203, the CPU 100 performs a difference detection on the images IN1 and IN2′.
For that an energy function f is defined for each possible binary mask. The energy function depends on the binary mask M, on IN1 and on IN2′. The function f returns an energy as output. The binary mask M is a single-channel image that has the same dimension as the images IN1 and IN2′. Each pixel of each binary mask M can take the null or one value. The energy function f is the sum of two terms, a data term and a regularization term.
We define LN1 as [0,w1 [×[0,h1 [where w1,h1 are the dimensions of IN1. In other words LN1 is the set of all the pixel locations in IN1. In a similar way we define LN2 as the set of all the pixel locations in IN2′. As IN1 and IN2′ have the same dimensions LN1=LN2′. In the rest of the description we will refer them as L.
The data term is a sum over all possible locations (x,y)εL of a sub term that depends only on the IN1(x,y), IN2′(x,y) and M(x,y) where IN1(x,y) is the pixel value of IN1 at position (x,y) and IN2′(x,y) is the pixel value of IN2′ at position (x,y). It has the following expression:
Where IN1(x,y)(i) is the ith element of the triplet of colours of IN1(x,y) and IN2′(x,y)(i) is the ith element of the triplet of colours of IN2′(x,y) with i=1 to 3.
The data term ensures that the binary mask M fits the differences between IN1 and IN2′.
The form of dcolor ensures a consistent pixel distance measure. The normalization |IN1(x,y)(i)|+|IN2(x,y)(i)| allows pixels with high intensity to have larger range variations.
In a preferred implementation d=0.8 and μ=0.4. These parameters have proven to provide a good tradeoff between detection efficiency and robustness to noise.
The regularization term is independent from the images IN1 and IN2′. It only depends on the binary mask M and penalizes sudden label changes. The regularization term has the expression:
N(x,y) is the 4-neighborhood of position (x,y) i.e. the set {(x−1, y), (x+1,y), (x,y−1), (x,y+1)}.
In a preferred implementation ε=0.4
The regularization term promotes binary masks with low number of label changes.
Once the energy function f is defined of each possible binary mask, the algorithm minimizes it over the set of all possible binary masks that can be defined thanks to a mathematical solver.
In a preferred implementation the CPU 100 uses, as a solver, a GraphCut algorithm as disclosed in the paper of Kolmogorov and Zabih, entitled “Visual correspondences with occlusions using graphs,” and published in the Proceedings of ICCV, 2001.
It is possible to use a GraphCut algorithm since the regularization term satisfies the constraint v(0,0)+v(1,1)≦v(0,1)+v(1,0).
The solution binary mask corresponding to the minimized function is the result difference mask. For each pixel of the solution binary mask M, if it equals null, the images are considered identical at the pixel location otherwise they are considered as different. The result difference mask locates the differences between the two images. At this step, it is possible to compute the difference mask for the image IR2 by applying the inverse transformation of H—the transformation that transforms IR2 into IR2′—named H−1—on M. The resulting image is named H−1(M). Then it is possible to compute the difference mask for the original image Im2 by applying the inverse transformation of R2—named R2−1 on H−1(M).
In a similar way, it is possible to compute the difference mask for the image Im1 by applying the inverse transformation of R1—the image resizing that transforms Im1 into IR1—named R1−1 on M. The resulting image is named R1−1(M).
At next step S204, the CPU 100 computes a score score(IN1, IN2′) to quantify the differences between the two images IN1 and IN2′.
The CPU 100 computes the different connected components CCk of ones in M thanks to a connected component labeling algorithm.
Connected-component labeling, alternatively connected-component analysis, blob extraction, region labeling, blob discovery, or region extraction, is an algorithmic application of graph theory, where subsets of connected components are uniquely labeled based on a given heuristic.
Connected-component labeling is used in computer vision to detect connected regions in binary digital images, although color images and data with higher-dimensionality can also be processed.
A connected component of ones is a set of pixels that fulfills the following two conditions. The first condition is that each pixel of the connected component has the value 1. The second condition is that each pixel of the connected component is connected to each of the pixel of the connected component by a path made of pixels that belong to the connected component. The connected component is not included in a larger set of pixels that fulfills the first and second conditions i.e. is not included in a larger connected component.
For each of the connected components CCk, the CPU 100 computes a score′(CCk). The score of a connected component is the sum of the pixel value distance between IN1 and IN2′ for all the locations that belong to the connected component.
The final score is the score of the connected component that has the maximum score.
As a special case, the score is null if there are no connected components of ones in M.
This formulation of score(IN1,IN2′) ensures that if at least a difference region has a high score, the final score is high.
At next step S205, CPU 100 commands the displaying of the final score.
At next step S206, CPU 100 commands the displaying of the image Im1 and of the registered image Im2.
At next step S207, CPU 100 commands, in at least one of the displayed images or in a new image, the highlighting or the superimposing of the pixels which are different from the displayed images. In a preferred implementation, the pixels that have not been detected as different are greyed, the intensity of the pixels that have been detected as different remains unchanged. Each connected component is circled. The intensity of the pixels that belong to the circles remains unchanged.
Image shown in
Examples of
In
In
The
As the brioche 310 of
As the price of the bottle 311 is modified in
Naturally, many modifications can be made to the embodiments of the invention described above without departing from the scope of the present invention.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/IB2012/002177 | 9/21/2012 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2014/045076 | 3/27/2014 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6182069 | Niblack et al. | Jan 2001 | B1 |
20070292008 | Yumoto et al. | Dec 2007 | A1 |
20090141967 | Hattori | Jun 2009 | A1 |
Number | Date | Country |
---|---|---|
102010005266 | Jul 2011 | DE |
Entry |
---|
Jun. 11, 2013 Search Report issued in International Application No. PCT/IB2012/002177. |
Jun. 11, 2013 Written Opinion issued in International Application No. PCT/IB2012/002177. |
Number | Date | Country | |
---|---|---|---|
20150242705 A1 | Aug 2015 | US |