The present invention is relative to the field of digital image and video coding. Namely, the present invention describes a method and system for compressing and decompressing images, especially natural images, so that they can be delivered over bandwidth-constrained channels or stored on capacity-limited media.
The problem addressed by this invention is the encoding of images and video sequences composed by images as well.
Most of the existing techniques rely, as the basic encoding tool, on a block-based transform known as the Discrete Cosine Transform (DCT), as for example in the various JPEG and MPEG coding standards. The image is subdivided into blocks having a square shape and then the DCT is applied to each block (possibly adapting the size of the block to the image characteristics), which is then independently encoded and decoded in the simplest case (more advanced compression schemes may include intra- and inter-frame block prediction to further the codec performance).
The DCT enjoyed widespread acceptance in image coding because it has the desirable property that it tends to cluster the perceptually most meaningful transform coefficients (i.e., to compact the energy of the signal) in the top-left part of the transform coefficients matrix, enabling efficient compression schemes such as non-uniform quantization, zig-zag coefficient scanning and entropy coding thereof. Clearly, the actual ability of the DCT to compact the energy in the signal depends on the semantics of the particular image block which is encoded. Homogeneous blocks (e.g., blocks representing the smooth surface of an object) are desirable, because they yield transform coefficient matrices with few significant coefficients, hence simple to encode, and do not yield reconstruction artifacts when recovered by the decoder. Conversely, blocks which contain discontinuities (e.g., the juncture between objects of different colors, text, etc.) result in matrices of transform coefficients where the significant coefficients are not constrained to an area of the matrix and which may yield significant reconstruction artifacts at the moment of their decoding.
Albeit most modern coding technologies address somehow this issue by adapting the size of each block to the characteristics of the image, the predefined square shape of the blocks represents one of the DCT biggest limits, as some discontinuity will be likely to be present in the blocks, yielding reconstruction artifacts in the decoded image as shown in
The present invention overcomes this limit of block-based image coding via a totally different approach known as graph-based transform.
The graph-based transform can be seen as a generalization of the block-based transform (or, conversely, the block based transform can be considered a special case of the graph-based transform). The image (or subset thereof) can be represented as a graph of nodes connected by weighted edges: each node is a pixel of the image and each weighted edge between two nodes describes the similarity between the pixels (for example, in the grayscale color space). For example, two pixels belonging to the same smooth region corresponding to the inner of the surface of an object will be similar and hence will be connected in the graph by an edge which has a high weight. Conversely, two pixels belonging to different objects will be likely to be dissimilar (or, equivalently, not similar) and will be connected in the graph by an edge bearing a low weight. Typically, for the purpose of image compression considered in this invention, each pixel of the image will be connected only to a subset of the other pixels in the image (typically, the four top, left, bottom and right adjacent pixels) and thus the corresponding edges will have a non-null weight. Conversely, each pixel will be disconnected from all the other pixels in the image, and hence the corresponding edge weight can conventionally be set to 0, since the similarity or dissimilarity with respect to those pixels is undefined in an embodiment of the invention.
One of the edges of the graph transform is that it can be applied to areas of the image of arbitrary shape and extension which can be then independently coded and decoded.
Having illustrated how an image can be represented as a graph where the nodes are the pixels and the edges connecting the nodes are weighted as a function of the similarity between pixels, the typical architecture of a graph-based image encoding-decoding architecture is illustrated in
The encoder device 150 is composed, at least, of a weights graph generation unit 100, a graph Laplacian unit 110 and a graph transform unit 120, as represented in the upper part of
The weights graph generation unit 100 takes in input an N-pixels image f or a block thereof and generates the N×N weights matrix W which is computed as follows. Let di,j be a measure of the distance in the grayscale space between the i-th pixel fi and the j-th pixel fj of the image f, e.g., di,j can be computed as the absolute difference between the values of the pixels fi and fj:
d
i,j
=|f
i
−f
j|
Furthermore, it is assumed that each element of the weights matrix W* is computed by means of the following formula:
It turns out that the value of the weight of the graph arc connecting pixels fi and fj, i.e., wi,j, will be close to 1 (“high” arc weight) if fi and fj are similar pixels, whereas the wi,j will be close to 0 (“low” arc weight) if fi and fj are dissimilar.
The graph Laplacian unit 110 generates the transform matrix U taking as input the weights matrix W*. This unit is configured for reading W* and computing a diagonal matrix E having N×N dimensions such that the i-th element of its diagonal is equal to the sum of all the weights of all the arcs incident into the i-th pixel as described in W*; hence, E is defined in matrix notation as shown in the following:
E=diag(W*·V1)
V1∈RN,1∧(∀x∈N,1≤x≤N|Vx,1=1)
After having computed at least part of the diagonal matrix E, the unit computes the matrix L (having N×N dimensions), as the difference between the diagonal matrix E and the weights matrix W*, i.e., matrix L is the Laplacian of W*. This computation step is summarized in matrix notation as shown below.
L=E−W
*
Finally, the unit computes the N×N matrix U known as graph transform matrix or simply transform matrix, wherein the rows of U are the eigenvectors of L, i.e., the rows of U are the vectors that allow to diagonalize L.
The graph transform unit 120 takes as input the image f (which is considered as a vector having N×1) and the transform matrix U, and computes the N×1 coefficients vector f̂ via the matrix multiplication
f̂=U·f
The encoder then transmits the transform matrix U (or, alternatively, the weights matrix W* from which U can be computed) and the coefficients vector f̂ to the receiver node over a bandwidth constrained channel or memorizes them on a memory support for later use, e.g., for decoding purposes.
The decoder 170 includes, at least, a graph Laplacian unit 110 and inverse graph transform unit 180 configured for reading, from a storage device or through a communication channel, both the weights matrix W and the coefficients vector f̂. For sake of simplicity, we assume that both W* and f̂ available to the decoders 170 are identical to those generated by the encoders 150, since in practical applications adequate measures are taken for minimizing read/write or channel errors occurring during information transfer from the encoder to the decoder.
The graph Laplacian unit 110, which is functionally analogous to the counterpart found at the transmitter side, takes in input the weights matrix W* and generates the transform matrix U as described above for the encoder counterpart.
The inverse graph transform unit 180 takes U and f̂ as inputs and recovers the original image f. In order to perform this task, the unit 180 internally inverts the matrix U by generating the N×N inverted transform matrix U−1, which is, in the present case, equal to the transposed matrix UT, since U is composed by the eigenvectors of the Laplacian matrix of W′; after that, the unit recovers the original image f via the following matrix multiplication:
f=U
−1
·f̂
The performance of the above graph transform based image coding and decoding scheme, both in terms of image quality and coding rate, is correlated with the characteristics of image f or the characteristics of the blocks into which the image is subdivided. In the simplest case, the image is encoded as a whole as a single block f which encompasses all the pixels in the image. Because typical natural images are likely to contain various elements with different textures, the corresponding weights matrix W will have many non-null elements whereas the corresponding transform matrix f̂ will show a lot of high frequency components different from zero. That will drive up the coding rate and yield reconstruction artifacts at the decoder, which is obviously unwanted.
In a more practical case, the graph transform can be applied to blocks of the image, which are independently coded and decoded. For example, the graph transform could be applied to blocks of fixed square size as in other JPEG/MPEG coding standards. While this approach has the advantage of being well understood and simple to implements, it incurs in the same problem with JPEG/MPEG codecs, i.e., it is likely that the square block are crossed by discontinuities.
Hence, it is of the utmost importance that the image is subdivided in coding areas such that the discontinuities are left outside such areas. Clearly, if the coding areas are of fixed size (e.g., square), it is unavoidable that some discontinuities will be found in each block, with the undesirable effects discussed above. Another issue with the reference architecture depicted in
The present invention hence discloses, among others, a method and system, to subdivide the image to code in optimal coding areas, so that the graph transform can be independently applied to each coding area, where each coding area encompasses no or few discontinuities, avoiding the issues with square-sized coding areas.
The Discrete Cosine Transform (DCT) is the most common transform used for block-based image and video compression (see K. Sayood, Introduction to data compression, Newnes, 2012); indeed, the DCT is at the basis of popular video coding standards such as MPEG-2 (used, for example, for terrestrial and satellite standard definition video broadcasting and in the DVD storage format), H.264/AVC (used for high-definition video broadcasting, streaming over IP networks and in Blu-Ray discs) and in the recently standardized H.265/HEVC (expected to replace H.264/AVC in the above-mentioned scenarios).
One of the main drawbacks of the DCT is that when a block contains edges that are not horizontal or vertical, the resulting transform coefficients are not sparse and the high-frequency coefficients can have large magnitude. This leads to higher bitrate or reconstruction artifacts around the edges. Recently, the graph-based approach has been proposed, according to which high-dimensional data naturally reside on the vertices of graphs and they can be visualized as a finite collection of samples defined as graph signals, with one sample at each vertex of the graph (D. I. Shuman, S. K. Narang, P. Frossard, A. Ortega, and P. Vandergheynst, “The emerging field of signal processing on graphs: Extending high-dimensional data analysis to networks and other irregular domains,” Signal Processing Magazine, IEEE, vol. 30, no. 3, pp. 83-98, 2013). In the last years, researchers have studied how to apply classical signal processing techniques in the graph domain. Techniques for filtering, translation, modulation and downsampling in the graph domain have been developed. Several graph transforms have also been proposed, such as the graph Fourier transform (G. Taubin, “A signal processing approach to fair surface design”, in Proceedings of the 22nd annual conference on Computer graphics and interactive techniques, ACM, 1995, pp. 351-358).
In general, while graph-transforms have been shown to be more efficient than conventional block-based transforms, the overhead of graph transmission may easily outweigh the coding efficiency benefits. Therefore, it is very important to design graph representations and corresponding graph transforms that are efficient also when graph has to be transferred to a decoder.
Sandryhaila et al. in “Nearest-neighbor image model”, published in ICIP 2012 proceedings, propose to represent an image as a graph of nodes and arcs, where the arcs weights are determined so as to minimize the expected distortion at the receiver. However, such work does not teach how to compress the weights graph, by making difficult to apply this technique in a real-world environment.
In U.S. patent application no. US 2011/206288 A1, Ortega et al. describe an image encoding and decoding system using graph based pixel prediction. This document teaches how to encode and decode pictures through a predictor selection, but it does not teach how to compress the weights graph, by making difficult to apply this technique in a real-world environment.
Kim, Narang and Ortega in “Graph based transforms for depth video coding”, published in ICASSP 2012 proceedings, propose to find the optimal adjacency matrix and compress it using context-based adaptive binary arithmetic coding following a fixed order; however, also their work does not teaches how to compress the weights graph, by making difficult to apply this technique in a real-world environment.
Narang, Chao and Ortega in “Critically sampled graph-based wavelet transforms for image coding”, published in APSIPA 2013 proceedings, propose to encode the image as a binary unweighted graph and encode it using JBIG of size (2N−1)×(N−1), where N is the number of pixels in the original image. This encoding scheme produces images having an high level of encoding noise, since the binary unweighted graph limits the quantity of information that can be encoded. Moreover, the present invention exploits inter-pixel prediction to further the compression ratio which enables a twofold reduction of the image coding rate over the approach proposed by Ortega.
The present invention aims at solving these and other problems by providing a method and an apparatus for subdividing an image in homogeneous coding areas of arbitrary shape such that each area is simple to encode enabling a bandwidth-efficient graph-based representation.
The basic idea of the present invention is described below.
First, the image is segmented in homogeneous areas called “superpixels” using existing techniques for image segmentation; the ideal segmentation technique is such that the returned segments adhere precisely to the image discontinuities and encompass few image discontinuities. The pixels belonging to the superpixels form a connected region of arbitrary shape of the input image; the belonging and position of the pixels to a certain superpixel and the position of the superpixels within the image is represented in form of specific border or shape information.
Second, the located segments are iteratively clustered into larger superpixels until a certain predetermined requirement is met on the resulting superpixel set; this can be for example an image encoding target bitrate or optimum rate-distortion tradeoff. The superpixel size and number drives in fact the tradeoff between accuracy of the segmentation and overall rate required to encode the segment in terms of transform coefficients rate. Another requirement can be related to the overall number of superpixels or, equivalently, to their average pixel number deemed to be optimal.
Third, the Graph Fourier Transform (GFT) is carried out individually and independently on each superpixel of the set, in a piece-wise way.
As a consequence of this way to encode the image, the shape of the superpixels is conveyed in some encoded form to the decoding unit instead of the weights matrix as from the reference architecture in
At the decoding side, first the partition information of the image into superpixel is acquired together with their GFT-transformed coefficients. Second, each superpixel is inversely graph Fourier transformed, individually and independently, from the frequency domain to the space domain basing on the acquired GFT coefficients; third, the original image is reassembled by placing the reconstructed pixels of the superpixels in their original position on the basis of the relevant partition information mapping the pixels of the superpixels to their position within the image.
The characteristics and other advantages of the present invention will become apparent from the description of an embodiment illustrated in the appended drawings, provided purely by way of non limiting example, in which:
In the following, we provide a detailed description of the superpixel-based image encoding and decoding method and system which is the object of the present invention. For the purpose of providing a schematic description of the invention, first the encoder side is described, next the decoder side is described as well.
Next, at step 420 the image is segmented in pixel areas which are homogeneous by content (called “superpixels” in the following) using some method for image segmentation. Whereas several image segmentation algorithms are described in the literature, the performance of the image encoding and decoding method described herein is substantially agnostic of the particular image segmentation scheme employed as actual coding experiments revealed.
At this point (step 430), each superpixel can be potentially encoded via the graph transform due to its ability to be applied to arbitrarily-shaped image areas. Since the superpixel segmentation leaves the discontinuities between the superpixel borders, the superpixels recovered at the decoder are less likely to show reconstruction artifacts. However, prior to graph-encoding the superpixels, they are iteratively clustered to strike a more favorable tradeoff between the rate required to represent the superpixel borders, the superpixel transform coefficients and possibly the encoding distortion, which depend on the number and area of the superpixels.
Eventually, at step 440, the resulting encoded superpixel data set P are outputted in form of a set of GFT transformed superpixels P̂i and relevant shape representation preferably in compressed/encoded form P*i; such data set can be memorized for later reading by a decoding apparatus or sent to it through a communication channel.
In the following, we detail an embodiment of the present invention where the superpixels are iteratively clustered and encoded until some target encoding rate is obtained, which enables to practically apply the present invention to the common scenario of communications over bandwidth-constrained channels or capacity-constrained media.
The image is initially segmented for the purpose of obtaining a preliminary subdivision of the image in groups of pixel (also called “superpixels” in the technical literature) which are similar in color or other low-level properties derived from the pixel values themselves (luminance component Y, chrominance components U or V, R G or B components, and so on) and hence encompass negligible or no discontinuities between the pixels pertaining to a group, so that the human beings tend to perceive that pixel group like a sort of single, merged big pixel, helping the individual to recognize the objects present in any real or artificial image. In other words, they are considered so similar that the processing of the image, like encoding and decoding can be effected with high efficiency if certain techniques are used, like the graph transforms for images (or videos).
Partitioning an image within superpixels is a well-known problem in the related literature which finds several practical applications. For example, one may want to separate a foreground object over a background image. Image segmentation algorithms enable to determine which pixels in an image belong to semantically affine regions, locating the boundaries which separate the regions.
As shown in
Such various partitioning techniques differ not only by complexity, which affects the segmentation time and the overall coding time, but also by the output, i.e., different image segmentation algorithms are expected to yield different segmentations of the same image. Our experiments with different segmentation algorithms showed that the SLIC (Radhakrishna Achanta, Appu Shaji, Kevin Smith, Aurelien Lucchi, Pascal Fua, and Sabine Süsstrunk, “SLIC Superpixels”, EPFL Technical Report no. 149300, June 2010.) algorithm yields the best performance image coding wise.
In particular, the SLIC algorithm yields superpixels which stick to the image discontinuity. Our coding experiments showed that when the graph transform is applied to superpixels generated using the SLIC algorithm, few high frequency coefficients are produced by the graph transform. Given the desired number of approximately equally sized superpixels (k), the SLIC algorithm performs an initial segmentation of an image, identifying a number of k regular grid spaced pixel called cluster centroid (Ck). For each pixel, located into an area surrounding a given cluster centroid, a measure of similarity respect to the cluster centroid is given. The size of the area of the image surrounding the given cluster centroid is related to the number of superpixels (k). The mentioned measure of similarity among pixels in the area surrounding a given cluster centroid, is performed employing a metric function given by the following relations:
where i and j are the pixel indices on which the similarity measure is evaluated and Nc,Ns are normalizing constants. The above metric function takes in to account both the color information of the pixels represented by the values of the CIELAB color space (l,a,b) and the coordinate information (x,y) for each pixel located into the above mentioned area. Once each pixel has been associated to the nearest cluster center on the basis of its metric values (e.g., each pixel is associated to the nearest cluster center if the value of the similarity metric is above a threshold value), an update step adjusts the cluster centers to be the mean of all the pixels belonging to the cluster area. The L2-norm is used to compute a residual error between the new cluster center locations and previous cluster center locations. The assignment and update steps are repeated iteratively until the error converges.
In detail, we assume that the image is segmented into m superpixels P={P1, . . . , Pm}. In the following, for the sake of clearness and accessibility of the exposition, we assume that the shape of the generic i-th superpixel Pi is represented as a black and white image Pbi, for example of the same size of the original image to be encoded, where each pixels is encoded over 1 bit and can be represented on the screen of a display apparatus with black if it belongs to Pi, and white otherwise (see in particular
Of course numerous techniques are possible for indicating which pixels of the image f belongs to a certain superpixel, i.e., to represent the shape or borders of a superpixel Pi of the pool. For example, alternatively the border pixels of a superpixel can be set to “1”, while all other pixels of the image assume the value “0” (see
The superpixels obtained via image segmentation are then clustered into progressively larger superpixels on the basis of clustering information in order to strike a more favorable tradeoff between the rate required to encode the superpixel borders, i.e., the superpixel geometry, and the rate required to encode the superpixel transform coefficients, i.e., the superpixel textures. One among several image segmentation algorithms, including the SLIC algorithm exemplarily considered in this embodiment, can be used to segment the image in highly homogeneous superpixels by subdividing the image in a large number of relatively small superpixels, as
First the encoding rate necessary for encoding the image as partitioned by segmentation algorithm is calculated in an embodiment of the invention.
In particular the flowchart in
The resulting compressed shape representations are indicated as P*={P*1, . . . , P*m}. At step 520 the superpixel counter and index i is initialized to 1 and the variable Rbest which here accumulates the value of the rate necessary for encoding the image according to the initial segmentation in the m superpixels; of course it is initialized to zero.
At step 530 the individual GFT of the i-th superpixel P̂i is calculated on the basis of the pixel values of the superpixel Pi, and the relevant shape representation Pbi is preferably compressed in order to obtain the encoded superpixel border P*i. Both entities P̂i and P*i are stored since they are necessary for the iterative encoding and transforming technique according to an embodiment of the invention which is carried out after the initial phase of the calculating the encoding rate necessary for coding the image according to the initial segmentation P.
The encoding cost rate Rbest is then updated at step 540 by adding the encoding rate of the current superpixel Pi to its previous value as from the formula below:
R
best
=R
best±rate(P*i)+rate(P̂i)
where rate (P*i) indicates the rate of the (possibly encoded) border and rate (P̂i) indicates the rate of the (possibly encoded) GFT coefficients of superpixel Pi. In case the shape representations pbi have not been compressed, the rate of Pbi can be used in the formula above instead of that of P*i.
At this point, the verification step 550 checks whether the last (m-th) superpixel of the initial segmentation has been processed. If so (i=m), the procedure ends, otherwise the superpixel index i is incremented by 1 at step 560 and the initial rate calculation procedure continues with step 530 until the rate of all superpixel has been added to the variable Rbest and the GFT coefficients P̂i as well as the encoded superpixels' shapes P*i of all superpixels has been calculated and stored.
As previously explained in general the conventional segmentation algorithms do not yield optimal results from the encoding cost rate if an individual GFT transform is applied to each superpixel due to their excessive number that increments the overhead for encoding their shapes; hence in an embodiment of the invention an iterative clustering algorithm is applied to this initial segmentation as shown in
Formally, as an overall result, the iterative clustering and encoding algorithm of
First at step 610 the iterative procedure checks whether the rate produced by encoding the image according to the invention in the initial segmentation Rbest satisfies the predetermined criterion, which in an exemplary embodiment is the target encoding rate Rtarg.
Next, as shown in
Otherwise, the algorithm compares all the pairs of neighbor superpixels and for each pair of adjacent superpixels it computes a measure of dissimilarity, clustering the pair of super pixel that are the most similar.
The similarity or the dissimilarity between arbitrary segments of an image can be computed via different metrics. In the embodiment of the present invention described herein, we exemplarily describe the use of the CIEDE2000 metric (G. Sharma, W. Wu, and E. N. Dalal, “The CIEDE2000 color difference formula: Implementation notes, supplementary test data, and mathematical observations”, Color Research and Application, vol. 30, no. 1, pp. 21-30, 2005.)
The CIEDE2000 algorithm is typically applied to an area of an image and returns a scalar figure which represents the average color of such area. Let P̂k and P̂l be two neighbor superpixels, and let M̂k and M̂l be the relative CIEDE2000 metric. The dissimilarity between P̂k, and P̂l is measured as |M̂k−M̂l|, and the algorithm measures such distance for each pair of neighbor superpixels. Eventually, the procedure returns the indices k,l of the two adjacent superpixels P̂k,P̂l that bear the smallest dissimilarity and are the best candidates for clustering because.
Next, at step 620 the procedure generates a novel superpixel Pj which is produced by clustering the pixels composing the superpixels Pk and Pl, i.e., Pj=Pk U P̂l, where U denotes the Union operator. Of course the border pixels separating Pk from Pl become also part of the novel superpixel Pj so that a new superpixel with a new shape Pbj (and possibly P*j) is produced.
In step 630 superpixel Pj is then encoded independently via a graph Fourier transform as {P*j, P̂j}=encode (Pj), where Rj represents the coding rate for generating P̂j, i.e., Rj=R(P*j)+R(P̂j) being R(P*j) the cost rate for encoding in a compressed way the shape of the new superpixel Pj, while R(P̂j) is the cost rate for encoding the pixels of the superpixel Pj, i.e., the cost for generating P̂j from Pj.
Once the superpixel Pj has been encoded, the algorithm checks whether aggregating superpixels P̂k and P̂l into superpixel P̂j has enabled a rate reduction of the coded image or not. Let Rprop be the coding rate of the proposed novel solution which consists in replacing superpixels P̂k and P̂l with P̂j, which is computed as Rprop=Rbest−Rk−Rl+Rj (step 650), where Rbest is the coding rate of the best solution found so far. At step 660 the procedure, checks whether Rprop<Rbest: if the condition is not met, then clustering superpixels Pk and Pl into Pj does not yield any bitrate reduction (typically, due to an increase in the transform coefficients rate), so the solution found so far is hence optimal and the algorithm terminates.
Otherwise, clustering P̂k and P̂l into P̂j has reduced the image coding rate (typically, due to reduced border coding rate), and so the iterative clustering and encoding procedure removes from the pool of superpixels which represent the current best solution P the superpixels P̂k and P̂l; at step 670 it replaces them with P̂j by removing Pk and Pl from P (P−={Pk, Pl}) and adding Pj to P (P+={Pj}); finally it keeps track of the rate corresponding to the updated solution as Rbest=Rprop.
A comparison between
Each superpixel P̂i is independently encoded from the other superpixels in the image as illustrated in
The superpixel encoder 210 takes in input two different elements.
The first input element to the superpixel encoder is for example represented by an array of N pixels P corresponding to the pixels (sometimes called texture) of the superpixel Pi to be encoded; please note that for the sake of simplicity the index i has exceptionally not been put in the elements of this figure). Let, for example, each pixel be encoded over 8 bit and each pixel can assume any integer value between 0 and 255 shades of gray, so that each pixel is encoded over 1 byte. For example,
The second input to the superpixel encoder apparatus is, in the proposed embodiment of the present invention, a black and white image Pbi such as that shown in
The optional border (or shape) coding unit 230 takes in input the image representing superpixel border Pbi and outputs a compressed representation of the superpixel border P*i in an embodiment of the present invention. Because the superpixel border is a black and white image, existing techniques for compression of black and white images, such as for example fax documents, apply. In the proposed embodiment, the superpixel border Pbi is compressed using the JBIG scheme for compression of bi-level images (ISO/IEC standard 11544 and as ITU-T recommendation T.82).
The weights matrix W generation unit 250 takes in input the superpixel border Pbi and outputs the relative binary weights matrix Wi corresponding to the superpixel to be encoded.
We recall that
The concept of adjacency between pixels is defined as follows and is exemplified in
Having clarified the concept of adjacency between pixels, the method to generate the weights matrix W corresponding to a given superpixel border Pb (also referred to as borders information) is described in
If the pixel fi does not belong to the current superpixel P (check 11020 gives “NO”) the next pixel fi+1 is processed by incrementing the pixel index (step 11090) and repeating the steps 11020-11090 until the last N-th pixel has been processed (check of step 11100); in this case the procedure regarding the generation of the weights matrix W of the generic superpixel P ends.
The graph Laplacian unit 110 takes as input the weights matrix Wi and outputs the N×N transform matrix Ui. From now on the index i will be neglected in the description and relevant formulas of the encoder apparatus 240, since it is clear that the calculations are related to a generic i-th superpixel and not the entire image or regular block thereof.
First, the unit computes the N×N diagonal matrix Δ from W such that the i-th element of its diagonal is equal to the sum of all the weights of all the edges incident into the i-th pixel as described in W′. Second, the unit computes the N×N matrix L=Δ−W′, where L is the graph-Laplacian of W.
Third and finally, the unit computes the N×N matrix U known as transform matrix, where the rows of U are the eigenvectors of L, i.e., the rows of U are the vectors that allow to diagonalize L.
The graph transform unit 220 takes as input the N×N transform matrix U and the N×1 vector P which represents the pixels of the superpixel texture and outputs the transform coefficients vector P̂. Vector P is composed of the pixels of the superpixel to code, indexed according to the same criteria used to generate the weights matrix W. For example, with reference again to
P̂=UP,
where the coefficients vector P̂ has size N×1.
The output of the encoder is hence composed by the (optionally compressed) superpixel border P* and the coefficients vector P̂, which are sufficient to enable to recover the superpixel independently from all the other superpixels in the original image as detailed in the following.
Then the CPU executes the iterative clustering algorithm in
Next, the CPU activates the graph Laplacian unit 1130, which fetches from the memory the weights matrix W, computes the eigenvectors U and stores them in the memory 1140. At this point, the CPU may dispose of the recovered weights matrix W from the memory because not required anymore at the encoder. Subsequently the CPU activates the DFT unit 1160, which fetches from the memory the eigenvectors U and computes the matrix of Fourier transform coefficients P̂ which are stored in the memory unit 1140. At this point, the CPU may dispose of the eigenvectors U from the memory because not required anymore at the encoder.
Finally, the CPU fetches the set of compressed superpixel borders and the set of transform coefficients P̂ from memory and puts them into the channel or saves them into the storage media 1200 by means of output means 1180 (e.g., an USB, Firewire, SATA or Ethernet controller or the like).
The encoding and apparatus described above may be controlled by the CPU to internally operate in a pipelined fashion, enabling to reduce the overall time required to process each image. Notice also than many other operations may need to be performed on the output of the coding device 1100 before it is sent on the channel or memorized on a storage unit, like modulation, channel coding (i.e., error protection). Anyhow those operations are irrelevant for embodying the present invention and are therefore neglected.
Summarizing, the encoding apparatus 1100 executes a method for encoding digital images or video streams that comprises the following phases:
The process to recover an image f encoded with the above described superpixel-based technique is illustrated in terms of a flow chart in
Each i-th superpixel is decoded independently from the other m′−1 superpixels that compose the original image f, thus the decoder may not need to have received all the m′ encoded superpixels to start the decoding process: rather, it may decode the coded superpixels as they get to the decoder. A detailed description of a complete superpixel decoder architecture in terms of its functional units is provided in the following description of
First, if compressed, the border Pi* is decompressed by the optional shape decoding unit 240 (
Next, at step 1030 the weights matrix Wi is recovered from the superpixel border image Pbi. Assuming that the i-th superpixel mask in Pbi includes N pixel, matrix Wi will have size N×N, where each element wii,j is equal to “1” if pixels fi and fj in the original image belonged to the same superpixel Pi and were adjacent, and is equal to “0” otherwise. In the following, a detailed description of the algorithm which allows to recover Wi is provided.
Following, at step 1040 the texture of the superpixel Pi is recovered via the inverse graph transform. First, the diagonal matrix Δi is computed from Wi, and then the eigenvectors matrix Ui and its inverse (Ui)−1 are computed; in the present case (Ui)−1 is equal to (Ui)T since in this particular case Ui is composed by the eigenvectors of the Laplacian matrix of W′. Finally, at step 1050 the multiplication between the N×N matrix (Ui)T and the N×1 vector P̂i is performed, which returns the N×1 vector P˜i, which contains the values of the pixels which constitute the (possibly approximated) superpixel texture in raster scan order.
Finally, in step 1060 the N×1 vector P˜i representing the recovered superpixel texture is devectorized, populating those pixels of the recovered image f˜ which belong to the i-th superpixel just decoded. For the sake of simplicity, in the following we will temporarily drop from the notation the index “i” indicating the superpixel number within the image to be recovered (i.e., we will write Pb in place of Pbi, P̂ in place of P̂i, etc.) Let P˜ be the j-th element of vector P˜, with 1<=j<=N. Let Pb be the j-th element of the superpixel border in raster scan order, i.e., the j-th pixel of the original image f such that it belongs to superpixel P. From the border image Pb, the exact coordinate of Pb are recovered, that we call (x,y)j. Once the target coordinates are known, the j-th pixel of the superpixel is recovered simply by copying the value within P˜ into f(xy)j. Such procedure can be implemented as a simple copy in memory and is repeated for each j-th element of P˜, until the whole superpixel texture is devectorized and the superpixel is recovered in f˜.
Resuming our original notation, once the i-th superpixel Pi has been decoded, the decoder checks if there are more superpixels to decode, i.e., checks whether the superpixel index i has not reached the value m′ (step 1070). If so, the counter i is incremented at step 1080 and the procedure of steps 1020-1070 is repeated. Otherwise, the image recovery process is complete and the procedure ends. Notice that whereas we described the process to recover the image f˜ as a serial procedure where superpixels are decoded one after another, in another embodiment the superpixels could be decoded totally or partly in parallel so to speed up the recovery process, assuming that enough computational resources are available.
The superpixel decoder, whose architecture is illustrated in
The optional superpixel border decoding unit 240 takes in input the possibly compressed superpixel border P* and outputs a decompressed representation of the superpixel Pb. The unit performs the inverse process with respect to the process performed by the superpixel coding unit 230 found at the encoder. For example, in the above description of unit 230, it was exemplified that the unit 230 may encode the superpixel border using the JBIG scheme for compression of bi-level images (ISO/IEC standard 11544 and as ITU-T recommendation T.82), in order to further reduce the bandwidth or storage capacity required for the channel or the memorization unit.
Consequently, for the purpose of exemplification, in an embodiment of the present invention the unit 240 may decode the compressed superpixel border P* using the JBIG decoding algorithm. The output of the block is the back and white image Pb which represents the border of the superpixel to decode. Since this operation is unessential, the compression unit 230 and decompression unit 240 are depicted in dashed lines. For example,
The weights matrix generation unit 250 found at the decoder is equivalent to the weights matrix generation unit 250 found to the encoder and serves the identical purpose of taking in input the superpixel border Pb and producing in output the relative weights matrix W.
The graph Laplacian unit 110 found at the decoder is analogous to the graph Laplacian unit 110 found at the encoder side: it takes in input the weights matrix W and outputs the N×N transform matrix U.
First, the unit computes the N×N diagonal matrix Δ from W such that the i-th element of its diagonal is equal to the sum of all the weights of all the edges incident into the i-th pixel, as described, in W. Second, the unit computes the N×N matrix L=Δ−W.
Finally, the inverse graph transform unit 280 takes in input the transform matrix U and translates it generating the N×N matrix UT. Second and finally, the unit multiplies the N×N matrix UT by the N×1 coefficients vector P̂ and recovers (an approximate reconstruction of) the original N×1 superpixel texture, that we denote as P˜, as
P˜=U
T
P̂.
At this point, the CPU may dispose of the superpixel border Pb from the memory because not required anymore to recover the superpixel. Subsequently the CPU activates the graph Laplacian unit 1130, which fetches from the memory the recovered weights graph W, computes the eigenvectors U and stores them in the memory. At this point, the CPU may dispose of the recovered weights matrix W from the memory because not required anymore to recover the superpixel.
Next, the CPU activates the inverse DFT unit 1260, which fetches from the memory the eigenvectors U and the transform coefficients P̂ and recovers the superpixel texture P, which is stored in memory in a master picture canvas where the recovered superpixels are stored. Such procedure is repeated for each superpixel into which the original picture f was encoded. Finally, the CPU may fetch from memory the recovered image f˜ and send it to the display unit 1400 or copy it into another memory unit by means of output video means 1170 (e.g., an USB, Firewire, SATA or Ethernet controller or a VGA or HDMI adapter or the like).
Summarizing, the decoding apparatus executes a method for decoding digital images that comprises the following phases:
In the detailed description of an embodiment of the invention, the clustering and graph Fourier transform are carried out in sequence in an iterative way, since the clustering or segmentation reduction is carried out on the basis of the target encoding rate; this requires that clustering and graph transform are performed one after the other in a single iteration. This is not necessary for carrying out the invention; also other procedure are possible; for example first a clustering procedure is put in place entirety before the superpixel driven graph Fourier transform (i.e., without any relation with the subsequent GFT transform), and afterwards the superpixels' set resulting from the clustering process are GFT transformed.
In such an embodiment, the superpixels' number coming out from the clustering process can be set in a very simple way according to an heuristic approach. Usually, particularly for natural images, there is an optimal value for the number of superpixels m′ to be individually encoded via shape encoding and GFT transform that is related to the overall pixel's number of the image. If we indicate with NP the desired average number of pixels in a superpixel of the segmentation, m′ is related to it and to the pixel number K of the image f by the following relation:
m′=K/N
P
According to the experiments made by the inventors on a large set of natural (i.e., non artificial) images, a good value for m lies in the range 300-1000, and for m′ in 50-150. Therefore the initial segmentation reduction can be executed until a certain pre-determined value of m′ is reached during such reduction process and then perform the superpixel-driven GFT transform afterwards, individually and separately on each of the m′ superpixels.
In an embodiment of the present invention, the image to be coded may be preliminarily filtered so to remove high frequency components and reduce the resulting coding bitrate. Examples of appropriate filters include Gaussian or linear or bi-linear or cubic filtering.
In another embodiment, the image may be segmented in superpixels using a different segmentation scheme than the SLIC algorithm considered in the present description. Suitable image segmentation algorithms include the normalized cuts algorithm (Jianbo Shi, Jitendra Malik, “Normalized Cuts and Image Segmentation”, IEEE Transactions on Pattern Analysis and Machine Intelligence, Volume 22 Issue 8, August 2000) the algorithm by Felzenswalb and Locker (Pedro Felzenszwalb, Daniel P. Huttenlocher, “Efficient graph-based image segmentation”, International Journal of Computer Vision 59.2, 2004) among the others.
In another embodiment of the superpixel clustering algorithm, the border and transform coefficients coding rates could be predicted at least in part according to a model based on the collected encoding statistics rather than being measured by actually graph-encoding the superpixel for reduced encoding complexity.
In another embodiment, the superpixel clustering may be based on a rate-distortion tradeoff metric rather than simply on meeting a maximum tolerable target bitrate over the image. In such embodiment after a certain encoding trial according to the invention the image is immediately decoded, the original image is compared with its decoded version, the rate distortion tradeoff is calculated and the tentative encoding is kept or not basing on the resulting tradeoff, or on the distortion introduced by the encoding process and/or from combination of the rate and the distortion.
In another embodiment, the similarity or the dissimilarity between two superpixels may be measured as the difference between other color representation metrics than the CIEDE2000 metric considered in the present description. Suitable color metrics include the Mahalanobis distance (Prasanta C. Mahalanobis, “On the generalized distance in statistics”, in National Institute of Sciences of India, Calcutta, India, 1936, vol. 2, pp. 49-55) and the Bhattacharyya distance (Anil K. Bhattacharyya, “On a measure of divergence between two statistical populations defined by their probability distributions”, Bulletin of Calcutta Mathematical Society, vol. 35, no. 1, pp. 99-109, 1943).
In another embodiment, the geometry of a single superpixel could be described by the polygon which spans over the inner border of the superpixel itself using a vectorial representation in place of a black and white image. This saves space in representing the border of the superpixel.
In another embodiment, the overall geometry of the superpixels could be represented as a black and white image where black (or white) pixels represent the boundaries which separate two superpixels as illustrated in
In another embodiment, the monochrome image representing the superpixel borders may be compressed using chain codes such as (H. Freeman, “On the encoding of arbitrary geometric configurations”, IRE Transactions on Electronic Computers EC, Vol. 10(1961)) or (E. Bribiesca, “A new chain code”, IEEE Transactions on Pattern Recognition, Vol. 32 (1999)) in place of the JBIG codec discussed in the present description.
In another embodiment, the monochrome image representing the superpixel borders may be compressed exploiting existing techniques for piecewise smooth images compression like for example the depth maps used in DIBR-based rendering such as the arithmetic-coding based scheme described in (I. Daribo, D. Florencio, G. Cheung, “Arbitrarily shaped motion prediction for depth video coding using arithmetic edge coding”, 2012 19th IEEE International Conference on Image Processing (ICIP), 30 2012).
In other embodiments of the invention, the graph transform coefficients f̂(usually contained in a vector) are determined on the basis of the reconstructed weight map W′ in any other way than that illustrated herewith, i.e., by computing the graph transform coefficients f̂ via a graph transform matrix U composed by the eigenvectors of the graph Laplacian matrix of W′.
In another embodiment, the transform coefficients f̂ are further compressed with existing coding techniques prior they are put on the channel or memorized in a storage unit and is decompressed at the receiver prior it is processed by the graph decoding unit. Suitable coding techniques include non-uniform quantization, zig-zag scanning, differential coding and entropy coding.
The invention can be adapted so as to be used for compressing also color images. In case of an RGB image, for example, the invention can be used to compress at least one of the R G or B components; since the components are in general strongly correlated, at least as far as the edges are concerned, it is possible to infer or predict the edges of the other components basing on those of the starting one. Analogously, in case of a YUV coded color image, the luminance component Y can be compressed according to the invention, while the chroma components U and V can be compressed and decompressed in a similar way as their difference signal from Y (Y−U and Y−V), with some adaptations taking into account the different statistical features of the chroma components with respect to luminance.
The invention can be also integrated in a video coding technique wherein also the temporal correlation between different images of the video sequence must be taken into account. To that end, a prediction mechanism similar to those used in the conventional video compression standards can be used in combination with the invention for effectively compressing and decompressing a video signal.
The terms image and image block used in the present description as input bi-dimensional signal must be interpreted in their broadest meaning. They can encompass pixel values directly derived or extracted from a natural image, an artificial image, the prediction error of an image, a subsampled version of an image at higher resolution, any portion of said kind of images, and so on.
The present description has tackled some of the possible variants, but it will be apparent to the man skilled in the art that other embodiments may also be implemented, wherein some elements may be replaced with other technically equivalent elements. The present invention is not therefore limited to the explanatory examples described herein, but may be subject to many modifications, improvements or replacements of equivalent parts and elements without departing from the basic inventive idea, as set out in the following claims.
Number | Date | Country | Kind |
---|---|---|---|
102015000055555 | Sep 2015 | IT | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/IB2016/055684 | 9/23/2016 | WO | 00 |