The present invention generally relates to image transcoding. More specifically, the present invention is concerned with a system and method for predicting the file size of images subject to transformation by scaling and a change of quality-controlling parameters.
Nowadays, the heterogeneous nature of mobile terminals, electronic devices, communications and multimedia applications renders multimedia transcoding inevitable. For example, in the emerging Multimedia Messaging Service (MMS), server-end adaptation is necessary to ensure interoperability when the destination mobile terminal cannot handle the received media under its current format. Image-related interoperability problems mainly originate from excessive resolution or file size. Accordingly, image transcoding operations commonly involve image scaling and file size reduction.
Although reducing the resolution of an image is a well-known and deterministic problem, reducing efficiently the compressed file size of an image in order to meet a given target remains a challenge. For example, in the lossy JPEG (Joint Photographic Experts Group) format, the user typically controls a quality factor (QF), which, affects the quantization process and therefore the compressed file size. Indeed, a higher QF leads to a better image quality and a larger file size. However, a precise relationship between the QF and the compressed file size still lacks, since other image properties must also be taken into consideration when establishing the relationship between the QF and the compressed file size.
A simple transcoding approach for file size reduction of an image may consist of decoding the image and then iteratively re-encoding the image with a different QF value until the given target size is met, within acceptable tolerance. Although functional, this approach is highly inefficient in terms of computations and is not acceptable for high volume image transcoding servers.
Several studies have investigated the relationship between quantization and file size, or the bitrate. Although these studies provide interesting results, they are difficult to implement in the proposed context of predicting a JPEG image file size subject to transformation by scaling and a change of QF value, because many assumptions do not hold. For example, most of the studies start from an original, artefact-free image. Also some of these studies were made in the context of MPEG video coding, which uses a simpler quantization scheme than JPEG. More importantly, these studies ignore scaling of the image as a bona fide adaptation strategy. The impact of these differences with the proposed context will be discussed herein below.
Furthermore, interesting methods have been proposed to address the specific problem of JPEG size adaptation (see for example U.S. Pat. No. 6,233,359 B1 granted to Ratnakar et al on May 15, 2001 and the article “Efficient transform-domain size and resolution reduction of images”, by J. Ridge, Signal Processing: Image Communication, 18(8):621-639, September 2003”). As discussed in the article of J. Ridge, the method of U.S. Pat. No. 6,233,359 B1 addresses complexity more than user experience and, also, this method is prone to undershooting file sizes, which represent two major shortcomings. Even though the method of J. Ridge provides much better results than the method disclosed in U.S. Pat. No. 6,233,359 B1, these two methods still have major drawbacks or limitations, in particular their non-treatment of scaling as a file size reduction strategy, so that there is a need to further investigate and improve the existing methods.
For example, the existing algorithms first require that some image statistics be gathered. By so doing, not only the complexity of the process is increased but also some level of re-engineering of the image compression tools is required, so that the JPEG encoder/decoder software has to become a specialized transcoder.
Secondly, those algorithms consider the resolution of the image as fixed, or independently altered in a previous stage, and focus solely on file size reduction. However, the study of the impact of changes in both quality-controlling parameters and scaling appears to be a necessity. Indeed, this will be useful so as to select the best combination of scaling and QF values which will meet terminal constraints. In particular, it is often better to have a lower resolution, high quality image than a high-resolution image with poor quality.
An object of the present invention is to provide a system and method for predicting a file size of an image subject to transformation by scaling and changes of quality-controlling parameters, these system and method capable of overcoming the above discussed problems and drawbacks.
More specifically, in accordance with the present invention, there is provided a method for predicting a file size of an image subject to transformation by scaling and a change of at least one quality-controlling parameter, comprising: receiving (a) the file size of the image before transformation of the image, (b) information about at least one quality-controlling parameter of the image before transformation of the image, (c) information about at least one quality-controlling parameter for application to the image during transformation of the image, and (d) a scaling factor for application to the image during transformation of the image; calculating a relative file size prediction on the basis of the received information about quality-controlling parameters and scaling factor; and calculating a file size prediction of the image after transformation of the image, wherein the file size prediction of the image after transformation of the image is calculated as a function of the file size of the image before transformation of the image and the calculated relative file size prediction.
The present invention also relates to a system for predicting a file size of an image subject to transformation by scaling and a change of at least one quality-controlling parameter, comprising: an input for receiving (a) the file size of the image before transformation of the image, (b) information about at least one quality-controlling parameter of the image before transformation of the image, (c) information about at least one quality-controlling parameter for application to the image during transformation of the image, and (d) a scaling factor for application to the image during transformation of the image; a calculator of a relative file size prediction on the basis of the received information about quality-controlling parameters and scaling factor; and a calculator of a file size prediction of the image after transformation of the image, wherein the file size prediction of the image after transformation of the image is calculated as a function of the file size of the image before transformation of the image and the calculated relative file size prediction.
The foregoing and other objects, advantages and features of the present invention will become more apparent upon reading of the following non-restrictive description of illustrative embodiments thereof, given by way of example only with reference to the accompanying drawings.
In the appended drawings:
a and 7b are graphs showing the percentage of zeros as a function of the file size (bytes).
Generally stated, a system and method according to the non-restrictive illustrative embodiments of the present invention will predict the file size of an image, which has already been compressed and which is subject to transformations by both scaling and changes of quality-controlling parameters.
Also, although the system and method according to the non-restrictive illustrative embodiments will predict the file size of a JPEG image subject to transformation by scaling and a change of at least one quality-controlling parameter, in this case the QF (Quality Factor), it should be kept in mind that the same concepts can be applied to other types of formats such as GIF (Graphics Interchange Format) as well as other image formats that have other quality-controlling parameters such as the number of colors, the color depth, the color component sampling structure (4:4:4, 4:2:2, 4:2:0, etc), horizontal and vertical resolutions, subsampling factors, etc. This invention is mostly described with one quality-controlling parameter for clarity and to help keeping the description simple but it extends to many quality controlling-parameters; this will be explained in more detail hereinafter.
The system and method according to the non-restrictive illustrative embodiments of the present invention will also select a proper combination of scaling and QF that meets a certain size constraint. Furthermore, in order to minimize processing complexity, the system for the prediction of the file size, hereinafter referred to as predictor of file size, uses values which are readily available and easily accessible from the image.
However, before further defining the predictor of file size, the concept of training and testing image corpus will be described.
For the purpose of testing a predictor of file size and/or a file size prediction method, a corpus of images is used. A useful corpus is formed of a collection of exemplars—in our case, images—representative of the population to be studied. Currently, typical JPEG databases are not widely available; therefore, one has to build his/her own database or image corpus. For example, images can be gathered from the Internet to form the image corpus. Indeed, a crawler can easily follow links starting from popular web pages, which ensures trendiness, and then grab any image media that it comes across. Furthermore, anonymization and uniqueness of the images in the image corpus can be ensured by renaming files using unique identifiers, for example identifiers generated by strong hash functions such as MD5 (Message Digest 5) applied to the entire files. Also, collisions can be safely ignored. A strong hash function, such as MD5, computes a digital signature from a document which can then be reliably used to identify the document for which it has been computed. Very strong hash functions like MD5 are extremely unlikely to produce the same digital signature for two different documents, thus enabling a very reliable method of detecting identical files.
In addition, the image corpus is divided into two random disjoint sets: a training set of images and a test set of images. The training set contains images used to optimize the model and method of prediction, while the test set is used to actually test the optimized model and method of prediction. Since the corpus presents a rather limited number of exemplars, new exemplars are generated by applying a large number of possible transformations, both in quality-controlling-parameters and in scaling, whereby the model can be populated with a much greater and useful exemplar population.
Currently used image file size prediction systems and methods, such as i) polynomial prediction and ii) ρ-domain prediction systems and methods will now be described.
i) Polynomial Prediction
Polynomial prediction uses a low order polynomial in order to formulate a prediction. If computing a polynomial fit on one-dimensional data is a simple task, however, adding more variables to the fit increases exponentially the number of points that need to be computed. Indeed, if the technique from Lin et al. (Article “Rate control using spline-interpolated R-D characteristics”, in Procs. VCIP'96, pages 111-122, 1996) is generalized to use a polynomial of order d in n variables, then, there is a need to solve (d+1)n equations in (d+1)n unknowns. For each of these (d+1)n equations a point on the curve needs to be evaluated. With the method proposed by Lin et al., this means that a partial transcoding for each point needs to be performed, which results in an unacceptable amount of computation.
Furthermore, it is unclear what is the optimal order d of the polynomial (or even if it is a polynomial at all) and what n variables should be included in the prediction. At least the scaling and the desired output quality factor QFout should be used to formulate a prediction; the input quality factor QFin is implicit in the image itself and, therefore, participates to the computation when the (d+1)n points are computed. Because this procedure is computationally prohibitive, it was decided not to study its behavior in depth.
It should be noted that QPs (Quantization Parameters) and QFs (Quality Factors) are inversely related. A high QP means a more aggressive quantization while a high QF means higher quality and therefore less aggressive quantization. QPs are directly related to quantization in schemes such as those used in Standard H.263. However, in JPEG, QFs are related to quantization through two successive steps: a first step in which a piecewise transfer function is used and a second step in which a quantization matrix is used. The quantization matrix scales the DCT (Discrete Cosine Transform) coefficients before encoding. It should be pointed out that, in the present specification, QF refers to the JPEG quality factor, as understood by the Independent JPEG Group (IJG).
ii) ρ-Domain Prediction
In ρ-domain prediction, an accurate prediction of the bitrate is calculated based on an estimate of the number of zeros resulting from quantization.
In ρ-domain prediction, it is assumed that i) the image is never resized, ii) the target bitrates are very low, and iii) the original images are available to the compressor. In the context of Standard H.263, the first two assumptions i) and ii) can be validated. However, assuming that the original images are available to the compressor (assumption iii)) is not valid in the context of image adaptation and transcoding; as mentioned hereinabove, original and raw images are generally not available to the transcoding engines.
ρ-domain prediction uses the cruder quantization of Standard H.263. JPEG uses a quantization matrix that can be customized, while Standard H.263 uses a simpler uniform quantizer. The additional complexity introduced by the quantization matrix renders the model of ρ-domain prediction less amenable to JPEG adaptation.
a and 7b show that a predictor according to ρ-domain prediction is linear within a region of very low QFs. More specifically, the number of zeros varies linearly with bitrate but at low bitrates only. However, linearity is lost if broader ranges of bitrates are considered, as shown in
Furthermore, ρ-domain prediction is expensive, in terms of computation, and supposes a different range of quantization parameter values.
Not only polynomial prediction and ρ-domain prediction are rather complex, they also present drawbacks. First, polynomial prediction and ρ-domain prediction make assumptions that, often, do not hold in transcoding, such as using an original image. Secondly, polynomial prediction and ρ-domain prediction ignore the operation of scaling for reducing the file size. Therefore, their estimation does not lead to a joint estimation of scaling and QF reduction. ρ-domain prediction assumes that, when scaling happens, it happens before the transcoded file size prediction, which does not allow one to formulate an adaptation strategy for file size reduction based on both scaling and quality factor. Polynomial prediction can, theoretically, include scaling as well, but the computational cost of doing so is prohibitive, as the number of transcoding needed grows exponentially with the number of variables used. Ignoring scaling as an adaptation strategy is a major shortcoming since it may well be that, in order to maximize the user experience, an image is to be scaled down and encoded with a higher QF rather than just being recompressed with a lower QF. Thus, a predictor of file size should be able to take into consideration scaling as well as, in addition, QF changes.
Furthermore, it would be interesting to obtain a predictor of file size that does not use image data besides the width, height, scaling and QF of the image. Also, the predictor of file size should be able to use information about other images so as to formulate a prediction about the present image. Therefore, non-parametric methods would be advantageously used.
Non-parametric modeling differs from parametric modeling in the number of internal parameters which is usually rather large and that these parameters are loosely organized so as to enable the discovery of structure. On the contrary, parametric modeling uses a fixed and small number of parameters, each assigned with very specific role by a priori assumptions.
Generally stated, a predictor of file size according to a first non-restrictive illustrative embodiment of the present invention predicts the file size of an image subject to transformation by scaling and a change of quality factor by considering the compressed file size of the image before transformation of that image multiplied by a certain prediction factor, referred hereinafter as the relative file size prediction.
Turning now to
In transcoding, media characteristics such as the type of media, the resolution, etc., are typically used to determine if adaptation is needed. Those parameters can usually be obtained without decompressing a compressed media. For example, scanning the file header of the compressed media is often sufficient. In a predictor of file size, using parameters based on metrics that require decompression of the compressed image or any pixel-level computations is very expensive in terms of computations and requires almost the same time and power of processing as actual transcoding. Therefore, parameters of this type are avoided.
Characterization data are used as inputs to the predictor of file size 10. For example, in the case of JPEG images, the characterization data could be the resolution, such as the width and height of the image, the quality factor QF, the subsampling method, or any other information readily available from the image.
In the first non-restrictive, illustrative embodiment of the present invention as illustrated in
Referring to
The predictor of file size 10 also includes an array-based, relative file size prediction calculator 16 for pre-computing relative file size predictions, based on a prediction array which will be described hereinbelow. This yields the prediction function ŝ(QFin,QFout,z) 15, which gives a relative compressed file size prediction of the image I to which the desired output quality factor QFout and the scaling factor (zoom factor) z have been applied.
Finally, the predictor of file size 10 comprises a transformed image file size prediction calculator 18 supplied with the compressed file size S(I) of the image I before transformation of that image and the prediction function ŝ(QFin,QFout,z) to compute a file size prediction 19 (Ŝ(I,QFout,z)) of the image I after transformation (image J) as follows:
{circumflex over (S)}(I,QFout,z)=S(I){circumflex over (s)}(QFin,QFout,z) (1)
where the function ŝ( ) is the relative size prediction, which is given by:
yielding output 19 of
The function s(J,QFout,z) represents the exact function of the file size of the transformed image J, with the desired QFout and scaling z. The function is given by:
where S(J) is the compressed file size of the transformed image J and T(J,QFout,z) is the function that returns the compressed, transformed image J after it is applied both scaling z and the change of quality factor to QFout. The expression S(T( )) is the compressed file size function related to the transformed image J using the desired output quality factor QFout and the scaling factor z.
It should be noted that TQF(I)⊂T is the subset of images having the same QF as the image I in the training set T and |TQF(I)| is the cardinality of the subset TQF(I). And the function T( ) can be, for example, a complete JPEG transcoder.
Also, it should be noted that ŝ( ) represents an optimal least mean square estimator. Indeed, it can be readily verified that:
However, since the function ŝ( ) is expensive in terms of computation, an array of relative file size predictions can be pre-compute using that function so as alleviate the computational complexity. Therefore, the relative file size prediction calculator 16 is used with an array M of pre-computed file size predictions whose indexes are the quantized quality factor Q{tilde over (F)}in of the image before transformation of the image, the desired quality factor Q{tilde over (F)}out for application during transformation of the image, and the scaling factor {tilde over (z)} for application during transformation of the image. Quantized values are denoted by the tilde ({tilde over ( )}) symbol.
Suitable quantization will prevent context dilution while allowing the array M to be searched efficiently. The values can be quantized through a conventional quantizer (not shown). Since quantizers are well-known to those of ordinary skill in the art, they will not be further described in the present specification.
As indicated hereinabove, the inputs of the array-based relative size prediction calculator 16 comprise the quantized quality factor Q{tilde over (F)}in of the image before transformation of the image, the desired quantized output quality factor Q{tilde over (F)}out of the image during transformation of the image and the quantized scaling factor {tilde over (z)} for application during transformation of the image and the array-based relative file size prediction calculator 16 comprises a relative file size prediction array calculator (not shown) supplied with these inputs to pre-compute an array of relative file size predictions. An entry of the array M is given by the following equation:
where QFout(J), z(J) are functions that return the QF used during the transformation, or QFout, and the scaling factor z, respectively. The function s(J,QFout(J),z(J)) (Equation (5)) returns the observed relative file size change when the transformed image J is applied the given transformation. The set SQ{tilde over (F)}
Accordingly, MQ{tilde over (F)}
The array-based relative size prediction calculator 18 of the predictor or file size 10 is responsive to the relative file size prediction ŝ( ) and the file size S(I) of the image I before transformation of the image to calculate the predicted file size 19 of the image I after transformation (image J) using the transformed image file size prediction calculator 18 as follows:
Ŝ(I,QFout,z)=S(I)MQ{tilde over (F)}
It should be pointed out that the function S(I) embeds some of the information about the image I that other systems and methods extract explicitly at larger cost, in terms of computation. S(I) can be thought of as a hash function of the image I that retains information about the characteristics of the image and injects them into the transformed image file size prediction calculator 18.
The predictor of file size 10 according to the first non-restrictive illustrative embodiment is a non-parametric predictor.
Turning now to
In operation 21, an image corpus is acquired. The means for such acquisition is beyond the scope of the present specification, but a non-restrictive illustrative embodiment is a web crawler or any other means of conducting a reliable survey of images existent. Images obtained on-the-fly by a transcoder can also be used for training.
In operation 22, each image in the corpus is used to generate any desired number of exemplars. In sub-operation 23 a large number of images on which were applied quality-controlling parameters changes and scaling, typically in a way that is compatible with the quantization scheme used in the predictor of file size 10 is generated from an image extracted from the corpus. With each exemplar are stored its quality factor QFin, quality factor QFout and scaling factor z.
In sub-operation 24, each of the generated exemplar is added to the exemplar list that also includes the original images from the corpus. Operation 22 is repeated as long as there are images left unprocessed in the corpus.
In operation 26, the array M is computed. Each exemplar generated in operation 22 is now processed to compute the array M.
In sub-operation 27, data extracted from a given exemplar is quantized. The values of its quality factor QFin quality factor QFout and scaling factor z are quantized to Q{tilde over (F)}in, Q{tilde over (F)}out, and {circumflex over (z)}.
In sub-operation 28, the quantized quality factors Q{tilde over (F)}in and Q{tilde over (F)}out, and the quantized scaling factor {tilde over (z)} are used to update the array M.
After operation 26, the array M contains the relative file size prediction for all images. According to equation (5):
where s( ) is calculated according to Equation (3). SQ{tilde over (F)}
The array-based relative file size prediction calculator 20 of
It should be noted that the update time in the array-based relative file size prediction calculator 20 of
Experiments have been carried out using the predictor of file size 10 of
The corpus used in the simulations contained 70,300 JPEG files. The corpus was free from corrupted files and all metadata, such as EXIF tags, are removed. EXIF is a common extension to many image formats, including JPEG, that holds extra information about the picture or image, especially when originating from a digital camera. EXIF extensions are used to store data such as exposure details, color balance, camera brand name, and other digital photography information. For each original exemplar (image) in the corpus, 100 (one hundred) exemplars were generated using different quality factors QFout and scaling factors z. The split between the training set and the test set is about 80/20.
Table 2 shows the expected absolute error E└|S(Iout)−Ŝ(Iout)|/S(Iout)┘×100% for the prediction array M8{tilde over (0)}. It can be seen that the prediction error is minimal around Q{tilde over (F)}in=Q{tilde over (F)}out=80 and {tilde over (z)}=100%. The prediction error is maximal when Q{tilde over (F)}in and Q{tilde over (F)}out and scaling factor differ the most, for example at the upper left of Table 2. Also, the portion of Table 2 which is in gray represents the region of expected absolute errors of 10% or less.
Table 3 gives the probabilities that the absolute relative error is under a certain threshold β, for typical quality factors such as Q{tilde over (F)}in=Q{tilde over (F)}out=80. The probabilities are given by:
P(|S(Iout)−{circumflex over (S)}(Iout)|<βS(Iout)|{tilde over (z)},Q{tilde over (F)}in=80,Q{tilde over (F)}out=80) (7)
for different β and {tilde over (z)}.
It should be noted that the distribution of errors spreads further away from scaling of 100%, as can be expected.
Turning now to
Above each box 50, the distribution of the actual values of s(J,Q{tilde over (F)}out=70) of all images which participated in the computation of the estimator M8{tilde over (0)},7{tilde over (0)},{tilde over (z)} is plotted. The distribution of the images is indicated by points. A thin line 51 joins the different least mean square estimators ŝ; this clearly shows that the surface is not very smooth.
The plots show the quartiles (rectangles such as 52) and the 5%/95% limits are indicated by dashes such as 53. It can be seen from
Some points lying far away above or below of the quartiles can be spotted in
A predictor of file size 30 according to a second non-restrictive, illustrative embodiment of the present invention will now be described. The predictor of file size 30 takes into consideration the original resolution of the images and thus the presence of outliers.
Now turning to
The predictor of file size 30 is supplied with inputs 31 including the original file size S(I), the original quality factor QF(I) (denoted QFin), the width W(I) and the height H(I) of an image I before transformation of the image, as well as the desired quality factor QFout and desired scaling factor (zoom factor) z after transformation of the image. The output 37 of the predictor 30 yields the file size prediction Ŝ(I,Q{tilde over (F)}out,{tilde over (z)}) of the image I after transformation of the image to which the scaling factor z and quality factor QFout have been applied.
The quantizer 32 processes the quality factor QFout and scaling factor z to produce a quantized quality factor Q{tilde over (F)}out and quantized scaling factor {tilde over (z)}, respectively, to serve as inputs to the cluster-based relative file size prediction calculator 34.
A centroid determination also occurs in quantizer 32, which yields an array M
The cluster-based relative file size prediction calculator 34 receives as input the array M
Then, the transformed image file size prediction calculator 36 computes the file size prediction 37 Ŝ(I,QFout,z) of the image I after transformation (image J) using the output 35 from the calculator 34 as follows:
Ŝ(I,QFout,z)=S(I){circumflex over (s)}(QFin,QFout,z) (1)
where the function ŝ( ) is the relative size prediction 35.
As described hereinabove, in cases such as with the presence of outliers, the small resolution of an image breaks down the above described predictor of file size 10. To overcome this issue, segmenting the image space into regions is performed, where regions of similar resolutions are grouped together. To do that, the exemplars generated from the corpus of images will be split into classes using clusters. Furthermore, the use of clustering allows for optimizing a least mean square estimator for each class, thus further minimizing the error of prediction.
It should be noted that clustering is an unsupervised learning technique that partitions data in a given number of disjoint subsets, called classes, so that data in each subset are maximally similar under a chosen metric. For each subset, a representative value or prototype is computed. Generally, the prototype is the centroid of the subset. Clustering is therefore synonymous with probability distribution function optimized vector quantization where the quantization levels are the centroids of the classes.
Turning now to
The number k of classes is chosen prior to clustering. Those of ordinary skill in the art know how to choose such a number k of classes. For example, the parameter k is sufficiently large to reduce the error and yet sufficiently small to avoid context dilution.
Still referring to
The generation of new exemplars 42 proceeds in the same way as operation 22 in
Therefore, the operation 42 creates exemplar vectors needed by the cluster calculator 44 to calculate a partition C of the training set T of images into a number k of classes.
By definition, the partition C is given by C={C1, C2, . . . , Ck} and will satisfy ∪i=1kCi=T and ∩i=1kCi=0.
Furthermore, an optimal partition C* will minimize the expected squared distance between any vector xI, with IεT, and its assigned centroid. The optimal partition C* is given by:
where ∥x∥=√{square root over (xTx)} is the familiar L2 norm, T is the transpose function, and
An example of clustering is shown in
After the number k of classes has been decided, the cluster calculator 44 (see 45) calculates the classes or clusters using the k-means algorithm. Then a prototype calculator (see 45) calculates the centroid Y, as follows:
which represents the prototype of all vectors in class Ci.
The complexity of computing the optimal partition C* makes it computationally infeasible. However, it can be approximated with high precision using the k-means algorithm, as disclosed in the article by Leon Bottou and Yoshua Bengio entitled “Convergence properties of the K-means algorithms” in G. Tesauro, D. Touretzky and T. Leen, editors, Advances in Neural Information Processing Systems, volume 7, pages 585-592, The MIT Press, 1995. Similar to Newton's algorithm, the k-means algorithm has superlinear convergence which, in practice, means that a relatively small number of iterations is required for a good approximation. The details and properties of k-means is believed to be well known to those of ordinary skill in the art and, for that reason, will not be further described in the present specification.
Once the classes or clusters C are computed, the array calculator (see 47 to 49 in
Each of these prediction arrays has two dimensions in the illustrative embodiment (but would have more if more quality-controlling parameters were used) the quantized output quality factor Q{tilde over (F)}out and the quantized scaling factor {tilde over (z)}. Quantization is performed in operation 48. Each entry of those arrays is computed as the following:
where JεCi is an image that was assigned to the class Ci, of cardinality |Ci| and with centroid
In order to find an estimator associated to an image J resulting from transformation of an image I, the closest centroid
Finally, the cluster-based relative file size prediction calculator of the predictor of file size 30 (
Ŝ(I,Q{tilde over (F)}out,{tilde over (z)})=S(I)M
It should be noted that the cost, in terms of computation, in the predictor 30 is limited to the cost of computing the closest centroid, which can be computed efficiently using adequate data structures (for details see Jean-Daniel Boissonnat and Mariette Yvinec, “Algorithmic Geometry”, Cambridge University Press, 1998). Once located, the array M
Referring back to
The second training method can be implemented for the predictor of file size 30.
In operation 42, each image in the corpus is used to generate any desired number of exemplars. In operation 42, a large number of images on which were applied quality-controlling parameters changes and scalings, typically in a way that is compatible with the quantization scheme used in the cluster-based relative file size prediction calculator 34, is generated from an image drawn from the corpus. With each exemplar J are stored its vector xJ=(W(J), H(J),αQF (J)), as well as QFout and z.
In sub-operation 43, each of the generated exemplar is added to the exemplar list that also includes the original images from the corpus. Operation 42 is repeated as long as there are images left unprocessed in the corpus.
In the cluster calculator 44, a number k of classes or clusters is specified.
In operation 45, the clusters and centroids are computed. A centroid
In operation 46, the arrays associated to the centroids are populated.
In operation 47, for each exemplar J, the quality factor QFin(J), width H(J) and eight H(J) before transformation of the image are used to find the corresponding centroid and its associated prediction array. The centroid which is the closest to the image I is computed using Equation (11).
In operation 48, the desired quality factor QFout after transformation of the image and scaling factor z are quantized to become respectively Q{tilde over (F)}out and {tilde over (z)}.
Finally, in operation 49, the array M
In experiments, k was chosen such that k=200. It was found empirically that α≈1000.
Results are presented in Table 4. Table 4 illustrates the expected absolute error for clustered prediction array M
As with the predictor of file size 10, the minimum errors in the predictor of file size 30 is concentrated around Q{tilde over (F)}in=Q{tilde over (F)}out=80, with {tilde over (z)}=100%. And the maximal prediction error is given by the portion of Table 4 where Q{tilde over (F)}in, Q{tilde over (F)}out and scaling factor differ the most, for example, in the upper left of Table 4. Similar to Table 2, the gray portion of Table 4 corresponds to the expected absolute errors of 10% or less. However, when comparing the two (2) gray portions of Tables 2 and 4, the expected absolute errors of Table 4 are significantly smaller than those of Table 2, thanks to the use of clusters. For example, the errors went down from 112.93% to 24.82%, from Table 2 to Table 4, in the most difficult transcoding setting, i.e. with Q{tilde over (F)}out=10 and {tilde over (z)}=10%.
Again, although the system and method according to the non-restrictive illustrative embodiments predict the file size of a JPEG image subject to transformation by scaling and a change of quality-controlling parameter, in this case the QF (Quality Factor), it should be kept in mind that the same concepts can be applied to other types of formats such as GIF (Graphics Interchange Format) and other quality-controlling parameters such as the number of colors, the color depth, the color component sampling structure, etc., and transformations such as color enhancement and cropping.
Although the present invention has been described in the foregoing description by means of non-restrictive illustrative embodiments, these illustrative embodiments can be modified at will within the scope of the appended claims without departing from the spirit and nature of the subject invention.
The present application is a Continuation of U.S. patent application Ser. No. 12/741,032 filed on May 2, 2010, which has now been allowed, which is a national stage of the International PCT application serial number PCT/CA2007/001974 to Steven PIGEON et al. entitled “System And Method For Predicting The File Size Of Images Subject To Transformation By Scaling And A Change Of Quality-Controlling Parameters” filed Nov. 2, 2007, entire contents of all applications being incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6154572 | Chaddha | Nov 2000 | A |
6233359 | Ratnakar | May 2001 | B1 |
6421467 | Mitra | Jul 2002 | B1 |
6490320 | Vetro et al. | Dec 2002 | B1 |
6563517 | Bhagwat | May 2003 | B1 |
6608924 | Soliman | Aug 2003 | B2 |
6990146 | Chen | Jan 2006 | B2 |
6992686 | Nagarajan | Jan 2006 | B2 |
7142601 | Kong et al. | Nov 2006 | B2 |
7177356 | Moni et al. | Feb 2007 | B2 |
7245842 | Hino | Jul 2007 | B2 |
7440626 | Kong et al. | Oct 2008 | B2 |
7551785 | Qian et al. | Jun 2009 | B2 |
7583844 | Fehmi et al. | Sep 2009 | B2 |
7668397 | Le Dinh | Feb 2010 | B2 |
7805292 | Huo et al. | Sep 2010 | B2 |
8073275 | Shatz et al. | Dec 2011 | B2 |
20030161541 | Ridge | Aug 2003 | A1 |
20030227977 | Henocq | Dec 2003 | A1 |
20040220891 | Dodgson | Nov 2004 | A1 |
20070160133 | Bao et al. | Jul 2007 | A1 |
20070239634 | Tian | Oct 2007 | A1 |
20080123741 | Li et al. | May 2008 | A1 |
20080279275 | Suzuki | Nov 2008 | A1 |
20090016434 | Amonou et al. | Jan 2009 | A1 |
20090141990 | Pigeon et al. | Jun 2009 | A1 |
20090141992 | Coulombe et al. | Jun 2009 | A1 |
20100150459 | Coulombe et al. | Jun 2010 | A1 |
Number | Date | Country |
---|---|---|
1615447 | Jan 2006 | EP |
0169936 | Sep 2001 | WO |
WO 2006085301 | Aug 2006 | WO |
WO 2006085301 | Aug 2006 | WO |
WO 2006097144 | Sep 2006 | WO |
WO 2006094000 | Sep 2006 | WO |
WO 2006110975 | Oct 2006 | WO |
2009055899 | May 2009 | WO |
Entry |
---|
Pigeon, S., Coulombe, S. “Computationally Efficient Algorithms for Predicting the File Size of JPEG Images Subject to Changes of Quality Factor and Scaling” Proceedings of the 24th Queens Biennial Symposium on Communications, Queen's University, Kingston, Canada, 2008. |
S. Chandra and C. S. Ellis “JPEG Compression Metric as a Quality Aware Image Transcoding” Proceedings of USITS' 99: The 2nd USENIX Symposium on Internet Technologies and Systems. Boulder, Colorado, USA, Oct. 11-14, 1999. |
A. Vetro, C. Christopoulos, and H. Sun, “Video transcoding architectures and techniques: an overview,” IEEE Signal Processing Magazine, vol. 20, No. 2, pp. 18-29, Mar. 2003. |
S. Grgi'c, M. Grgi'c, and M. Mrak, “Reliability of objective picture quality measures,” Journal of Electrical Engineering, vol. 55, No. 1-2, pp. 3-10, 2004. |
OMA Multimedia Messaging Service, Architecture Overview, Approved Version 1.2 01, published by Open Mobile Alliance, available from http://www.openmobilealliance.org/release—program/mms—v1—2.html Mar. 2005. |
Wang, Z., Bovic, A., Rahim, H., Sheikh, Simoncelli, E. “Image Quality Assessment: From Error Visibility to Structural Similarity” IEEE Transactions on Image Processing, vol. 13, No. 4, pp. 600-612, Apr. 2004. |
Lane, T., Gladstone, P., Ortiz, L., Boucher, J., Crocker L., Minguillon, J., Phillips, G., Rossi, D., Weijers, G., “The Independent JPEG Group Software Release 6b” 1998. |
JPEG—Wikipedia, the free encyclopedia, http://en.wikipedia.org/wiki/JPEG, Aug. 5, 2007. |
Avcibas, Ismail; Sankur, Bulent and Sayood, Khalid “Statistical Evaluation of Image Quality Measures” Journal of Electronic Imaging, vol. 11, No. 2, pp. 206-223, Apr. 2002. |
Reed E C et al, “Optimal multidimensional bit-rate control for video communication”, IEEE Transactions on Image Processing, vol. 11, No. 8, Aug. 1, 2002, pp. 873-885. |
Ta-Peng Tan et al, “On the methods and application of arbitrarily downsizing video transcoding”, Multimedia and Expo, 2002. ICME '02. Proceedings. 2002 IEEE International Conference on Lausanne Switzerland Aug. 26-29, 2002, Piscataway, NJ, USA. IEEE US vol. 1, Aug. 26, 2002, pp. 609-612. |
Haiyan Shu et al, “Frame Size Selection in Video Downsizing Transcoding Application”, Conference Proceedings/IEEE International Symposium on Circuits and Systems (ISCAS): May 23-26, 2005, pp. 896-899. |
Haiwei Sun et al, “Fast motion vector and bitrate re-estimation for arbitrary downsizing video transcoding”, Proceedings of the 2003 International Symposium on Circuits and Systems (ISCAS), 2003. vol. 2, Jan. 1, 2003, pp. II-856. |
Shu H et al, “The Realization of Arbitrary Downsizing Video Transcoding”, IEEE Transactions on Circuits and Systems for Video Technology, IEEE Service Center, vol. 16, No. 4, Apr. 1, 2006, pp. 540-546. |
Bruckstein A M et al, “Down-scaling for better transform compression”, IEEE Transactions on Image Processing, vol. 12, No. 9, Sep. 1, 2003, pp. 1132-1144. |
Wang D et al, “Towards Optimal Rate Control: A Study of the Impact of Spatial Resolution, Frame Rate, and Quantization on Subjective Video Quality and Bit Rate”, Visual Communications and Image Processing, 2003, In Proceedings of SPIE, vol. 5150, Jul. 8, 2003, pp. 198-209. |
Herman et al, “Nonlinearity Modelling of QoE for Video Streaming over Wireless and Mobile Network”, Intelligent Systems, Modelling and Simulation (ISMS), 2011 Second International Conference on, IEEE, Jan. 25, 2011, pp. 313-317. |
3GPP in 3GPP TS 23.140 V6.14.0 (Nov. 6, 2006) Technical Specification 3rd Generation Partnership Project; Technical Specification Group Core Network and Terminals; Multimedia Messaging Service (MMS); Functional description; Stage 2 (Release 6) at http://www.3gpp.org/ftp/Specs/html-info/23140.htm (document http://www.3gpp.org/FTP/Specs/archive/23—series/23.140/23140-6e0.zip). |
Multimedia Messaging Service, Media formats and codecs 3GPP TS 26.140, V7.1.0, http://www.3gpp.org/ftp/specs/html-info/26140.htm, Jun. 2007. |
“The independent JPEG Group” ftp.uu.net/graphics/jpeg/jpegsrc.v6b.tar.gz, Aug. 3, 2007. |
S. Coulombe and G. Grassel, “Multimedia adaptation for the multimedia messaging service,” IEEE Communications Magazine, vol. 42, No. 7, pp. 120-126, Jul. 2004. |
Z. Lei and N.D. Georganas, “Accurate bit allocation and rate control for DCT domain video transcoding,” in IEEE CCECE 2002. Canadian Conference on Electrical and Computer Engineering, vol. 2, pp. 968-973, 2002. |
J. Ridge, “Efficient transform-domain size and resolution reduction of images,” Signal Processing: Image Communication, vol. 18, No. 8, pp. 621-639, Sep. 2003. |
Pigeon, S., Coulombe, S. “Very Low Cost Algorithms for Predicting the File Size of JPEG Images Subject to Changes of Quality Factor and Scaling” Data Compression Conference p. 528, 2008. |
Wang, Y. et al: “Utility-Based Video Adaptation for Universal Multimedia Access (UMA) and Content-Based Utility Function Prediction for Real-Time Video Transcoding”, IEEE Transactions on Multimedia, IEEE Service Center, Piscataway, NJ, U.S. vol. 9, No. 2, Feb. 1, 2007, pp. 213-220, XP011346385, ISSN: 1520-9210, DOI: 10.1109/TMM.2006.886253. |
Coulombe S. et al: “Low-Complexity Transcoding of JPEG Images With Near-Optimal Quality Using a Predictive Quality Factor and Scaling Parameters”, IEEE Transactions on Image Processing, IEEE Service Center, Piscataway, NJ, US. vol. 18, No. 3, Mar. 1, 2010, pp. 712-721, XP011297927, ISSN: 1057-7149. |
Number | Date | Country | |
---|---|---|---|
20120237139 A1 | Sep 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12741032 | US | |
Child | 13463694 | US |