BACKGROUND OF THE INVENTION

[0001]
1. Field of the Invention

[0002]
The present invention relates to an image processing scheme used in an image data processing apparatus, an image data processing method, a software program for performing the method, and a recording medium storing the software program therein, and, in particular, to device drivers such as an application program and a printer driver, and so forth for decoding image information, in particular, color image information.

[0003]
2. Description of the Related Art

[0004]
Recently, in a case of transmission or storage of a color image, in order to reduce an amount of data, it is common to compress an original image data. In case the compression is performed, orthogonal transform is performed on components of the image, and, thus, the amount of information is biased in a predetermined manner, and, then, quantization is performed on thusobtained coefficients, so that the information amount is reduced. Further, in order to perform extreme quantization, all specific coefficients may be eliminated (regarded as zero), in some case.

[0005]
Japanese patent publication No. 763177 discloses such an art. In which color image data is transformed into a brightness signal and a colordifference signal for every block unit, orthogonal transform is performed thereon so that coefficients expressing lowfrequency directcurrent components and highfrequency alternatecurrent components are obtained. Then, after that, quantization is performed thereon. On the other hand, as for the colordifference signal, orthogonal transform is not performed, and, only a representative color on each block is quantized and coded.

[0006]
When the thuscompressed image is decompressed, inversequantization is performed, and, therethrough, quantization error may occur between the original image and the decompressed image. When such quantization error is large, the value on each pixel after decompression may exceed a predetermined range.

[0007]
For example, as to a general fullcolor image, for each color component of RGB, each pixel is expressed by 8 bits, i.e., may have a value in a range between 0 and 255. However, due to the abovementioned quantization error, the value of pixel may become negative, or exceeds 255. Such a situation will be referred to as rangeover, hereinafter.

[0008]
When such rangeover occurs, a clipping processing is performed, in which a negative value is replaced by 0 and the value exceeding 255 is replaced by 255, conventionally. However, in case extreme quantization has been made, an amount of rangeover (amount by which the value deviates from the predetermined range) may become large. Accordingly, the color tone/hue may change locally, only through simple clipping processing, and thereby, the image quality may be remarkably degraded.

[0009]
The abovementioned problem is also pointed out by U.S. Pat. No. 5,757,975, ‘Artifact reduction for large dynamic range input data in JPEG compression’. According to this patent, local average values are maintained, and local change in color tone is reduced as a result of peripheral pixels of the rangeover pixel each having a value within a predetermined range being searched for, and the rangeover amount being distributed to/borne by these peripheral pixels.

[0010]
Such a scheme of ‘maintaining local average’ is effective in term of reducing image degradation. However, in order to search for peripheral pixels each having a value within a predetermined range may require a considerable amount of calculation. In fact, for this purpose, it is necessary to read the pixel values on many peripheral pixels, one by one, only for dealing with a single rangeover pixel.
SUMMARY OF THE INVENTION

[0011]
An object of the present invention is to provide an image data processing scheme in which, by considering a quantization rate for each frequency coefficient obtained through frequency transform (such as Stransform, 5×3 wavelet transform, 9×7 wavelet transform), and/or a property of a target image itself (for example, a natural image, or the like), it is possible to quickly correct a deviation in image data occurring in a pixel without performing complex processing, and, thereby, to quickly provide a highquality decompressed image having an effectively reduced hue change occurring through data compression/decompression.

[0012]
An information recording scheme according to the present invention, comprises the following processes:

[0013]
a) at least reducing the deviation on a pixel having a value deviating from a predetermined range through inverse transform of image data from a frequency domain; and

[0014]
b) determining a pixel which should have a value changed in a direction reverse to the deviation, based on a character of the inverse transform.

[0015]
Thereby, it is possible to make the average pixel values uniform through reducing the deviation and also changing a value of another pixel in a direction reverse to the deviation. Also, it is possible to quickly select a pixel which should bear the deviation according to the property/character of the frequency transform scheme applied, and, thus, it is possible to perform image data compression/decompression such as to provide a highquality decompressed image having an effectively reduced hue change, through a relatively simple apparatus configuration, within a short processing time.
BRIEF DESCRIPTION OF THE DRAWINGS

[0016]
Other objects and further features of the present invention will become more apparent from the following detailed description when read in conjunction with the following accompanying drawings:

[0017]
[0017]FIGS. 1A through 1E illustrate Stransform;

[0018]
[0018]FIGS. 2A through 2C illustrate directions among pixels;

[0019]
[0019]FIG. 3 illustrates histograms on HL, LH and HH values in a natural image;

[0020]
[0020]FIG. 4 shows a block diagram of an image data processing apparatus in a first embodiment of the present invention;

[0021]
[0021]FIGS. 5A, 5B, 6A and 6B show flow charts illustrating operations of the image data processing apparatus shown in FIG. 4;

[0022]
[0022]FIG. 7 illustrates pixel positions as rangeover distribution places according to the operations shown in FIGS. 5A, 5B, 6A and 6C;

[0023]
[0023]FIG. 8 shows an example of specific configuration of the image data processing apparatus in the first embodiment shown in FIG. 4;

[0024]
[0024]FIG. 9 shows another example of specific configuration of the image data processing apparatus in the first embodiment shown in FIG. 4;

[0025]
[0025]FIG. 10 shows an encoding (compression) part of the image data processing apparatus in the abovementioned first embodiment;

[0026]
[0026]FIG. 11 shows one example of configuration of a fixedlength code generated by the encoding part shown in FIG. 10;

[0027]
[0027]FIG. 12 shows an operation flow chart on the encoding part shown in FIG. 10;

[0028]
[0028]FIG. 13 shows a decoding (decompression) part of the image data processing apparatus in the first embodiment;

[0029]
[0029]FIG. 14 shows an operation flow chart on the decoding part shown in FIG. 13;

[0030]
[0030]FIG. 15 shows an operation flow chart illustrating rangeover correction processing according to the image data processing apparatus in the first embodiment;

[0031]
[0031]FIGS. 16 through 19 show operation flow charts illustrating the processing shown in FIG. 15 in more detail;

[0032]
[0032]FIG. 20 shows an operation flow chart illustrating rangeover correction processing according to the image data processing apparatus in a second first embodiment (variant of the first embodiment) of the present invention;

[0033]
[0033]FIG. 21 shows an example of a configuration of a fixedlength code generated by processing according to the abovementioned second embodiment;

[0034]
[0034]FIG. 22 shows a block diagram illustrating an image data processing apparatus in a third embodiment of the present invention, in particular, image compression/decompression algorithm according to a DWT scheme in JPEG2000;

[0035]
[0035]FIG. 23 illustrates a twodimensional arrangement of wavelet coefficients together with types of the coefficients;

[0036]
[0036]FIGS. 24A, 24B, 25A, 25B, 26A, 26B and 27A, 27B illustrate examples of constants used for 5×3 wavelet inverse transform;

[0037]
[0037]FIGS. 28A and 28B shows contribution degrees on an error occurring in a pixel at LL position, obtained from the constants shown in FIG. 24A;

[0038]
[0038]FIGS. 29A and 29B shows contribution degrees on an error occurring in a pixel at HL position, obtained from the constants shown in FIG. 25A;

[0039]
[0039]FIGS. 30A and 30B shows contribution degrees on an error occurring in a pixel at LH position, obtained from the constants shown in FIG. 26A;

[0040]
[0040]FIGS. 31A and 31B shows contribution degrees on an error occurring in a pixel at HH position, obtained from the constants shown in FIG. 27A;

[0041]
[0041]FIG. 32 illustrates an example of distribution places predetermined in probabilistic viewpoint according to the abovementioned third embodiment of the present invention;

[0042]
[0042]FIG. 33 shows contribution degrees assuming that the numbers of quantization steps are 1:1:1:1;

[0043]
[0043]FIGS. 34, 35, 36 and 37 illustrate examples of constants used for 9×7 wavelet inverse transform;

[0044]
[0044]FIG. 38 shows contribution degrees on an error occurring in a pixel at each position, obtained from the constants shown in FIGS. 34 through 37 assuming that the numbers of quantization steps are 1:8:8:16;

[0045]
[0045]FIG. 39 shows contribution degrees on an error occurring in a pixel at each position assuming that the numbers of quantization steps are 1:1:1:1 in case of 9×7 wavelet inverse transform;

[0046]
[0046]FIG. 40 illustrates another example of distribution places predetermined in probabilistic viewpoint according to the third embodiment of the present invention;

[0047]
[0047]FIGS. 41A and 41B illustrate polarities of the constants shown in FIGS. 28A and 28B;

[0048]
[0048]FIGS. 42A and 42B illustrate polarities of the constants shown in FIGS. 29A and 29B;

[0049]
[0049]FIGS. 43A and 43B illustrate polarities of the constants shown in FIGS. 30A and 30B;

[0050]
[0050]FIGS. 44A and 44B illustrate polarities of the constants shown in FIGS. 31A and 31B;

[0051]
[0051]FIG. 45 shows the polarities shown in FIGS. 41A through 44B, and, thus directions of contribution in case of 5×3 wavelet inverse transform;

[0052]
[0052]FIG. 46 shows an example of distribution places determined according to the polarities of contribution according to the third embodiment of the present invention;

[0053]
[0053]FIG. 47 shows another example of distribution places determined according to the polarities of contribution according to the third embodiment of the present invention;

[0054]
[0054]FIG. 48 shows another example of distribution places determined according to the polarities of contribution according to the third embodiment of the present invention;

[0055]
[0055]FIG. 49 shows another example of distribution places determined according to the polarities of contribution according to the third embodiment of the present invention;

[0056]
[0056]FIG. 50 shows a partial block diagram of the image data processing apparatus in the third embodiment of the present invention;

[0057]
[0057]FIG. 51 shows an example of a specific configuration of the image data processing apparatus in the third embodiment of the present invention;

[0058]
[0058]FIG. 52 shows another example of a specific configuration of the image data processing apparatus in the third embodiment of the present invention;

[0059]
[0059]FIG. 53 shows a block diagram of a color transform/inverse transform part shown in FIG. 22 in detail;

[0060]
[0060]FIG. 54 shows an operation flow chart on the image data processing apparatus in the third embodiment of the present invention, and illustrates basic decoding processing;

[0061]
[0061]FIGS. 55 through 59 show operation flow charts illustrating the processing shown in FIG. 54 in more detail; and

[0062]
[0062]FIG. 60 shows an operation flow chart on an image data processing apparatus in a fourth embodiment (variant of the third embodiment) of the present invention.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

[0063]
[0063]FIGS. 1A through 1E illustrate Stransform (Smoothing transform), which is one type of orthogonal transform. FIG. 1A shows a set of pixels which is a unit on which Stransform is performed. FIGS. 1B, 1C, 1D and 1E show edges along respective directions for which Stransform detects by components (coefficients) thereof.

[0064]
Stransform is performed according to the following formulas:

LL=(a+b+c+d)/4 (1)

HL=(a+c)/2−(b+d)/2 (2)

LH=(a+b)/2−(c+d)/2 (3)

HH=(a−b)−(c−d) (4)

[0065]
The formula (1) calculates a lowfrequency (directcurrent) component (coefficient) LL; the formula (2) provides a highfrequency (alternatecurrent) component (coefficient) HL detecting a vertical edge, shown in FIG. 1B; the formula (3) provides a highfrequency (alternatecurrent) component (coefficient) LH detecting a horizontal edge, shown in FIG. 1C; and the formula (4) provides a highfrequency (alternatecurrent) component (coefficient) HH detecting an oblique edge or line, shown in FIGS. 1D and 1E.

[0066]
As described above, Stransform is operation in that 2×2 pixels are extracted as a unit for transform from a given image, and thus, the pixel values a, b, c and d thereof are transformed into coefficients LL, HL, LH and HH accordingly. There, the pixel values a, b, c and d may be values on R of RGB, values on G thereof, values on brightness, or values on color difference, and so forth.

[0067]
Inverse Stransform which calculates the values a through d from the four coefficients LL, LH, HL and HH is performed by the following formulas:

a=LL+(HL+LH)/2+HH/4 (5)

b=LL−(HL−LH)/2−HH/4 (6)

c=LL+(HL−LH)/2−HH/4 (7)

d 32 LL−(HL+LH)/2+HH/4 (8)

[0068]
As mentioned above, the coefficient LL is a lowfrequency component, the coefficients HL, LH and HH are highfrequency components, having a large value on vertical edge, horizontal edge and oblique edge, respectively.

[0069]
In case quantization is performed, the quantization rate on the lowfrequency component LL, which has a larger influence on quality of image, is made minimum, while the quantization rates on the highfrequency components, i.e., LH, HL and HH components, are made larger, which has relatively small influence on the quality of image. There, the quantization rate means the degree of reduction on image information through the quantization. For example, when one bit of 8bit data is cut, and obtains 7 bits as a result, the quantization rate is 2^{1}=2. Similarly, when three bits of 8bit data are cut, and obtains 5 bits as a result, the quantization rate is 2^{3}=8.

[0070]
As a result, the quantization error also becomes the minimum on LL component, while becomes larger on LH, HL and HH components. That is, according to a common compression scheme, error occurring on the right side of each of the formulas (5) through (8) during process of decompression may be regarded as the quantization error on LH, HL and HH components.

[0071]
Assuming that ΔE denotes the quantization error on HL, then, as can be seen from the formulas (5) through (8), the polarity (positive/negative) of the error occurring by ΔE appears in the same direction on ‘a’ and ‘c’, while in the reverse direction on ‘b’ and ‘d’. For example, in case ΔE on HL occurs, each of ‘a’ and ‘c’ increases by ΔE/2, while each of ‘b’ and ‘d’ increases by −ΔE/2. Then, when some of the original values of a, b, c and d is close to the lower or upper limit of the range before compression, and, also, ΔE is much larger, the abovementioned rangeover may occur accordingly.

[0072]
It will now be discussed on the abovementioned ‘to maintain local average’ as in the prior art. For example, it is assumed that, as a result of compression and decompression, the pixel value of ‘a’ becomes 260 exceeding 255 which is the upper limit of the range, and this value is corrected to 255 on the range upper limit. In this case, in order to keep the total of a, b, c and d unchanged before and after the correction, it is necessary to add the value 5 (reduced from the pixel as mentioned above) to one or some of the pixels. This processing will be referred to as ‘rangeover correction’.

[0073]
As can be seen from the abovementioned ‘direction’ of error appearance, if ‘c’ is one to be added to, the error on ‘c’ increases, accordingly. On the other hand, if ‘b’ or ‘d’ is one to be added to, the error thereon decreases, accordingly. Thus, according to this logic, the error amount exceeding from ‘a’ should be added to ‘b’ or ‘d’, or both ‘b’ and ‘d’, for the purpose of preventing a pixel having borne the error from having then rangeover occurring therein. Thus, it is possible to previously determine the pixel(s) which should absorb the rangeover amount for each pixel. Similarly, in case ‘a’ becomes lower than the lower limit of the range, or, in case the quantization error occurs on LH or HH, the same discussion can be applied.

[0074]
[0074]FIGS. 2A, 2B and
2C show explanatory notes on direction between these pixels. As shown in the figures, with respect to the pixel ‘a’, the directions on the pixels ‘b’, ‘c’ and ‘d’ can be referred to as ‘horizontal direction’ (see FIG. 2A) , ‘vertical direction’ (see FIG. 2B) and ‘diagonal direction’ (see FIG. 2C), respectively. From the aboveshown discussion, positional relationship between the coefficient on which the quantization error occurs and the pixel which should have the rangeover amount added thereto can be as shown below in Table 1:
 TABLE 1 
 
 
 coefficient having  direction of pixel to have 
 quantization error  rangeover amount added 
 occurring  thereto 
 
 HL  horizontal or diagonal 
 LH  vertical or diagonal 
 HH  horizontal or vertical 
 

[0075]
However, in each actual case, it is not possible to determine as to which coefficient has quantization error such as to cause rangeover. Usually, even it is not possible to determine which coefficient has quantization error occurring therein. Therefore, it is necessary to make processing such as to cope with cases where any coefficient has quantization error occurring therein, or to estimate, by probabilistic manner, as to which coefficient is likely to have quantization error.

[0076]
For example, in case where the rangeover amount is absorbed by a single pixel, the diagonal pixel should be selected according to the abovementioned table 1 assuming that HL or LH coefficient has quantization error causing the rangeover, since the diagonal direction is common between HL and LH in table 1.

[0077]
However, also according to table 1, selection of diagonal pixel should not be made assuming that HH coefficient has quantization error causing the rangeover. However, assuming, in a probabilistic manner, that rangeover caused by HH is not likely to occur in comparison to rangeover caused by HL or LH, selection of diagonal pixel to bear the rangeover amount by considering HL and LH rather than considering HH, is a simple and effective way, for example.

[0078]
In a common compression manner, in many cases, it can be said that rangeover caused by HH is not likely to occur rather than that caused by LH or HL, as will be described now by specific examples.

[0079]
Case 1: Linear Quantization with the Same Number of Quantization Steps for HL, LH and HH

[0080]
In case the number of quantization steps is same, the amounts of quantization error occurring on HL, LH and HH are made same in probabilistic viewpoint. However, as can be seen from the abovementioned formulas (5) through (8), error causing rangeover is ½ of HL or LH while ¼ of HH. Accordingly, simply, rangeover caused by HH should not likely to occur rather than that caused by HL or LH.

[0081]
Case 2: Compression Made on Natural Image and Nonlinear Quantization on HL, LH and HH

[0082]
It is wellknown that, in natural images, oblique edges are not likely to occur rather than vertical or horizontal edges. It is said that this phenomena results from the direction of gravity. This results in a fact that the value on HH is smaller than the value on HL or LH according to the abovementioned formulas (1) through (4). Although HH is obtained not through division by ½ but directly from pixel values, different from LH or HL which is obtained through division by ½ therefrom, as shown in the formulas (2), (3) and (4), the value on HH is still smaller than the value on HL or LH by the abovementioned reason actually in general.

[0083]
[0083]FIG. 3 shows histograms of the values on HL, LH and HH in a natural image. Since it is common for the value of HH to be small compared with the value of HL or LH, the histograms of the values on HL, LH and HH in a natural image is such that coefficients HH having smaller values occur frequently. In nonlinear quantizing the coefficients appearing such histograms, usually in consideration of frequency of appearances, a rang of smaller values is quantized finely (at narrower quantization intervals) while a range of larger values is quantized coarsely (at wider quantization intervals), as shown in FIG. 3. The quantization error becomes larger as the quantization interval is wider. Therefore, through the abovementioned nonlinear quantization, the quantization error becomes larger for LH or HL which has a value larger than HH. Accordingly, rangeover caused by HH becomes much fewer than rangeover caused by HL or LH.

[0084]
A matter as to which pixel is selected to have the rangeover amount added thereto is determined, first, by a probabilistic magnitude relationship on quantization error among LH, HL and HH/2, and, then, second, by the fact that no problem should occur in cases rangeover occurs due to any coefficients. The abovementioned probabilistic quantization error on HH/2 means ½ the quantization error on HH. As the number of quantization steps and quantization intervals are determined by design of a quantizer employed, the probabilistic magnitude relationship on quantization error among LH, HL and HH/2 is also determined by the design of the quantizer accordingly. Thereby, it is also possible to determine a direction in which a pixel to bear the rangeover amount is located with respect to a pixel having the rangeover occurring therein, at the time of design of the quantizer. Thus, by employing such a probabilistic manner, it becomes not necessary to search for a pixel which should bear the rangeover amount.

[0085]
Accordingly, in consideration of the probabilistic magnitude relationship on quantization error, in particular, mainly of the coefficient probabilistically having the maximum quantization error, the predetermined pixel (direction in which the pixel is located) to bear the rangeover amount is obtained as shown in table 2 below:
 TABLE 2 
 
 
 Probabilistic  Direction of  Direction of 
 relationship on  pixel to first  pixel to 
 quantization  bear rangeover  subsequently bear 
 error  amount  rangeover amount 
 
 HL ≧ LH ≧ HH/2  Horizontal  Diagonal 
 HL ≧ HH/2 ≧ LH  Horizontal  Diagonal 
 LH ≧ HL ≧ HH/2  Vertical  Diagonal 
 LH ≧ HH/2 ≧ HL  Vertical  Diagonal 
 HH/2 ≧ HL ≧ LH  Horizontal  Vertical 
 HH/2 ≧ LH ≧ HL  Horizontal  Vertical 
 

[0086]
In consideration of both the probabilistic magnitude relationship (two coefficients other than the coefficient probabilistically having the minimum quantization error) and the fact that no problem should occur in cases rangeover occurs by any coefficients, the predetermined pixel to bear the rangeover amount is obtained as shown in table 3 below:
 TABLE 3 
 
 
 Probabilistic  Direction of  Direction of 
 relationship on  pixel to first  pixel to 
 quantization  bear rangeover  subsequently bear 
 error  amount  rangeover amount 
 
 HL ≧ LH ≧ HH/2  Diagonal  Horizontal 
 HL ≧ HH/2 ≧ LH  Horizontal  Diagonal 
 LH ≧ HL ≧ HH/2  Diagonal  Vertical 
 LH ≧ HH/2 ≧ HL  Vertical  Diagonal 
 HH/2 ≧ HL ≧ LH  Horizontal  Vertical 
 HH/2 ≧ LH ≧ HL  Vertical  Horizontal 
 

[0087]
Although the abovementioned cases are those in which the unit of the amount (for example, R value) undergoing inverse Stransform is the same as the unit of the amount undergoing the rangeover correction (i.e., in case only Stransform is performed, and no colortransform into brightness and/or color difference is performed), it is also possible that the same manner is applied to a case, for example, where the unit of amount undergoing inverse Stransform is brightness and/or color difference, while the unit of amount undergoing rangeover correction is RGB value.

[0088]
For example, in case of the art disclosed by Japanese patent publication No. 763177, color image data in RGB value is transformed into brightness signal and colordifference signal for every block unit, further, orthogonal transform is performed on a brightness signal, and, thus, coefficients are obtained. After that, the coefficients are quantized. On the other hand, the colordifference signal does not undergo orthogonal transform but merely the representative value on each block is quantized and encoded (compressed). Then, when decompressed, inverse orthogonal transform is performed, then, inverse color transform is performed, and, thus, RGB values are obtained.

[0089]
It is assumed that this orthogonal transform is Stransform, and, also, average values on color difference are used as the representative values. Then, as for the average values, since they are equivalent to LL component in Stransform, this means that all the brightness and color difference undergo Stransform, and, as for the color difference, all the HL, LH and HH components are discarded (quantization is performed by the infinite number of quantization steps). Further, in case the image to be compressed is a natural image, the HH components has the minimum value on both the brightness and color difference.

[0090]
The quantization error occurring in the color difference is propagated as being error in RGB as a result during color transform. Accordingly, it is possible to previously determine the pixel to bear the rangeover amount occurring in R value or B value, based on the probabilistic magnitude relationship on quantization error among the Stransform coefficients of color difference components.

[0091]
For example, it is assumed that the color transform is expressed by the following formulas (9) through (11) (called RCT):

Brightness Y=(R+2G+B)/4 (9)

Color difference U=R−G (10)

Color difference V=B−G (11)

[0092]
The inverse transform thereof is expressed by the following formulas (12) through (14):

R=G+U (12)

G=Y−(U+V)/4 (13)

B=V+G (14)

[0093]
The abovedescribed color transform is reversible in case solution of the division by 4 is rounded down by using a floor function, or is rounded up by using a ceiling function, and, thus, is called RCT (Reversible Component Transform). In the specification of the present application, the abovementioned color transform is simply referred to as RCT whether or not it is actually reversible.

[0094]
In decompression, inverse Stransform is performed on both the brightness and color difference. Therefore, in case the U component is discussed for example, and the U component on each pixel shown in FIG. 1A is referred to as Ua, Ub, Uc and Ud on the pixels a, b, c and d, respectively, the U component on each pixel is expressed by the respective components of Stransform, as follows:

Ua=ULL+(UHL+ULH)/2+UHH/4 (15)

Ub=ULL−(UHL−ULH)/2−UHH/4 (16)

Uc=ULL+(UHL−ULH)/2−UHH/4 (17)

Ud=ULL−(UHL+ULH)/2+UHH/4 (18)

[0095]
Where ULL, UHL, ULH and UHH correspond to LL, HL, LH and LL mentioned above.

[0096]
As highfrequency components of U component are discarded uniformly as mentioned above, the quantization error on HH component becomes minimum in each of Ua through Ud, same as in the abovemade discussion.

[0097]
Then, inverse RCT is performed on the respective Ua through Ud by the abovementioned formula (12), into carried Ra through Rd, as follows:
$\begin{array}{cc}\begin{array}{c}\mathrm{Ra}=\mathrm{Ga}+\mathrm{Ua}\\ =\mathrm{Ya}\left(\mathrm{Ua}+\mathrm{Va}\right)/4+\mathrm{Ua}\\ =\mathrm{Ya}+3/4\ue89e\mathrm{Ua}1/4\ue89e\mathrm{Va}\end{array}& \left(19\right)\end{array}$

[0098]
In a common compression scheme, error occurring in Ya is small compared with error occurring in Ua or Va. It is because the quantization rate on brightness is made lower and the quantization rate on color difference is made higher in order to improve the quality of image obtained through decompression, according to a wellknown manner.

[0099]
Consequently, in error occurring in Ra through the formula (19), the quantization errors on Ua and Va are the majority. When a design is made such that the probable quantization errors on Ua and Va be equal to one another, the error resulting from Ua multiplied by ¾ becomes maximum. However, by considering every coefficient, the quantization error on UHH becomes minimum. The same discussion can be applied also for relationship between V component and B value.

[0100]
Accordingly, it is possible to determine the pixel to bear the rangeover amount occurring in R value or B value based on the probabilistic magnitude relationship on quantization error among the Stransform coefficients obtained from the color difference components.

[0101]
Further, any case may occur depending on respective particular quantization rates on the brightness data Y, and color difference data U and V (i.e., a basic design concept). Same as in the abovemade discussion, the quantization error from HH component on brightness or HH component on color difference becomes minimum. Accordingly, it is possible to previously determine the pixel to bear the rangeover amount occurring in G value based on the probabilistic magnitude relationship on quantization error among Stransform coefficients obtained from brightness component or color difference component.

[0102]
The abovemade discussion can be applied not only to RCT but also wellknown YCbCr transform employed by JPEG and so forth by the same manner. Furthermore, as long as inverse Stransform is performed after quantization of Stransform coefficients, the abovemade discussion can be applied not only to a case of decompression but also to a case of decoding.

[0103]
[0103]FIG. 4 shows a block diagram illustrating an image data processing apparatus according to the present invention.

[0104]
The image data processing apparatus in a first embodiment of the present invention shown in FIG. 4 processes image data components (for example, the abovementioned R value, B value, or brightness or color difference value as will be described later) having undergone inverse Stransform, and, includes a rangeover pixel check part 1 searching for a pixel having a component value exceeding the upper limit of a predetermined range, a component value correcting part 2 reducing the component value of the pixel so as to make it fall within the predetermined range, and a component value distributing part 3 increasing the component value of a pixel predetermined based on probabilistic magnitude relationship on quantization error among Stransform coefficients LH, HL and HH/2. According to the embodiment of the present invention, it is possible to control change in color tone/hue during inverse Stransform (decompression/decoding) by a simple scheme, in case of rangeover from the upper limit, and, thereby, it is possible to perform decompression/decoding with effectively reduced loss in image quality.

[0105]
In the abovementioned image data processing apparatus in the first embodiment of the present invention shown in FIG. 4, each part may instead or further perform the following functions. That is, the rangeover pixel check part 1 searches for a pixel having a component value below the lower limit of the predetermined range, the component value correcting part 2 increases the component value of the pixel so as to make it fall within the predetermined range, and the component value distributing part 3 reduces the component value of a pixel predetermined based on probabilistic magnitude relationship on quantization error among Stransform coefficients LH, HL and HH/2. According to the embodiment of the present invention having the abovedescribed configuration, it is possible to control change in color tone/hue during inverse Stransform (decompression/decoding) by a simple scheme, in case of rangeover from the lower limit, and, thereby, it is possible to perform decompression/decoding with effectively reduced loss in image quality.

[0106]
Furthermore, the abovementioned component value distributing part 3 previously determines the pixel to bear the rangeover amount in component value based on estimation as to which one of the Stransform coefficients LH, HL and HH/2 has the minimum quantization error.

[0107]
Thus, when distributing the rangeover amount to the predetermined pixel, it is assumed that this pixel has the value within the predetermined range after having the rangeover amount distributed thereto. However, due to some reason such as accumulation of error among the coefficients and so forth, the value of the pixel having the rangeover amount distributed thereto then has the value which exceeds the upper limit or lower limit of the predetermined range. In such a case, redistribution or rounding processing, as will be described later, is needed. In each of the abovementioned tables 2 and 3, ‘subsequently bear’ means the redistribution.

[0108]
For this purpose, in case the pixel having the rangeover amount distributed thereto then has the value exceeding the upper limit of the predetermined range, the component value correcting part 2 reduces the component value of the pixel having the rangeover amount distributed thereto so as to make it fall within the predetermined range, and, also, the component value distributing part 3 increases a value on a second pixel predetermined based on probabilistic estimation as to which one of the Stransform coefficients LH, HL and HH/2 has the maximum value in quantization error. Thereby, even in case where rangover occurs repeatedly, it is also possible to control change in color tone/hue during inverse Stransform (decompression/decoding) by a simple scheme, and, thereby, it is possible to perform decompression/decoding with effectively reduced loss in image quality.

[0109]
Similarly, for the same purpose, in case the pixel having the rangeover amount distributed thereto then has the value below the lower limit of the predetermined range, the component value correcting part 2 increases the component value of the pixel having the rangeover amount distributed thereto so as to make it fall within the predetermined range, and, also, the component value distributing part 3 reduces a value on a second pixel predetermined based on probabilistic estimation as to which one of the Stransform coefficients LH, HL and HH/2 has the maximum value in quantization error. Thereby, even in case where rangover occurs repeatedly, it is also possible to control change in color tone during inverse Stransform (decompression/decoding) by a simple scheme, and, thereby, it is possible to perform decompression/decoding with effectively reduced loss in image quality.

[0110]
Further, the image data processing apparatus in the first embodiment of the present invention performs the abovementioned rounding processing in case the component value on the abovementioned second pixel having the value thus increased through the redistribution, thereby, has the value exceeding the upper limit of the predetermined range, such as to reduce the value thus exceeding the upper limit so as to make the value on the pixel same as the upper limit of the predetermined range (ceiling function) Similarly, the image data processing apparatus in the first embodiment of the present invention performs the rounding processing in case the component value on the abovementioned second pixel having the value thus reduced through the redistribution, thereby, has the value below the lower limit of the predetermined range, such as to increase the value below the lower limit so as to make the value on the pixel same as the lower limit of the predetermined range (flooring function).

[0111]
Furthermore, in the image data processing apparatus, the component value distributing part 3 increases the value on the pixel diagonal from the pixel having the value exceeding the upper limit of the predetermined range (in a step S4 of FIG. 5) while the exceeding amount of the pixel having the value exceeding is reduced so as to be made it fall within the predetermined range by the component value correcting part 2 (in a step S3) after searching for the pixel having the value exceeding the upper limit of the predetermined range (in a step S1), in case it can be estimated probabilistically that the quantization error on HH/2 is minimum (in a step S1).

[0112]
Similarly, in the image data processing apparatus, the component value distributing part 3 reduces the value on the pixel diagonal from the pixel having the value below the lower limit of the predetermined range (in a step S14 in FIG. 6) while the short amount of the pixel having the value below the predetermined range is increased so as to be made it fall within the predetermined range by the component value correcting part 2 (in a step S13), after searching for the pixel having the value below the lower limit of the predetermined range (in a step S12), in case it can be estimated probabilistically that the quantization error on HH/2 is minimum (in a step S11).

[0113]
Further, in case the value on the pixel thus having the exceeding amount distributed thereto through distribution (in the steps S2S4) exceeds the upper limit of the predetermined range (in a step S5), the component value correcting part 2 reduces the value of this pixel so as to make it fall within the predetermined range (in a step S6), and, then, the component value distributing part 3 increases the value of the pixel located horizontal or vertical from the pixel from which the component value was reduced (in a step S7).

[0114]
Similarly, in case the value on the pixel thus having the short amount subtracted therefrom through distribution (in the steps S12S14) becomes below the lower limit of the predetermined range (in a step S15), the component value correcting part 2 increases the value of this pixel so as to make it fall within the predetermined range (in a step S16), and, then, the component value distributing part 3 reduces the value on the pixel located horizontal or vertical from the pixel from which the component value was increased (in a step S17).

[0115]
[0115]FIG. 7 shows positional relationship among pixel having the value exceeding or below the predetermined range (rangeover), pixels to have the rangeover amount distributed thereto (added thereto/subtracted therefrom and thereby newly having a rangeover amount, and pixels to have the newly rangeover amount redistributed thereto (added thereto/subtracted therefrom).

[0116]
Further, in the image data processing apparatus in the first embodiment, the value to be subtracted from the rangeover pixel (for example, in the step S3) is preferably the same as the value added to the pixel which thus bears the rangeover amount (in the step S4). Similarly, the value to be added to the rangeover pixel (for example, in the step S13) is preferably the same as the value subtracted from the pixel which thus bears the rangeover amount (in the step S14). Thereby, the total amount of the pixel values is maintained.

[0117]
Further, in the first embodiment, in case the value on the pixel having the rangeover amount redistributed thereto (added thereto) exceeds the upper limit of the predetermined range (for example, Yes in a step S8 of FIG. 5B), the component value on the pixel is made to be the same as the upper limit, thus, socalled ceiling processing is performed in a step S9.

[0118]
Similarly, in case the value on the pixel having the rangeover amount redistributed again thereto (subtracted therefrom) becomes below the lower limit of the predetermined range (for example, Yes in a step S18 of FIG. 6B), the component value on the pixel is preferably made to be the same as the lower limit, thus, socalled flooring processing is performed in a step S19.

[0119]
In the abovedescribed first embodiment, as described above, inverse Stransform is performed on the color difference components of image data, and, the abovementioned component values are of R values, G values or B values. Thus, after the inverse Stransform is performed, inverse color transform is performed so that the RGB values are obtained. In this decoding processing, rangeover occurring in RGB values can be simply dealt with by using estimated errors on Stransform coefficients of the color difference components.

[0120]
However, the present invention in the abovementioned first embodiment may also be applied to a case where inverse Stransform is performed on the brightness components of image data, and, the abovementioned components values are of G values. Thus, after the inverse Stransform, inverse color transform is performed so that the G values are obtained. In this decoding processing, rangeover occurring in G values can be simply dealt with by using estimated errors on Stransform coefficients of the brightness components.

[0121]
In general, in order to maintain the image quality through the compression/decompression, the quantization rate on the brightness data is made lower than that on the color difference data. Thereby, as can be seen from the abovementioned formulas (12) through (14), it can be estimated that quantization error occurring on G value is smaller than that on R or B value. As a result, even when quantization error occurs, the rangeover amount is relatively small on G value.

[0122]
Therefore, in the image data processing apparatus in this embodiment, in case G value exceeds the upper limit of the predetermined or becomes below the lower limit thereof, rounding processing is performed, i.e., the abovementioned ceiling processing or flooring processing is performed without distribution of the correction value.

[0123]
Further, in order to make the compression rate on image data variable, it is common that the quantization rate at a time of encoding is made variable, and when the quantization rate is low, it can be estimated that rangeover itself is not likely to occur.

[0124]
Therefore, in the image data processing apparatus in the embodiment, a part of switching as to whether the rangeover amount is distributed or merely rounding processing as mentioned above is performed without distribution of the correction value, depending on the quantization rate on the Stransform coefficients, may preferably be provided. Thereby, it is possible to simplify processing performed in case it is estimated that rangeover amounts, even if any, have smaller values.

[0125]
Further, in the image data processing apparatus in the embodiment, a part of switching as to whether the rangeover amount is distributed or rounding processing as mentioned above is performed without rangeover amount distribution, depending on the quantization rate on the Stransform coefficients, in case where rangeover occurs in G value, may preferably be provided. Thereby, it is possible to simplify processing performed in case it is estimated that rangeover amounts, even if any, should have smaller values.

[0126]
The abovedescribed first embodiment of the present invention will now be described in more detail.

[0127]
[0127]FIG. 8 shows a specific configuration of the image data processing apparatus 1 in the first embodiment of the present invention shown in FIG. 4. The image data processing apparatus 1 includes a RAM 11, a CPU 12, and a HDD 14, which are connected through a data bus 13. This apparatus 1 performs image data compression processing (encoding processing) on an original image.

[0128]
The original image recorded on the HDD 14 is read onto the RAM 11 by a command from the CPU 12 (i). Then, as a compression step, the CPU 12 reads the image from the RAM 11 partially every time (ii), and compresses it through a common encoding scheme described later. The CPU 12 writes the data after compression onto another area in the RAM 11 (iii). After the entire original image is compressed, the data after the compression is recorded onto the HDD 14 by a command from the CPU 12 (iv).

[0129]
Further, in the same apparatus, decompression processing (decoding processing) of compressed image is performed by the following operation flow. The compressed image recorded onto the HDD 14 is read by a command from the CPU 12 onto the RAM 11 (inverse of iv). Then, as an decompression step, the CPU 12 reads partially every time the compressed image from the RAM 11 (inverse of iii), and decompresses it by a decoding (decompression) processing according to the present invention. The CPU 12 writes the data after the decompression onto another area in the RAM 11 (inverse of ii). After the entire compressed image is decompressed, the data after the decompression is recorded onto the HDD 14 by a command from the CPU 12 (inverse of i).

[0130]
[0130]FIG. 9 shows another specific configuration of the image data processing apparatus in the first embodiment of the present invention.

[0131]
The image data processing apparatus shown in FIG. 9 includes a RAM 21 in PC (Personal Computer), a CPU 22 and a HDD 24 in the PC, and a printer 25, which are connected through a data bus 23. On an occasion of printingout of an original image, compression of the image is made and the data after the compression is transmitted to the printer 25. Since the amount of transmission data to the printer 25 is thus reduced, the required transmission time is effectively shortened, and even considering the time required for the compression and decompression, a highspeed printing can be achieved.

[0132]
The original image recorded onto the HDD 24 is read onto the RAM 21 by a command from the CPU 22 (i). Then, as a compression step, the CPU 22 reads the image from the RAM 21 partially every time, and compresses it by a common encoding scheme described later. The CPU 22 writes the data after the compression onto another area in the RAM 21 (iii). The data after the compression is recorded onto a RAM 27 in the printer 25 by a command from the CPU 22 (iv). As an decompression step, a CPU 26 in the printer 25 decompresses the image by a decompression (decoding) processing according to the present invention which reads the data after the decompression (v). The CPU 26 writes the data after decompression onto the RAM 27 (vi). The printer 25 prints out the data after the decompression in a predetermined procedure, after the entire data is decompressed.

[0133]
[0133]FIG. 10 shows a encoding part (compressing part) in the image data processing apparatus in the first embodiment of the present invention, and FIG. 11 shows an example of a code in a fixed length generated by the encoding part shown in FIG. 10. FIG. 12 shows a flow of operation performed by the encoding part shown in FIG. 10. The operation flow on the encoding part shown in FIG. 10 is performed in the apparatus configuration shown in FIG. 8 or 9.

[0134]
The flow of processing on the encoding part (compression part) employs the abovedescribed Stransform (Harr Wavelet transform) for classifying given image data into lowfrequency components and highfrequency components. According to Stransform, transform operation is performed every 2×2 pixels, shown in FIG. 1A. Then, assuming that the pixel values on 2×2 pixels are a, b, c and d, respectively, this block is transformed into four coefficients, i.e., LL, HL, LH and HH, as described above. In case the pixel values a through d are R values on the respective pixels, the Stransform coefficients are Rll, Rhl, Rlh and Rhh. Similarly, in case of G values, Gll, Ghl, Glh and Ghh are obtained. This same manner is applied in case of B values.

[0135]
The image data given as RGB data which takes the value in the range between 0 and 255 (8 bits) is input into an Stransform part 32 by a 2×2pixel extracting part 31 per 4 pixels (in a step S51). In the Stransform part 32, transform by the abovementioned formulas (1) through (4) is performed, and the 12 coefficients of Rll, Rhl, Rlh, Rhh, Gll, Ghl, Glh, Ghh, Bll, Bhl, Blh, and Bhh are calculated and held (in a step S52). Three directcurrent components, Rll, Gll, and Bll, are input into an RCT (Reversible Component Transform) part 34 without being quantized, and while the other alternatecurrent components are made to pass through a quantization part 33, and, then, they are input into the RCT part 34.

[0136]
The quantization part 33 performs linear quantization for 2 bits on all of Rhl, Rlh, Rhh, Bhl, Blh, Bhh, Ghl, Glh, and Ghh into Rhl′, Rlh′, Rhh′, Bhl′, Blh′, Bhh′, Ghl′, Glh′, and Ghh′, which are then held (in a step S53). This manner of quantization corresponds to the abovementioned case 1 with regard to the probabilistic relationship on quantization error.

[0137]
The RCT part 34 performs calculation of Yll, Ull and Vll from Rll, Gll, and Bll through RCT, and are held (in a step S54). Furthermore, Yhl, Ylh, and Yhh are calculated from Rhl′, Rlh′, Rhh′, Bhl′, Blh′, Bhh′, Ghl′, Glh′ and Ghh′ generated by quantization in the step S53, and are held (in a step S55). Here, although even LL through HH are generated on the brightness data Y, in order to improve the compression rate, only LL is generated on the color difference data U and V. This manner also corresponds to the abovementioned case 1 with regard to probabilistic relationship on the quantization error occurring in the S transform coefficients on color difference (same as the abovementioned scheme disclosed by Japanese patent publication No. 763177). Further, also the probabilistic magnitude relationship on quantization error in Stransform coefficients on brightness data corresponds to the abovementioned case 1.

[0138]
The respective YUV coefficients are input to the code generating part 35, are connected so that the fixedlength code 40 of 4 pixels shown in FIG. 11 is generated (in a step S56). This fixedlength code 40 has a configuration such that Yll, Yhl, Ylh, Yhh, Ull, and Vll have fixed lengths of 8, 7, 7, 8, 9 and 9 (bits), respectively. Processing is continued until code generation is completed for all the pixels (in a step S57).

[0139]
Although the order between S transform and color transform (RCT) is reverse from that on the scheme disclosed by Japanese patent publication No. 763177, and, also, the position of the quantization part is different therefrom, it is obvious that the present invention may be applied regardless of the order/position mentioned above.

[0140]
[0140]FIG. 13 shows a block diagram of a decoding part (decompressing part) in the image data processing apparatus in the first embodiment. FIG. 14 shows an operation flow chart of the decoding part shown in FIG. 13.

[0141]
In a code division part 41, the image data Yll, Yhl, Ylh, Yhh, Ull, and Vll for 4 pixels is extracted from the fixedlength code 40 obtained through the encoding process described above with reference to FIGS. 10, 11 and 12 (in a step S66). Then, by an inverse RCT part 42, Rll, Gll, Gll, Rhl′, Rlh′, Rhh′, Bhl′, Blh′, Bhh′, Ghl′, Glh′, and Ghh′ are generated and held (in a step S62). Then, in an inverse quantization part 43, 2bit inverse quantization is performed on the coefficients other than LL, and thereby, Rhl, Rlh, Rhh, Ghl, Glh, Ghh, Bhl, Blh and Bhh are obtained (in a step S63). Then, in an inverse Stransform part 44, inverse S transform is performed on each coefficient, and, thereby, R, G, and B for 4 pixels, i.e., Ra, Rb, Rc, Rd, Ga, Gb, Gc, Gd, Ba, Bb, Bc, and Bd, are calculated (in a step S64), which are then input into a rangeover correcting part 45, which performs rangeover correction operation (in a step S65). These processes are repeated until all the pixels have been processed (decoded). The rangeover correction part 45 includes the abovementioned rangeover pixel check part 1, component value correcting part 2, and component value distributing part 3 shown in FIG. 4.

[0142]
[0142]FIG. 15 shows an operation flow chart on the rangeover correction processing in the image data processing apparatus in the first embodiment of the present invention, and FIGS. 16 through 19 show operation flow charts on the processing shown in FIG. 15 in detail.

[0143]
In this case of the operation, the amount of correction on each pixel is calculated as shown in FIG. 16 for all RGB components, and is held, in a step S71. As shown in FIG. 16,

amount of correction=rangeover amount

[0144]
Then, as described above, as to the quantization error, the abovementioned case 1 is assumed. Accordingly, the error on HH is estimated as being minimum. Further, taking into consideration of coping with errors on both HL and LH, the rangeover amount (correction amount) is added to a diagonal pixel in a step S72. This means that the middle column in the abovementioned table 3 is applied.

[0145]
Then, after that, as the abovementioned rounding processing is performed only on G, the amount of correction is calculated only for R and B in a step S73, and the amount of correction is added to a horizontallyadjacent pixel in a step S74. This means that, in the middle column in the table 3 is applied as mentioned above, and, also, redistribution is made in a horizontal direction (quantization error on HL is first regarded). Then, finally the rounding processing is performed in a step S75.

[0146]
Then, with reference to FIG. 16, an operation flow of the rounding and the correction amount holding processing will now be described.

[0147]
First, each of the amounts of correction on all the positions a, b, c, and d is set to 0 (in a step S81). Then in a step S82, when the component value x is less than 0, the value is set such that x=0, the relevant position (a through d) and the correction amount (x−0) are held in a step S83. When the component value x is larger than 255 in a step S84, the value is set such that x=255, and the relevant position (a through d) and the correction amount (x−255) are held (in a step S85). This processing is repeated on x for the 4 pixels a through d (in a step S86).

[0148]
The flow of abovementioned diagonal position correction processing will now be described with reference to FIG. 17.

[0149]
First, it is determined whether or not the amount of correction is 0 in a step S91. When the amount of correction is not 0, a step S92 is performed, and the amount of correction is added to the component value on the diagonallyadjacent pixel. This processing is repeated on the amount of correction for the 4 pixels (a through d) in a step S93.

[0150]
The flow of abovementioned horizontal position correction processing will now be described with reference to FIG. 18.

[0151]
First, it is determined whether or not the amount of correction is 0 in a step S101. When the amount of correction is not 0, the step S102 is performed, and the amount of correction is added to the component value on a horizontallyadjacent pixel. This processing is repeated on the amount of correction for the 4 pixels (in a step S103).

[0152]
An operation flow of the abovementioned rounding processing will now be described with reference to FIG. 19.

[0153]
First, when the component value x is less than 0 in a step S111, it is set such as x=0 in a step S112. When the component value x is larger than 255 in a step S113, it is set such that x=255 in a step S114. Then, this processing is repeated on x for the 4 pixels (in step S115).

[0154]
[0154]FIG. 20 shows an operation flow on the rangeover correction processing in the image data processing apparatus in a second embodiment of the present invention. FIG. 21 shows an example of configuration of fixedlength code generated by processing concerning processing shown in FIG. 20.

[0155]
In the second embodiment, in a step S121, in case the rate of quantization on all the coefficients is larger than a threshold Th1, the amount of correction on each pixel is calculated through the processing shown in FIG. 16 for all R, G and B, and are held (in a step S122). Furthermore, the rangeover amount (the amount of correction in FIG. 16) is added to a diagonallyadjacent pixel for all R, G and B (in a step S123), and the rounding processing is performed for all R, G and B (in a step S127). However, when the rate of quantization on all the coefficients is not larger than the threshold Th2 in the step S121, the step S124 is performed. In the step S124, when the rate of quantization on all the coefficients is larger than another threshold Th2 (Th1>Th2), the amount of correction on each pixel calculated by the processing shown in FIG. 16 is held in a step S124. Then, for R and B, the rangeover amount is added to a diagonallyhorizontal pixel in a step S126, and, then, for all R, G and B, the rounding processing is performed, in a step S127. When the rate of quantization on all the coefficients is not larger than the threshold Th2, the step S127 is immediately performed without the steps S125 and S126 being performed. With reference to FIGS. 16 through 19, the details of processing therefor have been already described.

[0156]
In the second embodiment, as shown in FIG. 21, a value in a fixed length of 2 bits is added as a header on each pixel such as to indicate as to whether or not the component value is larger than the threshold Th1 or Th2. For example, when it is “11”, the rate of quantization>Th1. “10” indicates that Th1≧quantization rate>Th2. “01” indicates that quantization rate<Th2. Thereby, the step S121 or S124 can make the determination.

[0157]
The abovementioned discussion assumes Stransform. However, the concept of the present invention may also be applied to general transform into frequency domain such as orthogonal transform, widely. That is, it can also be said that, which pixel should bear the rangover amount should be determined by probabilistic magnitude relationship of products between respective elements (which is constants) of a matrix which is used for transform which is inverse of the transform into frequency domain, and quantization errors on respective frequency transform coefficients which are multiplied with these elements, respectively, in inverse transform.

[0158]
Ordinarily, image data has lowfrequency components more than highfrequency component. Accordingly, when an image is considered in a frequency domain, it is possible to allocate codes depending on such unevenness in frequency components. Thereby, it is possible to effectively reduce the data amount. The abovementioned general transform such as orthogonal transform is transform of transforming image data into values in a frequency domain (corresponding to orthogonal transform coefficients, for example).

[0159]
Specifically, transform A is considered which transforms n pieces of image data, i.e., f
0, f
1, . . . , fn−1 into n coefficients, i.e., F
0, F
1, . . . , Fn−1, as follows:
$\underset{\_}{\mathrm{Transform}\ue89e\text{\hspace{1em}}\ue89eA}\ue89e\text{}\left[\begin{array}{c}\mathrm{F0}\\ \mathrm{F1}\\ \vdots \\ \mathrm{Fn}1\end{array}\right]=\left[\begin{array}{cccc}\mathrm{a11}& \mathrm{a12}& \dots & \mathrm{a1n}\\ \mathrm{a21}& \mathrm{a22}& \dots & \mathrm{a2n}\ue89e\text{\hspace{1em}}\\ \vdots & \vdots & \dots & \vdots \\ \mathrm{an1}& \mathrm{an2}& \dots & \mathrm{ann}\end{array}\right]\ue8a0\left[\begin{array}{c}\mathrm{f0}\\ \mathrm{f1}\\ \vdots \\ \mathrm{fn}1\end{array}\right]$

[0160]
Then, the inverse transform thereof B is as follows:
$\underset{\_}{\mathrm{Transform}\ue89e\text{\hspace{1em}}\ue89eB}\ue89e\text{}\left[\begin{array}{c}\mathrm{f0}\\ \mathrm{f1}\\ \vdots \\ \mathrm{fn}1\end{array}\right]=\left[\begin{array}{cccc}\mathrm{b11}& \mathrm{b12}& \dots & \mathrm{b1n}\\ \mathrm{b12}& \mathrm{b22}& \dots & \mathrm{b2n}\\ \vdots & \vdots & \dots & \vdots \\ \mathrm{bn1}& \mathrm{bn2}& \dots & \mathrm{bnn}\end{array}\right]\ue8a0\left[\begin{array}{c}\mathrm{F0}\\ \mathrm{F1}\\ \vdots \\ \mathrm{Fn}1\end{array}\right]$

[0161]
Then, the encoding is to obtain the coefficients F0, F1, . . . , Fn−1 from the image data f0, f1, . . . , fn−1, and, then, as the necessity arises, these coefficients are quantized. Then, further as the necessity arises, entropy coding is performed thereon.

[0162]
On the other hand, in order to decode the thusobtained entropy codes, they are decoded so as to obtain the quantized coefficients, and, then, inverse quantization is performed thereon, and, then, the abovementioned inverse transform B is performed. Thereby, original image data is obtained.

[0163]
Here, assuming that the values obtained through the inverse quantization are F0′, F1′, . . . , Fn−1′, and quantization errors included therein are eF0′, eF1′, . . . , eFn−1′, respectively, as

f 0=b 11·F 0+b 12·F 1+ . . . +b 1 n·Fn−1

[0164]
then,

ef 0=b 11·eF 0′+b 12·eF 1′+ . . . +b 1 n·eFn−1′ (19)

[0165]
where ef0 denotes error occurring in the data f0.

[0166]
Similarly,

ef 1=b 21·eF 0′+b 22·eF 1′+ . . . +b 2 n·eFn−1′ (20)

[0167]
There, it is noted that bij (element of a matrix) on the inverse transform B is constant, and, also, average magnitude relationship between the quantization errors eF0′, eF1′, . . . , eFn−1′ is previously determined, in many cases.

[0168]
For example, in case of linear quantization, as the number of quantization steps (denominator of division in the linear quantization) becomes larger, the quantization error becomes larger, and, also, in many cases, the number of quantization steps is determined for each coefficient, i.e., F0, F1, . . . , or Fn−1. That is, when decoding is performed, it can be estimated that which term of the right side of

ef 0=b 11·eF 0′+b 12·eF 1′+ . . . +b 1 n·eFn−1′

[0169]
i.e., which is maximum of the products of the elements bij and quantization errors eFk can be estimated previously. In other words, it is possible to estimate which term in the right side is a dominant one.

[0170]
Assuming that the dominant term in the right side of the formula (19) is b1n·eFn−1′,

ef 0≈b 1 n·eFn−1′ (21)

[0171]
Similarly, assuming that the dominant term in the right side of the formula (20) is b2n·eFn−1′,

ef 1≈b 2n·eFn−1′ (22)

[0172]
The elements (in the matrix) in the inverse transform B may have a character/property. For example, in case where b1n=−b2n, from the abovementioned formulas (21) and (22),

ef0≈ef1

[0173]
This means, in case an error e occurs in image data f0, an error−e should occur in image data f1.

[0174]
Accordingly, in case the image data f0 is close to the range upper limit (for example, 255), and rangeover occurs on f0 after decoding (for example, 260), the rangeover amount (260−255=5) should be added to the decoded value on the image data f1.

[0175]
Even when b1n=−b2n does not hold, but the polarity therebetween is different, the polarities of errors occurring in the image data f0 and f1 should be opposite.

[0176]
Accordingly, the rangeover amount on f0 should be added to the decoded value on f1. Thereby, error on f1 itself may also be corrected, as a result.

[0177]
Similarly, there are many examples of transform schemes in which a pair having the same absolute values and different polarities is included in the elements of inversetransform matrix, for example, Hadamard transform, slant transform, Stransform, wavelet transform (such as wavelet transform of 5×3, 9×7 or the like, described later). However, in order to obtain the effect of the present invention, the absolute values are not necessarily the same but at only the polarities should be different/opposite.

[0178]
According to the present invention, i.e., a pixel which bears the rangover amount is determined based on probabilistic magnitude relationship of the respective products between elements of the inversetransform matrix and quantization errors occurring in frequency transform coefficients multiplied by these elements, respectively, may be applied not only Stransform but also various transform schemes as long as they has such a character/property.

[0179]
A principle of the present invention will now be described again by using wavelet transform which is described in JPEG2000.

[0180]
[0180]FIG. 22 shows an image data processing scheme in a third embodiment of the present invention illustrating image compression/decompression algorithm on DWT in JPEG2000.

[0181]
As shown in FIG. 22, an image processing apparatus in this third embodiment of the present invention includes a color space transform/inverse transform part 101, or a 2dimensional wavelet transform/inverse transform part 102, a quantization/inverse quantization part 103, and an entropy coding/decoding part 104 and a tag processing part 105. Each part may include separate parts for forward/inverse transform directions. Furthermore, processing performed by each part may be performed for every image data component.

[0182]
There are two types of wavelet transform schemes specified by JPEG2000, i.e., 5×3 wavelet transform and 9×7 wavelet transform, and only these transform schemes will now be described. However, the present invention may also be applied to other types of wavelet transform schemes.

[0183]
In 5×3 wavelet transform, first vertically, the following formula (23) is first applied to pixel values (indicated as P(2i) or the like) on the evennumbered pixels, and pixel values (indicated as P(2i+1) or the like) on the oddnumbered pixels, and, thus, wavelet coefficients on a middle step (C(2i+1) or the like) are obtained. Then, after that, the following formula (24) is applied to the pixel values P(2i) and also the abovementioned wavelet coefficients (C(2i+1) or the like), and, thus, wavelet coefficients (C(2i) or the like) in the middle step are obtained.

C(2 i+1)=P(2 i+1)−└P(2 i)+P(2 i+2))/2┘ (23)

C(2 i)=P(2 i)+└(C(2 i−1)+C(2 i+1)+2)/4┘ (24)

[0184]
where the symbols └, ┘ denote floor functions.

[0185]
Then, horizontally, the abovementioned formula (23) is applied to the coefficient values on oddnumbered and evennumbered pixels (here, as once undergoing the transform vertically, P(2i) and so forth denote coefficients), and, thus, wavelet coefficients are obtained. Then, wavelet coefficients are obtained through the formula (24) applied to the evennumbered coefficient values and oddnumbered wavelet coefficients obtained previously.

[0186]
[0186]FIG. 23 illustrate a 2dimensional arrangement of wavelet coefficients and types thereof.

[0187]
After the abovementioned vertical and horizontal transform has been made, such a 2dimensional arrangement of final wavelet coefficients is obtained. By expressing as C(x, y), C(2i, 2j) is a coefficient LL 111, C(2j+1, 2j) is a coefficient HL 112, C(2i, 2j+1) is a coefficient LH 113, and C(2i+1, 2j+1) is a coefficient HH 114, where i=0 and j=0. Thus, according to wavelet transform, through single transform (decomposition), each of the four types of coefficients LL, HL, LH and HH are obtained in number corresponding to ¼ the number of the total pixels. With regard to decomposition, definition is made in JPEG 2000, Part I, FDIS (Final Draft International Standard), as follows:

[0188]
Decomposition Level

[0189]
A collection of wavelet subbands where each coefficient has the same spatial impart or span with respect to the source component samples. These include the HL, LH, and HH subbands of the same two dimensional subband decomposition. For the last decomposition level, the LL subband is also included.

[0190]
At a time of inverse transform, inverse transform is carried out on these four types of coefficients. First, for the twodimensional arrangement of coefficients, the following formula (25) is applied horizontally to coefficient values (indicated as C(2i), C(2i+1) or the like) on the evennumbered and oddnumbered coefficients, and, thus, wavelet coefficients on a middle step are obtained. Then, after that, the following formula (26) is applied to the oddnumbered coefficient values (C(2i+1) or the like) and evennumbered wavelet coefficient values obtained previously, and, thus, wavelet coefficients on the middle step are obtained.

P(2 i)=C(2 i)−└(C(2 i−1)+C(2 i+1)+2)/4┘ (25)

P(2 i+1)=C(2 i+1)+└(P(2 i)+P(2 i+2))/2┘ (26)

[0191]
where the symbols └, ┘ denote floor functions.

[0192]
Then, vertically the abovementioned formula (25) is applied to the evennumbered and oddnumbered coefficient values, so that pixel values are obtained, and, after that, final pixel values are obtained through the formula (26) applied to the oddnumbered coefficient values, and evennumbered pixel values obtained previously. Thereby, the twodimensional arrangement of coefficients in the frequency domain are inversetransformed into a twodimensional arrangement P(x, y) of pixel values.

[0193]
Thus, also in inverse transform of wavelet transform, each pixel value is given as a linear summation of wavelet coefficients, and, therefor, four types of formulas are used depending on pixel positions in each pixel unit.

[0194]
[0194]FIGS. 24A through 27B show examples of constants used for 5×3 wavelet inverse transform, and each of FIGS. 24A, 25A, 26A and 27A shows constant values on respective pixel positions while each of FIGS. 24B, 25B, 26B and 27B shows corresponding coefficient positions.

[0195]
First, a pixel value P(2i, 2j) is given as a linear summation of nine coefficients surrounding the relevant pixel position. FIG. 24A shows constants (corresponding to the abovementioned elements of the inversetransform matrix) to be multiplied with these nine coefficients at positions corresponding to the coefficients. For example, the position of the coefficient corresponding to the pixel position 121 of the pixel value P(2i, 2j) is shown at a position 122 (position of LL). Namely, the following inverse transform is performed in the case of FIGS. 24A and 24B:

[0196]
P(2i, 2j )=0.0625·C(2i−1, 2j−1)−0.25·C(2i, 2j−1)+0.0625·C(2i+1, 2j−1)−0.25·C(2i−1, 2j)+1·C(2i, 2j)−0.25·C(2i+1, 2j)+0.0625·C(2i−1, 2j+1)−0.25·C(2i, 2j+1)+0.0625·C(2i+1, 2j+1)−0.75

[0197]
where these coefficients C(2i−1,2j−1), C(2i,2j−1), C(2i+1,2j−1), C(2i−1,2j), C(2i,2j), C(2i+1,2j), C(2i−1,2j+1), C(2i,2j+1) and C(2i+1,2j+1) correspond to HH, LH, HH, HL, LL, HL, HH, HL and HH, respectively, shown in FIG. 24B.

[0198]
In case of 5×3, as the constant term ‘2’ is included in the formula (25), the constant ‘−0.75’ is included in the above formula on inverse transform. Further, precisely, the floor function is included in the formula. However, it is omitted as this omission does not affect the discussion according to the present invention.

[0199]
Assuming that the coefficients such as C(
2i,
2j) are those obtained after inverse quantization, and, thus, include quantization error C(
2i,
2j)′, the following formula can be obtained as in the above discussion. In the formula, the abovementioned constant term is not relevant in discussion of errors.
${\left(P\ue89e\left(2\ue89ei,2\ue89ej\right)\right)}^{\prime}=0.0625\xb7{\left(C\ue89e\left(2\ue89ei1,2\ue89ej1\right)\right)}^{\prime}0.25\xb7{\left(C\ue89e\left(2\ue89ei,2\ue89ej1\right)\right)}^{\prime}+0.0625\xb7{\left(C\ue89e\left(2\ue89ei+1,2\ue89ej1\right)\right)}^{\prime}0.25\xb7{\left(C\ue89e\left(2\ue89ei1,2\ue89ej\right)\right)}^{\prime}+{\left(C\ue89e\left(2\ue89ei,2\ue89ej\right)\right)}^{\prime}0.25\xb7{\left(C\ue89e\left(2\ue89ei+1,2\ue89ej\right)\right)}^{\prime}+0.0625\xb7{\left(C\ue89e\left(2\ue89ei1,2\ue89ej+1\right)\right)}^{\prime}0.25\xb7{\left(C\ue89e\left(2\ue89ei,2\ue89ej+1\right)\right)}^{\prime}+0.0625\xb7{\left(C\ue89e\left(2\ue89ei+1,2\ue89ej+1\right)\right)}^{\prime}$

[0200]
Similarly, FIGS. 25A through 27B show constant values used for inverse transform on P(2i+1, 2j), P(2i, 2j+1), P(2i+1, 2j+1), respectively. Same as in FIGS. 24A and 24B, positions of respective pixel values are shown as pixel positions 123, 125 and 127, while corresponding coefficient positions are shown as 124, 126 and 128 (HL, LH, and HH), respectively, there.

[0201]
According to the above discussion, in case of decoding, probabilistic C(2i, 2j)′ and so forth should be previously known. There, C(2i, 2j) is a coefficient LL, C (2i+1, 2j) is a coefficient HL, C(2i+1, 2j) is a coefficient LH, and C(2i+1, 2j+1) is a coefficient HH, as mentioned above. When performing linear quantization in encoding which uses wavelet transform, usually the number of quantization steps (denominator of division performed on the coefficient) is set for these four types of coefficients, as in JPEG2000. As the number of quantization steps is embedded into each code obtained in performing linear quantization in encoding process employing wavelet transform according to JPEG2000, it is possible to know this information in case of decoding. Moreover, also in case quantization is made according to another scheme such as a truncate scheme in which code reduction is made for quantization other than linear quantization, it should be possible to know necessary information on numbers of quantization steps in case of decoding.

[0202]
Assuming that the numbers of quantization steps on LL, HL, LH, and HH are 4, 32, 32, and 64 (1:8:8:16) in the stated order, for example, usually, since probable quantization errors can be approximated as being proportional to the numbers of quantization steps, the following relationship among the quantization errors can be obtained:

C(2 i, 2 j)′:C(2 i+1, 2 j)′:C(2 i+1, 2 j)′:C(2 i+1, 2 j+1)′=1:8:8:16

[0203]
As shown in FIG. 23, although many LL coefficients exist, since the probable quantization errors on all of them are determined according to the number of quantization steps, they become equal.

[0204]
In order to perform inverse quantization, as a simplest scheme, the abovementioned number of quantization steps is multiplied with the corresponding wavelet coefficient. In this case,

[0205]
[wavelet coefficient before quantization]=[wavelet coefficient after inverse quantization]

[0206]
Thus, it can be clearly seen that the abovementioned approximation holds.

[0207]
In order to perform inverse quantization at more precisely, it is a common scheme that an experimentally obtained constant α is used, as follows:

[0208]
[wavelet coefficient after inverse quantization]=([wavelet coefficient]±α)×[number of quantization steps]

[0209]
In this case, although the quantization error may have a value of positive, negative or zero, the abovementioned approximation also holds.

[0210]
[0210]FIGS. 28A through 31B show degrees of contribution by respective positions onto errors occurring in the abovementioned four types of coefficients, obtained from the constants shown in FIGS. 24A through 27B.

[0211]
When the abovementioned probabilistic ratios of quantization errors are multiplied with the constants of FIGS. 24A through 27B, the degrees of contribution by the respective positions onto errors occurring in the pixels at positions on the four types (positions of LL, HL, LH and HH) are shown in FIGS. 28A through 31B, respectively. FIGS. 28A through 31A show the degrees of contribution on respective pixels while FIGS. 28B through 31B show corresponding coefficient positions. In each of FIGS. 28A through 31A, halftone is applied to the positions of coefficients having the largest contribution degrees.

[0212]
As to FIGS. 31A and 31B, the contribution from the HH position is the maximum one of the contribution degrees to the error on the pixel at the HH position. Therefore, when the pixel at the HH position has rangeover (exceeding the range or below the range), it can be estimated that, as a largest probability, this error is mainly caused by the coefficient at the HH position (i.e., the HH coefficient). Since actual rangeover occurs not by the error of HH coefficient solely but by a sum of total 25 times of (error on coefficient×constant), the abovementioned estimation may not precisely hold. However, it can be said that, in many cases, the abovementioned estimation holds.

[0213]
In case a pixel at the HH position exceeds or falls below the range mainly due to the error of the HH coefficient, how the error of the HH coefficient affects other pixels will now be considered. When FIGS. 31A and 31B are compared with FIGS. 29A and 29B, the degree of contribution from the HH position is 9.0 in FIG. 31A while it is −3 in FIG. 29A, which has the reverse polarity. Further, this degree of contribution of −3 is the second one (in magnitude) of those shown in FIG. 29A.

[0214]
Accordingly, when the pixel at the HH position exceeds the range, the pixel at the HL position is likely to, at a high probability, fall below the range. Thus, it can be estimated that the rangeover amount of the pixel at the HH position should be distributed to the pixel at the HL position. Similarly, in case the pixel at the HH position falls below the range, it can be estimated that the rangeover amount of the pixel at the HH position should be distributed to the pixel at the HL position.

[0215]
Further, as the same discussion of ‘9’ and ‘−3’ holds in a case FIGS. 31A and 30A are compared, at a same probability, it can also be said that the rangeover amount of the pixel at the HH position should be distributed into the pixel at the LH position.

[0216]
Through the same discussion, in case an error occurs at an HL position, according to FIGS. 29A and 29B, it can be estimated that this error is mainly caused by the error by the coefficient at the HL position (the maximum degree of contribution of 6). Further, according to FIGS. 28A and 28B, the error on the coefficient at the HL position contributes onto the pixel at the LL position in the reverse direction and also with the maximum magnitude (degree of contribution: −2). Accordingly, the rangeover amount occurring on the pixel at the LH position should be distributed onto the pixel at the LL position. Subsequent to the LL position, the pixel at the LH position having the contribution degree of −1 (see FIGS. 30A and 30B) is a second candidate to bear the rangeover amount.

[0217]
Further, as a subsequent third candidate for the LH position, as it is considered that the rangeover occurs due to the HH position having the contribution degree of ‘−3’ (see FIGS. 29A and 29B) having the magnitude subsequent to the magnitude of the abovementioned contribution degree of ‘6’ from the LH position itself, the rangeover amount should be distributed to the HH position having the contribution degree of ‘9’ onto the HH position itself (see FIGS. 31A and 31B) which has the polarity (positive) reverse to the polarity (negative) of the abovementioned contribution degree of ‘−3’.

[0218]
A rangeover amount at the LL position should be distributed to HL or LH having the contribution degree of ‘6’ having the reverse polarity and maximum magnitude onto HL or LH itself (see FIGS. 29A, 29B and 30A, 30B) with respect to the contribution degree of ‘−2’ (see FIGS. 28A and 28B).

[0219]
[0219]FIG. 32 shows an example of distribution places predetermined from a probabilistic viewpoint, on the occasion of range over, according to the above discussion.

[0220]
Thus, the rangeover amount should be distributed to the pixel at HL or LH position, when the pixel at LL position causes range over; the rangeover amount should be distributed to the pixel at LL position (the next candidate is LH position), when the pixel at HL position causes rangeover; the rangeover amount should be distributed to the pixel at LL position (the next candidate is HL position), when the pixel at LH position causes range over; and the rangeover amount should be distributed to the pixel at HL or LH position, when the pixel at HH position causes range over.

[0221]
In the above discussion, it is assumed that the ratio on the numbers of the quantization steps is 1:8:8:16 as mentioned above. In case the same is assumed as 1:1:1:1, for example, different discussion should be made.

[0222]
[0222]FIG. 33 shows the contribution degrees in case the ratio on the numbers of the quantization steps is 1:1:1:1. In FIG. 33, merely the contribution degree having the maximum magnitude is shown for each position, and corresponds to a summary of the information shown in FIGS. 28A through 31B. By applying the same discussion, the same result as that shown in FIG. 32 is obtained. Accordingly, it is possible to determine the rangeoveramount distribution destinations regardless of the ratio of the numbers of quantization steps.

[0223]
According to the scheme shown in FIG. 33, from the LL position, the pixel of HL position is “a pixel adjacent in the horizontally right direction”, and the pixel of LH position is “a pixel adjacent in the vertically downward” (see FIG. 23). However, as the symmetry in contribution can be seen from FIGS. 28A through 31B, it can also be said for thesame case that the pixel of HL position is “a pixel adjacent in the horizontally left direction”, and the pixel of LH position is “a pixel adjacent in the vertically upward”. Accordingly, it is also possible not to distinguish between right and left and between upward and downward.

[0224]
Although 5×3 wavelet has been discussed above, for example, 9×7 wavelet will now be discussed in the same manner, as another example.

[0225]
[0225]FIGS. 34 through 37 show examples of constants used for 9×7 wavelet inverse transform. In FIGS. 34 through 37, the pixel values P(2i, 2j), P(2i+1, 2j), P(2i, 2j+1), and P(2i+1, 2j+1) are shown in pixel positions 131, 132, 133, and 134, and they correspond to the coefficient positions LL, HL, LH, and HH, respectively.

[0226]
[0226]FIG. 38 shows degrees of contribution in case the ratio of the numbers of quantization steps is assumed as being 1:8:8:16, while FIG. 39 assumes the same as being 1:1:1:1. In FIGS. 38 and 39, for the sake of simplification, only the contribution degree of the maximum magnitude is shown for each position.

[0227]
Also in the case of 9×7 wavelet transform, same as in the case of 5×3 wavelet transform, the constants used for wavelet inverse transform shown in FIGS. 34 through 37 are obtained, and, then, based on the contribution degrees shown in FIGS. 38 and 39, through the same discussion, it can be said that the scheme shown in FIG. 32 can also be applied. As to the specific detail scheme of 9×7 wavelet transform, see JPEG2000, standard specification and so forth.

[0228]
According to the above discussion, when image data components inversetransformed from the frequency domain is processed, a pixel which has a component value exceeding/falling below the range is searched for. Then, the rangeover amount is reduced/added so as to make the component value fall within the range. Then, the component value on a pixel predetermined by using a probabilistic magnitude relationship of products between respective elements of the matrix used for the inverse transform and respective quantization errors to be multiplied with these elements should be added/reduced accordingly to bear he rangeover amount.

[0229]
Then, after that, when this predetermined pixel thus having the component value added/reduced to bear the rangeover amount then becomes excess or below the range, redistribution or rounding processing mentioned above with reference to the first embodiment of the present invention should be made.

[0230]
[0230]FIG. 40 shows a preferable scheme in the abovedescribed third embodiment in which, in case, after the rangeover amount is borne by a predetermined pixel, which then has a component value exceeding/falling below the predetermined range, the thusoccurring second rangeover amount is then borne by a second predetermined pixel. In FIG. 40, in the third line, the rangeover amount of LH position is distributed to/borne by the LL position pixel, and, then, the second rangeover amount, if any, is distributed to/borne by the LH position. In this connection, this rangeover amount of LL position may be borne by either the LH position pixel or HL position pixel, probabilistically. Then, by holding the position information of the distribution origin, it is possible to know whether this rangeover occurs due to distribution from HL or LH. However, in order to omit holding this information, the second predetermined pixel is determined as LH position pixel in this case for the sake of simplification of operation needed for performing the rangeover dealingwith processing.

[0231]
In order to further simplify the processing, the following discussion is made. That is, without regarding the absolute values of the abovementioned contribution degrees, merely the polarities thereof should do well. Accordingly, without regarding the quantization errors, it is possible to obtained an effect of effective rangeover correction even when the effect may not be necessarily maximum or optimum, as long as the polarities of the elements of the inverse transform matrix are opposite. Furthermore, by regarding not only the polarities of the elements of the inverse transform matrix but also the magnitudes thereof, an effect of effective rangeover correction can be obtained without regard of the quantization errors, i.e., the ratio of the numbers of quantization steps.

[0232]
[0232]FIGS. 41A through 44B show merely the polarities on the contribution degrees obtained from FIGS. 28A through 31B, respectively. FIGS. 41A through 44A show the polarities of the contribution degrees, while FIGS. 41B through 44B show the corresponding coefficient positions. In FIGS. 41A through 44A, halftone is applied to the coefficient position having the maximum contribution degree.

[0233]
The pixel value P(2i, 2j) is given as a linear sum of the nine coefficients which surround the relevant pixel position. FIG. 41A shows the polarities of the respective constants to be multiplied with these nine coefficients at the corresponding positions of the coefficients shown in FIG. 41B. In the figures, the pixel position 141 corresponds to the pixel value P(2i, 2j) and the coefficient position 142 (position of LL) corresponds thereto. Similarly, FIGS. 42A through 44A shows the polarities of the constants used for the inverse transform for the pixel values P(2i+1, 2j), P(2i, 2j+1) and P(2i+1, 2j+1). Similar to FIGS. 41A and 41B, the pixel positions 143, 145 and 147 correspond to the respective pixel values, and the coefficient positions 144, 146 and 148 (positions of HL, LH and HH) correspond thereto, respectively.

[0234]
There, the positive polarity (+) means that, when the polarity of the quantization error of the wavelet coefficient with which the relevant coefficient is multiplied is positive, the positive error is propagated into the pixel value. Similarly, the negative polarity (−) means that, the error in the opposite polarity is propagated. FIG. 45 shows these polarities in summary. FIG. 45 shows the direction (polarity) of contribution from the coefficients, onto each position according to 5×3 wavelet inverse transform. In case of 9×7 wavelet inverse transform, the same result as that shown in FIG. 45 is obtained.

[0235]
For example, when the pixel of LL position exceeds the range and it originates from the error of the coefficient of HL position, the error of the coefficient HL is propagated with the opposite polarity to the pixel of HH position (in the first and fourth lines of FIG. 45). Moreover, when the range over on the pixel at he LL position originates from the error of the coefficient of LH position, the error of this coefficient lH is similarly propagated with the opposite polarity to the pixel of HH position. (in the same first and fourth lines of FIG. 45). That is, a method for distributing the rangeover amount on the pixel of LL position to HH position can be considered. This scheme corresponds to the abovedescribed first embodiment of the present invention from the standpoint in that a process should be determined such that a predetermined effect can be obtained regardless of which coefficient causes the error’. As the relationships with the pixels at the HL position and LH position are the same, this scheme can do well.

[0236]
[0236]FIG. 46 shows an example of distribution places predetermined only from the polarities of the contribution degrees on the occasion of rangeover.

[0237]
In case the rangeover correction processing is performed on every four pixels defined by rectangular shown in FIG. 23 for the purpose of saving the memory capacity, a simple scheme only in consideration of polarity can be employed in which, a first distribution place can be specified as a diagonal pixel, as shown in FIG. 46. That is, when a pixel having rangeover occurring therein is any of LL position, HL position, LH position, or HH position, the first distribution is made onto the pixel located diagonal therefrom, as shown in FIG. 46. In case rangeover again occurs as a result of the abovementioned first distribution being performed, it can be estimated that the abovementioned first estimation is wrong. Accordingly, it is estimated that the correct origin of the error is HH position, and, thus, redistribution is made between LL and LH positions, and between HL and HH positions.

[0238]
[0238]FIGS. 47 through 49 show other examples of he distribution places predetermined only from the polarities of contribution degrees, on the occasion of range over, respectively.

[0239]
Similar to the scheme shown in FIG. 46, in case of taking only the polarity into consideration for determining the distribution place, the selection shown in FIG. 47 on the second distribution place is also possible. That is, the first distribution is made according to the scheme shown in FIG. 46, and, then, in case rangeover again occurs as a result of the abovementioned first distribution being performed, it can be estimated that the abovementioned first estimation is wrong. Accordingly, it is estimated that the correct origin of the error is HH position, and, thus, redistribution is made between LL and HL positions, and between LH and HH positions.

[0240]
As to the scheme shown in FIG. 48, similar to the scheme shown in FIG. 46, in case of taking only the polarity into consideration for determining the distribution place, the selection shown in FIG. 48 on the second distribution place is also possible. That is, the first distribution is made, different from the schemes shown in FIGS. 46 and 47, and, thus, the rangeover amount is first distributed to a pixel vertically adjacent to the pixel first having the rangeover occurring therein, as shown in FIG. 48. Then, in case rangeover again occurs as a result of the abovementioned first distribution being performed, it can be estimated that the abovementioned first estimation is wrong. Accordingly, it is estimated that the correct origin of the error is LH position, and, thus, redistribution is made onto a pixel diagonally adjacent to or horizontally adjacent to the abovementioned pixel first having the rangeover occurring therein, as shown in FIG. 48.

[0241]
As to the scheme shown in FIG. 49, similar to the scheme shown in FIG. 46, in case of taking only the polarity into consideration for determining the distribution place, the selection shown in FIG. 48 on the second distribution place is also possible. That is, the first distribution is made, different from the schemes shown in FIGS. 46, 47 and 48, and, thus, the rangeover amount is first distributed to a pixel horizontally adjacent to the pixel first having the rangeover occurring therein, as shown in FIG. 49. Then, in case rangeover again occurs as a result of the abovementioned first distribution being performed, it can be estimated that the abovementioned first estimation is wrong. Accordingly, it is estimated that the correct origin of the error is HL position, and, thus, redistribution is made onto a pixel diagonally adjacent to or vertically adjacent to the abovementioned pixel first having the rangeover occurring therein, as shown in FIG. 49.

[0242]
These schemes are those which disregard the probable standpoint and give priority to simplification of processing. In contrast thereto, schemes in consideration of the degree of contribution based not only on the polarities of elements of the matrix used for inverse transform but also the magnitudes thereof can be considered. In this case, FIG. 33 mentioned above also shows the degree of contribution based not only on the polarities of elements of the matrix used for inverse transform but also the magnitudes thereof. Therefore, in 5×3 wavelet transform, the distribution place predetermined using “the degree of contribution based not only on the polarities of elements of the matrix used for inverse transform but also the magnitudes thereof are those shown in FIG. 32 or 40.

[0243]
Similarly, in the case of 9×7 wavelet, FIG. 39 shows the degree of contribution and FIG. 40 shows the distribution place.

[0244]
[0244]FIG. 50 shows a block diagram illustrating an image data processing apparatus in the abovedescribed third embodiment of the present invention.

[0245]
The image data processing apparatus in the third embodiment of the present invention shown in FIG. 50 processes image data components (for example, the abovementioned R values, B values, or brightness or color difference values being described later) having undergone inverse transform of a predetermined transform into frequency domain, and, includes a rangeover pixel check part 151 searching for a pixel having a component value exceeding the upper limit of a predetermined range, a component value correcting part 152 reducing the component value of the pixel so as to make it fall within the predetermined range, and a component value distributing part 153 increasing the component value of a pixel predetermined based on the polarity (or, polarity and magnitude) of each element of a matrix used for the inverse transform. Also according to the third embodiment of the present invention, it is possible to control change in color tone/hue during inverse transform (decompression/decoding) by a simple scheme, in case of rangeover from the upper limit, and, thereby, it is possible to perform decompression/decoding with effectively reduced loss in image quality.

[0246]
Further, in the abovementioned third embodiment, the rangeover pixel check part 151 also searches for a pixel having a component value below the lower limit of the predetermined range, the component value correcting part 152 increases the component value of the pixel so as to make it fall within the predetermined range, and the component value distributing part 153 reduces the component value of a pixel predetermined based on the polarity (or, polarity and magnitude) of each element of a matrix used for the inverse transform. According to the third embodiment of the present invention, it is possible to control change in color tone/hue during inverse transform (decompression/decoding) by a simple scheme, in case of rangeover from the upper limit, and, thereby, it is possible to perform decompression/decoding with effectively reduced loss in image quality.

[0247]
In any of the abovementioned cases where the rangeover amount borne by or distributed to the predetermined pixel, this predetermined pixel may thus have a component value exceeding or below the predetermined range, due to accumulation of errors between coefficients, or the like. In such a case, redistribution or rounding processing is performed according to any of the abovementioned tables 2 and 3, where ‘subsequently bear’ means the redistribution.

[0248]
For this purpose, in case the pixel having the rangeover amount distributed thereto has the value exceeding the upper limit of the predetermined range, the component value correcting part 152 reduces the component value of the pixel having the rangeover amount distributed thereto so as to make it fall within the predetermined range, and, also, the component value distributing part 153 increases a value on a second pixel predetermined based on the polarity (or polarity and magnitude) of each element of the matrix used for the inverse transform. Thereby, even in case where rangover occurs repeatedly, it is also possible to control change in color tone/hue during inverse Stransform (decompression/decoding) by a simple scheme, and, thereby, it is possible to perform decompression/decoding with effectively reduced loss in image quality.

[0249]
Similarly, for the same purpose, in case the pixel having the rangeover amount distributed thereto has the value below the lower limit of the predetermined range, the component value correcting part 152 also increases the component value of the pixel having the rangeover amount distributed thereto so as to make it fall within the predetermined range, and, also, the component value distributing part 153 reduces a value on a second pixel predetermined based the polarity (or polarity and magnitude) of each element of the matrix used for the inverse transform. Thereby, even in case where rangover occurs repeatedly, it is also possible to control change in color tone during inverse Stransform (decompression/decoding) by a simple scheme, and, thereby, it is possible to perform decompression/decoding with effectively reduced loss in image quality.

[0250]
Further, the image data processing apparatus in the third embodiment of the present invention performs rounding processing in case the component value on the abovementioned second pixel having the value thus increased through the redistribution, thereby, has the value exceeding the upper limit of the predetermined range, such as to reduce the value exceeding the upper limit so as to make the value on the pixel same as the upper limit of the predetermined range. Similarly, the image data processing apparatus in the third embodiment of the present invention performs rounding processing in case the component value on the abovementioned second pixel having the value thus reduced through the redistribution, thereby, has the value below the lower limit of the predetermined range, such as to increase the value below the lower limit so as to make the value on the pixel same as the lower limit of the predetermined range.

[0251]
In the image data processing apparatus in the third embodiment of the present invention, the abovementioned predetermined pixel is one adjacent vertically to the rangeover pixel, and also, the abovementioned second predetermined pixel is one adjacent horizontally or diagonally to the same rangeover pixel.

[0252]
Instead, in the image data processing apparatus in the third embodiment of the present invention, the abovementioned predetermined pixel may be one adjacent horizontally to the rangeover pixel, and also, the abovementioned second predetermined pixel may be one adjacent vertically or diagonally to the same rangeover pixel.

[0253]
Instead, in the image data processing apparatus in the third embodiment of the present invention, the abovementioned predetermined pixel may be one adjacent diagonally to the rangeover pixel, and also, the abovementioned second predetermined pixel may be one adjacent horizontally to the same rangeover pixel.

[0254]
Further, in the image data processing apparatus in the third embodiment of the present invention, the abovementioned predetermined pixel may be one adjacent vertically, horizontally or diagonally to the rangeover pixel.

[0255]
Further, in the image data processing apparatus in the third embodiment, it is preferable to make the amount reduced from/added to the rangeover pixel so as to make the pixel have the component value fall within the predetermined range equal to the amount added to/reduced from the predetermined pixel to which the rangeover amount is thus distributed from the rangeover pixel. Thereby, it is possible to maintain the total component value of all the pixels, and, thus, hue change occurring through image data compression/decompression can be effectively reduced.

[0256]
In the abovedescribed third embodiment, as described above, the inverse transform is performed on the color difference components of image data, and, the abovementioned component values are of R values, G values or B values. Then, after the inverse transform, inverse color transform is performed so as to obtain these component values. In this decoding processing, rangeover occurring in RGB value is dealt with by using the polarity (or polarity and magnitude) of each element of the matrix used for the inverse transform.

[0257]
However, the present invention in the abovementioned third embodiment may also be applied to a case where the inverse transform is performed on the brightness component of image data, and, the abovementioned component values are of G values. Then, after the inverse transform, inverse color transform is performed so as to obtain these component values. In this decoding processing, rangeover occurring in G value is dealt with by using by using the polarity (or polarity and magnitude) of each element of the matrix used for the inverse transform.

[0258]
In general, in order to maintain the image quality through the compression/decompression, the quantization rate on the brightness data is made lower than that on the color difference data. Thereby, as can be seen from the abovementioned formulas (12) through (14), it can be estimated that quantization error occurring on G value is smaller than that on R or B value. As a result, even when quantization error occurs, the rangeover amount is relatively small on G value.

[0259]
Therefore, in the image data processing apparatus in this embodiment, in case G value exceeds the upper limit of the predetermined or becomes below the lower limit thereof, merely rounding processing is performed, i.e., the abovementioned ceiling processing or flooring processing, without performing distribution of correction value.

[0260]
Further, in order to make the compression rate on image data variable, it is common that the quantization rate at a time of encoding is made variable, and when the quantization rate is low, it can be estimated that rangeover itself is not likely to occur.

[0261]
Therefore, in the image data processing apparatus in the embodiment, a part of switching as to whether the rangeover amount is distributed or merely rounding processing as mentioned above is performed, depending on the quantization rate on the frequency transform coefficients, may preferably be provided. Thereby, it is possible to simplify the processing in case it is estimate that rangeover amounts, if any, have smaller values.

[0262]
Further, in the image data processing apparatus in the third embodiment, a part of switching as to whether the rangeover amount is distributed or merely rounding processing as mentioned above is performed, depending on the quantization rate on the frequency transform coefficients, in case where rangeover occurs in G value, may preferably be provided. Thereby, it is possible to simplify the processing in case it is estimate that rangeover amounts, if any, have smaller values.

[0263]
The abovedescribed third embodiment of the present invention will now be described in more detail.

[0264]
[0264]FIG. 51 shows a specific configuration of the image data processing apparatus in the third embodiment of the present invention shown in FIG. 50. The image data processing apparatus includes a RAM 161, a CPU 162, and a HDD 164, which are connected through a data bus 163. This apparatus performs image data compression processing (encoding processing) on an original image.

[0265]
The original image recorded on the HDD 164 is read onto the RAM 161 by a command from the CPU 162 (i). Then, as a compression step, the CPU 162 reads the image from the RAM 161 partially every time (ii), and compresses it through a common encoding scheme described later. The CPU 162 writes the data after compression onto another area on in the RAM 11 (iii). After the entire original image is compressed, the data after compression is recorded onto the HDD 164 by a command from the CPU 162 (iv).

[0266]
Further, in the same apparatus, decompression processing (decoding processing) of compressed image is performed by the following operation flow. The compressed image recorded onto the HDD 164 is read by a command from the CPU 162 onto the RAM 161 (inverse of iv). Then, as a decompression step, the CPU 162 reads partially every time the compressed image from the RAM 161 (inverse of iii), and decompress it by a decoding (decompression) processing according to the present invention. The CPU 162 writes the data after decompression onto another are in the RAM 161 (inverse of ii). After the entire compressed images are decompressed, the data after decompression is recorded onto the HDD 164 by a command from the CPU 162 (inverse of i).

[0267]
[0267]FIG. 52 shows another specific configuration of the image data processing apparatus in the third embodiment of the present invention.

[0268]
The image data processing apparatus shown in FIG. 52 includes a RAM 171 in PC (Personal Computer), a CPU 172 and a HDD 174 in the PC, and a printer 175, which are connected through a data bus 173. On an occasion of printingout of an original image, compression of the image is made and the data after compression is transmitted to the printer 175. Since the amount of transmission data to the printer 175 is thus reduced, the required transmission time is effectively shortened, and even considering the time required for the compression and decompression, a highspeed printing can be achieved.

[0269]
The original image recorded onto the HDD 174 is read onto the RAM 171 by a command from the CPU 172 (i). Then, as a compression step, the CPU 172 reads the image from the RAM 171 partially every time, and compresses it by a common coding scheme described later. The CPU 172 writes the data after compression onto another area in the RAM 171 (iii). The data after compression is recorded onto a RAM 177 in the printer 175 by a command from the CPU 172 (iv). As an decompression step, a CPU 176 in the printer 175 decompresses the image by a decompression (decoding) processing according to the present invention which reads the data after compression (v). The CPU 176 writes the data after decompression onto the RAM 177 (vi). The printer 175 prints out the data after the decompression in a predetermined procedure, after the entire data is decompressed.

[0270]
[0270]FIG. 53 shows the color transform part/inverse color transform part 101 in the image data processing apparatus shown in FIG. 22 in detail. The outline of decompression processing according to JPEG2000 is as shown in FIG. 22. In this color transform part/inverse color transform part 101, in compression process, color transform is performed by a the color transform part 181, inverse color transform is performed by an inverse color transform part 182 in decompression processing, and, the abovementioned rangeover pixel value is dealt with by a rangeover correction part 183 which includes the rangeover check part 151, component value correction part 152 and component value distribution part 153 shown in FIG. 50. Moreover, 5×3 wavelet or 9×7 wavelet is applicable as transform of the present invention as mentioned above. Moreover, in case color transform is made into brightness values/color difference values from the RGB value by JPEG2000, RCT is employed in case of using 5×3 wavelet, while YCbCr transform (referred to as ICT according to JPEG2000) is employed in case of using 9×7 wavelet.

[0271]
According to JPEG2000, as described above, coefficients F0, F1, . . . , Fn−1 are obtained from given image data f0, f1, . . . , fn−1, and, then, as the necessity arises, these coefficients are quantized, and, then, as the necessity arises, entropy encoding is performed on the coefficients having undergone the quantization. In decompression, similar processing is performed in an approximately inverse direction. The present invention is applied to rangeover correction on RGB values or the like after undergoing inverse color transform (inverse color transform may be omitted) in the decompression. More precisely according to JPEG2000, compression is made after an offset is added to RGB value or the like (referred to as DC shift according to JPEG2000). Accordingly, according to the present invention, rangeover correction is performed after the offset is cancelled.

[0272]
[0272]FIG. 54 shows a flow chart illustrating basic processing of the image data processing apparatus in the third embodiment, while FIGS. 55 through 59 illustrate detail thereof.

[0273]
As shown in FIG. 54, the image data processing apparatus decodes given entropy codes (in a step S201) and, then, after the completion of decoding, inverse quantization is performed on all the thusobtained wavelet coefficients (in a step S202). Then, inverse wavelet transform is performed on the wavelet coefficients having undergone the inverse quantization, and, thus, brightness value and color difference value are calculated on each pixel (in a step S203). Then, inverse color transform is performed on the thusobtained brightness value and color difference value (in a step S204). Finally, rangeover correction processing is performed on the thusobtained pixel values (in a step S205). This rangeover correction processing may include the abovementioned rounding and holding processing (after rounding processing, holding rangeover amount), correction processing (distributing the rangeover amount onto a predetermined pixel), and simple rounding processing. FIGS. 55 through 58 show details thereof.

[0274]
With reference to FIG. 55, the rounding and holding processing will now be described.

[0275]
In this case of operation, RCT or ICT is performed, and, the component value x denotes R, G or B value. First, correction values on 4 pixels (LL, HL, LH, and HH position) are set to 0 (in a step S211). Then in a step S212, when the component value x is less than 0, the value is set such that x=0, and the relevant position (LL, HL, LH or HH) and the correction amount (x−0) are held in a step S213. When the component value x is larger than 255 in a step S214, the value is set such that x=255, and the relevant position (LL, HL, LH or HH) and the correction amount (x−255) are held (in a step S215). This processing is repeated on x for the 4 pixels (in a step S216).

[0276]
The flow of abovementioned correction processing will now be described with reference to FIG. 56.

[0277]
First, it is determined whether or not the amount of correction is 0 in a step S221. When the amount of correction is not 0, a step S222 is performed, and the amount of correction is added to the component value on a pixel predetermined according to any of the tables shown in FIGS. 46 through 49 (FIG. 32 or 40). This processing is repeated on the amount of correction for the 4 pixels (in a step S223).

[0278]
The flow of second correction processing will now be described with reference to FIG. 57.

[0279]
First, it is determined whether or not the amount of correction is 0 in a step S231. When the amount of correction is not 0, the step S232 is performed, and the amount of correction is added to the component value on a pixel predetermined according to any of the tables shown in FIGS. 46 through 49 (FIG. 32 or 40). However, in this case, each table, ‘pixel to second bear rangover’ is applied there. This processing is repeated on the amount of correction for the 4 pixels (in a step S233).

[0280]
An operation flow of the abovementioned simple rounding processing will now be described with reference to FIG. 58.

[0281]
First, when the component value x is less than 0 in a step S241, it is set such as x=0 in a step S242. When the component value x is larger than 255 in a step S243, it is set such that x=255 in a step S244. Then, this processing is repeated on x for the 4 pixels (in step S245).

[0282]
With reference to FIG. 59, the rangeover processing in case the image data component is of RGB will now be described.

[0283]
The correction amount is calculated for each pixel in 4pixel unit shown in FIG. 23 for all the R, G and B values. First, rounding is performed on all R, G and B values, and, then, holds the thusobtained respective correction values (in a step s251). Then, the correction values are distributed to the respective first distribution places for all R, G and B values (in a step S252). There, each correction value is equal to the corresponding rangeover amount, as shown in FIG. 55.

[0284]
The first distribution place is determined according to any one of the tables shown in FIGS. 46 through 49, i.e., horizontally, vertically or diagonally adjacent places. Then, rounding is performed only on R and B values, and the respective correction values are held (in a step S253). Then, these correction values are distributed to the second distribution places as the second correction (in a step S254). Finally, simple rounding is performed on all R, G and B values (in a step S255). This processing is performed on all the four pixels included in the given image.

[0285]
[0285]FIG. 60 shows an operation flow on the rangeover correction processing in an image data processing apparatus in a fourth embodiment of the present invention.

[0286]
In the fourth embodiment, in a step S261, in case any of the rates of quantization on the coefficients HL, LH and HH is larger than a threshold Th1, the amount of correction on each pixel is calculated through the processing shown in FIG. 55 for all R, G and B, and are held (in a step S262). Furthermore, the rangeover amount (the amount of correction in FIG. 55) is added to the first distribution place (pixel to first bear rangeover) for all R, G and B (in a step S263), and the rounding processing is performed for all R, G and B (in a step S267). However, when the rate of quantization on all the coefficients is not larger than the threshold Th2 (Th1>Th2) in the step S261, the step S264 is performed. In the step S264, when the rate of quantization on all the coefficients is larger than another threshold Th2, the amount of correction on each pixel calculated by the processing shown in FIG. 55 is held in a step S264. Then, for R and B, the rangeover amount is added to the second distribution place (pixel to second bear rangeover) in a step S266, and, then, for all R, G and B, the rounding processing is performed, in a step S267. When the rate of quantization on all the coefficients is not larger than the threshold Th2, the step S267 is immediately performed without the steps S265 and S266 being performed. With reference to FIGS. 55 through 58, the details of processing therefor have been already described.

[0287]
The present invention is applicable to wavelet transform according to JPEG2000 described above. Then, in the image data processing apparatus in the third or fourth embodiment, wavelet transform (5×3 wavelet transform or 9×7 wavelet transform according to JPEG2000, for example) is employed, and, also, it may be employed by each of the first and second embodiment.

[0288]
Each of the abovementioned embodiments of the present invention may be embodied by utilizing a generalpurpose computer in which a predetermined software program is installed. The predetermined software program is configured to perform the abovedescribed steps of operation according to the respective one of the embodiments of the present invention. The software program may be previously recorded in one of various recording media such as a CDROM, a magnetooptical disk, a DVDROM, an FD, a flush memory, other RAM, ROM and so forth. Instead, it is also possible that the predetermined software program is downloaded from a predetermined server through a communications network such as Internet.

[0289]
Further, the present invention is not limited to the abovedescribed embodiments, and variations and modifications may be made without departing from the scope of the present invention.

[0290]
The present application is based on Japanese priority applications Nos. 2001053721, 2001175009 and 2001289625, filed on Feb. 28, 2001, Jun. 11, 2001 and Sep. 21, 2001, respectively, the entire contents of which are hereby incorporated by reference.