An image coding embedded in matrix operation. A sorting and refining processes are merged, based on matrix and the stream control mechanism, a novel concept for embedded image compression in a single stage is achieved. A significant map array is used to determine whether the node in a hierarchic tree is significant to ensure and enhance the compression efficiency. A status bit coding processing apparatus employing the above method is based on a simple algorithm logic to require only one and a quarter memory space of an image transform coefficient. The design of the bit budget controller further overcome the conflict between the embedded type and matrix type coding to ensure a high efficient compression well suited for the implementation of low cost hardware chip or DSP chip.

Patent
   6584228
Priority
Apr 28 2000
Filed
Jun 21 2000
Issued
Jun 24 2003
Expiry
Jan 24 2022
Extension
582 days
Assg.orig
Entity
Small
9
10
EXPIRED
1. A method of image coding embedded in matrix operation, comprising:
performing a wavelet transform on a pixel data to obtain a transform coefficient array;
removing a dc grain in the transform coefficient array;
constructing a significant map array and a plurality of scaling auxiliary array;
estimating an evaluated bit usage required by coding according to the scaling auxiliary array;
performing a normal coding process before the evaluated bit usage reaches a coding warning value, then going back to the step of estimating the evaluated bit usage; and
performing a final coding process when the evaluated bit usage reaches the coding warning value according to the significant map array.
7. A status bit coding processing apparatus, comprising:
a significant bit filter, continuously scanning a transform coefficient array to output a significant transform coefficient using an array sequential scanning method with a bit plane coding process;
a status bit p coding unit, coupled to the significant bit filter to code the possibly significant transform coefficient into a status bit p;
a status bit s coding unit, coupled to the significant bit filter to code the possibly significant transform coefficient into a status bit s;
a status bit r coding unit, coupled to the significant bit filter to code the possibly significant transform coefficient into a status bit r;
a status bit c coding unit, coupled to the significant bit filter to code the possibly significant transform coefficient into a status bit c; and
a bit budget controller, coupled to the status bit r coding unit and the status bit c coding unit to estimate an evaluation bit usage consumed by coding, and when the evaluation bit usage reaching a coding warning value, controlling the status bit r coding unit and the status bit c coding unit to select stop coding the status bits r, c.
2. The method according to claim 1, wherein the step of performing the normal coding process further comprises the steps of:
using an array sequential scanning method with a bit plane coding method to consecutively scan the transform coefficient array;
coding a plurality of status bits p, s, r unconditionally when L=Lmax;
coding the status bits r, s, p and another status bit c unconditional when L=Lmax-1; and
coding the status bit p, s, r, c according to cij which is possible to be significant; wherein:
a decision logic of the status bit p, s comprises:
If |cij|<2T
If |cij|≧T
P=1
If cij>0
S=0
Else
S=1
Else
P=0
the logic for judging the status bit r is:
If |cij|≧2T
If |cij|& T
R=1
Else
R=0
the logic for judging the status c is:
If MAXMAGij<2T
If MAXMAGij≧T
C=1
Else
C=0
the status bit p is the significant bit of mother tree;
the status bit s is the sign bit of the mother tree;
the status bit r is the refinement bit of the mother tree;
the status bit c is the significant bit of the subtree;
cij is the transform coefficient located at the coordinate (i, j);
MAXMAGij is the maximum absolute value of a node located at (i, j) of the subtree;
T is the threshold value; and
L is the scale, Lmax locates at the highest scale of a hierarchical tree, and Lmin locates at the lowest scale of the hierarchic tree.
3. The method according to claim 1, wherein the step of performing the final coding process further comprises:
using an array sequential scanning method with a bit plane coding method to consecutively scan the transform coefficient array;
coding a plurality of status bits p, s according to the significant map array;
coding the status bits p, s and another status bit c of a residual transform coefficient when the actual bit usage consumed by coding does not reaching a coding budget; and
coding a status bit r when the actual bit usage consumed by coding reaches the coding budget; wherein:
the logic of the status bits p, s includes:
If |cij|<2T
If |cij|≧T
P=1
If cij>0
S=0
Else
S=1
Else
P=0
the logic for judging the status bit r is:
If |cij|≧2T
If |cij|& T
R=1
Else
R=0
the logic for judging the status c is:
If MAXMAGij<2T
If MAXMAGij≧T
C=1
Else
C=0
wherein
the status bit p is the significant bit of mother tree;
the status bit s is the sign bit of the mother tree;
the status bit r is the refinement bit of the mother tree;
the status bit c is the significant bit of the subtree;
cij is the transform coefficient at the coordinate (i, j);
MAXMAGij is the maximum absolute value of the node located at (i, j) of the subtree;
T is the threshold value; and
L is the scale, Lmax locates at the highest scale of the hierarchical tree, and Lmin locates at the lowest scale of the hierarchic tree.
4. The method according to claim 1, wherein the step of constructing the scaling auxiliary array comprises the following step:
using an array sequential scanning method to scan the transform coefficient array, and
using the following formula to recursively construct the scaling auxiliary array:
M[Tn]=count of {cij|Tn<=|cij|<Tn-1}
MM[Tn]=count of {MAXMAGij<|Tn<=|MAXMAGij<|Tn-1}
MM2[Tn]=count of {MAXMAGij|Tn<=|MAXMAGij|<Tn-1, L>}
wherein
M[Tn], MM[Tn], MM2[Tn] are the scaling auxiliary array;
cij is the transform coefficient of transform coefficient array at (i, j);
MAXMAGij is the maximum absolute value of the node of the subtree located at (i, j); and
Tn is the threshold value of the nth recursion;
L is the level number.
5. The method according to claim 1, wherein the step of estimating the evaluation bit usage consumed by coding is performed according to the following formula:
pn=Pn-1+MM[Tn]·4+M[Tn]
sn=M[Tn]
rn=Rn-1+M[Tn-1]
cn=Cn-1+MM2[Tn]·4-MM[Tn-1] (3)
wherein
M[Tn], MM[Tn] Mm2[Tn] are the scaling auxiliary array;
Tn is the threshold value of the nth recursion; and pn, sn, rn, cn are the required maximum coding length when the status bit p, s, r and s are at the threshold values, respectively.
6. The method according to claim 1, wherein the step of constructing the significant map array comprising the follow steps:
using an array sequential scanning method to scan the transform coefficient array; and
using the following formula to recursively construct the significant map array: MAXMAG i &it; &it; j &LeftBracketingBar; = max &it; { &LeftBracketingBar; c 2 &it; i , 2 &it; j &RightBracketingBar; , &LeftBracketingBar; c 2 &it; i + 1 , 2 &it; j &RightBracketingBar; , &it; &LeftBracketingBar; c 2 &it; i , 2 &it; j + 1 &RightBracketingBar; , &LeftBracketingBar; c 2 &it; i + 1 , 2 &it; j + 1 &RightBracketingBar; , MAXMAG 2 &it; i , 2 &it; j , MAXMAG 2 &it; i + 1 , 2 &it; j , MAXMAG 2 &it; i , 2 &it; j + 1 , MAXMAG 2 &it; i + 1 , 2 &it; j + 1 } image" FILE="US06584228-20030624-M00002.TIF"/>
wherein:
cij is the transform coefficient at the coordinate (i, j) in the transform coefficient array; and
MAXMAGij is the maximum absolute value of the node located at (i, j) in the subtree.
8. The apparatus according to claim 7, wherein when the evaluation bit usage reaches the coding warning value, the significant bit filter outputs the possible significant transform coefficient, and the status bits p, s, r, c coding units code the status bits p, s, r, s according to the following rules:
when L=Lmax, coding the status bits p, s, r unconditionally;
when L=Lmax-1, coding the status bits p, s, r, c unconditionally;
when L<Lmax-1 and L>1, coding the status bits p, s, r, c according to the possible significant cij; and
a judging logic for status bit p, s comprising:
If |cij|<2T
If |cij|≧T
P=1
If cij>0
S=0
Else
S=1
Else
P=0
the logic for judging the status bit r comprising:
If |cij|≧2T
If |cij|& T
R=1
Else
R=0
the logic for judging the status c comprising:
If MAXMAGij<2T
If MAXMAGij≧T
C=1
Else
C=0
the status bit p is the significant bit of mother tree;
the status bit s is the sign bit of the mother tree;
the status bit r is the refinement bit of the mother tree;
the status bit c is the significant bit of the subtree;
cij is the transform coefficient located at the coordinate (i, j);
MAXMAGij is the maximum absolute value of a node located at (i, j) of the subtree;
T is the threshold value; and
L is the scale, Lmax locates at the highest scale of a hierarchical tree, and Lmin locates at the lowest scale of the hierarchic tree.
9. The apparatus according to claim 7, wherein when the evaluation bit usage reaches a coding warning value, the status bits p, s are obtained by coding in the status bits p, s coding units, and the status bits r, c are controlled by the bit budget controller to code the status bits r, c according to the following formula:
a judging logic for status bit p, s comprising:
If |cij|<2T
If |cij|≧T
P=1
If cij>0
S=0
Else
S=1
Else
P=0
the logic for judging the status bit r comprising:
If |cij|≧2T
If |cij|& T
R=1
Else
R=0
the logic for judging the status c comprising:
If MAXMAGij<2T
If MAXMAGij≧T
C=1
Else
C=0
the status bit p is the significant bit of mother tree;
the status bit s is the sign bit of the mother tree;
the status bit r is the refinement bit of the mother tree;
the status bit c is the significant bit of the subtree;
cij is the transform coefficient located at the coordinate (i, j);
MAXMAGij is the maximum absolute value of a node located at (i, j) of the subtree;
T is the threshold value; and L is the scale, Lmax locates at the highest scale of a hierarchical tree, and Lmin locates at the lowest scale of the hierarchic tree.
10. The apparatus according to claim 7, wherein the bit budget controller estimates the evaluation bit usage consumed by coding and scan the transform coefficient array using array sequential scanning method to construct a plurality of scaling auxiliary array according to the formula:
M[Tn]=count of {cij|Tn<=|cij|<Tn-1}
MM[Tn]=count of {MAXMAGij|Tn<=|MAXMAGij|<Tn-1}
MM2[Tn]=count of {MAXMAGij|Tn<=|MAXMAGij|<Tn-1, L>1|}
wherein
M[Tn], MM[Tn], MM2[Tn] are the scaling auxiliary array;
cij is the transform coefficient of transform coefficient array at (i, j);
MAXMAGij is the maximum absolute value of the node of the subtree located at (i, j); and
Tn is the threshold value of the nth recursion;
L is the level number.
11. The apparatus according to claim 10, wherein the bit budget controller estimates the evaluation bit usage consumed by coding according to the formula:
pn=Pn-1+MM[Tn]·4+M[Tn]
sn=M[Tn]
rn=Rn-1+M[Tn-1]
cn=Cn-1+MM2[Tn]·4-MM[Tn-1] (3)
wherein
M[Tn], MM[Tn] Mm2[Tn] are the scaling auxiliary array;
Tn is the threshold value of the nth recursion; and
pn, sn, rn, cn are the required maximum coding length when the status bit p, s, r and s are at the threshold values, respectively.
12. The apparatus according to claim 7, wherein the transform coefficient array is scanned using the array sequential scanning method according to the formula: MAXMAG i &it; &it; j &LeftBracketingBar; = max &it; { &LeftBracketingBar; c 2 &it; i , 2 &it; j &RightBracketingBar; , &LeftBracketingBar; c 2 &it; i + 1 , 2 &it; j &RightBracketingBar; , &it; &LeftBracketingBar; c 2 &it; i , 2 &it; j + 1 &RightBracketingBar; , &LeftBracketingBar; c 2 &it; i + 1 , 2 &it; j + 1 &RightBracketingBar; , MAXMAG 2 &it; i , 2 &it; j , MAXMAG 2 &it; i + 1 , 2 &it; j , MAXMAG 2 &it; i , 2 &it; j + 1 , MAXMAG 2 &it; i + 1 , 2 &it; j + 1 } image" FILE="US06584228-20030624-M00003.TIF"/>
wherein:
cij is the transform coefficient at the coordinate (i, j) in the transform coefficient array; and
MAXMAGij is the maximum absolute value of the node located at (i, j) in the subtree.

This application claims the priority benefit of provisional application filed on Apr. 28, 2000, title "ARRAY-BASED EMBEDDED IMAGE CODER", and the Ser. No. 60/200,482.

1. Field of the Invention

The invention relates in general to an image coding method. More particularly, this invention relates to a method and an operation apparatus of image compression coding embedded in matrix operation.

2. Description of the Related Art

In the recent years, as the development of mobile phone and internet becomes more and more advanced, the data transmitted to the computer or the mobile phone via cable or wireless network is more and more enormous. In addition to text data, the transmitted data further comprise audio or video information. The multimedia products that transceive the massive audio-video information are thus very popular. How to enhance the performance of signal transmitting and the economic efficiency becomes an important topic in industry.

It is well known that the multi-medium signal may include image, speech and various data signals. Generally speaking, the image signal is the most magnificent one among all the signals. For example, the image signal requires a speed of 3 Mbits/sec. (bps) for transmission, the speech signal requires only a speed of 64K bps for transmission. For the massive data of the speech or image signal, a compression operation is required for transmission or storage to save the memory space and the usage of communication bandwith, so as to enhance the transmitting and processing speed.

Among the current methods and standards for digital-type signal compression/decompression, the motion picture expert group (MPEF) standard, no matter MPEG-I or MPEG-II, is the most commonly applied standard for animation in multi-medium industry. Regarding the still image, JPEG is the common standard for compression/decompression. Both the MPEG and JPEG compression operation methods with a high compression ratio comprise three stages of operation. These three stages include transform, quantization and coding. The method of quantization comprises at least a bit-discard method for specific threshold value and sorting method.

In a conventional wavelet image compression algorithm, a zero-tree data structure of wavelet transform coefficient is used to accommodate a bit plane coding technique to obtain a data stream with a high compression ratio and embedded properties. This kind of embedded wavelet compression image data stream includes the advantages of progressive transmission, precision in controlling coding length and error tolerance. Particularly, the precision in controlling the coding length cannot be achieved by simply using bit-discard method. In the current network application, a real time transmission of image data between hetero-networks is highly demanded. The technique of quality of service (QoS) plays a crucial role. Only with a precise control of image coding length and quality of compression algorithm, the requirement of controlling QoS can be met. Under such circumstance, the embedded wavelet image compression technique plays an important role in the field of image communication.

To obtain an image frame with a real time compression high resolution, or to compress the image frame applying both high compression ratio and real time transmission, the digital signal processing (DSP) chip capable of running firmware program or hardware of a very large scaled integrated circuit (VLSI) is implemented. The current commercial wavelet compression system, especially the VLSI chip employing the conventional bit-discard method, does not use the modern embedding coding method. Therefore, the commercial DSP chip or VLSI chip cannot meet the requirement of QoS control.

In the embedded image coding theory, the sorting operation is performed on the transform coefficient after the stage of wavelet transform. The quantization is performed with accommodating the bit plane coding method. During the coding process, to accelerate the sorting operation and to enhance the compression efficiency, a conventional wavelet image compression algorithm is applied to a zero tree structure based on the relationship between the frequency and time domains of the wavelet transform coefficient. In fact, two lists, a dominant list and a subordinate list have to be maintained for the above algorithm. Firstly, all the wavelet transform coefficients are saved into the dominant list in a predetermined order. In the main operation procedure, the dominant list is scanned. With the zero tree as the common structure base at the two ends of the code, for all the coefficients with the absolute values are no less than the initial threshold value T0, the coordinates and the positive and negative signs thereof are coded (sorted). The coefficients are then shifted to the subordinate list. The original coefficients are erased to zero to ensure that there is no coding performed in the major operation procedure. In the subordinate operation procedure, the subordinary bit of all the coefficients in the subordinate list are coded (sorted) and output. By decreasing the threshold values into a half, the previous coding procedure is repeated until the code length is run out, or until reaching the minimum threshold value Tmin.

Due to the enormous memory and time expenditure for list operation, it is difficult to implement a low-cost embedded image hardware which adopts the conventional algorithm. More importantly, the memory space for list or tree structures is much larger than that of the conventional bit-discard method, the design difficulty and production cost are further increased.

The invention provides an image coding embedded in matrix operation (ICEM) and the status bit coding apparatus employed by the image coding. The advantages of progressive transmission, the precision in controlling the coding length are achieved to thoroughly adjust QoS of the network image transmission. More particularly, the used memory space is small and fixed, and the coding speed is accelerated to be well suitable for hardware implementation.

In the image coding embedded in matrix operation, a wavelet transform is performed on a pixel data to obtain a transform coefficient array. The DV gain in the transform coefficient array is removed. The transform coefficient array is scanned to construct a significant map array and a plurality of scaling auxiliary array. According to the scaling auxiliary array, the evaluated bit usage consumed by coding is estimated. Before the evaluated bit image reaches a coding warning value, an ICEM normal processing is performed according to the significant map array, followed by jumping to the foregoing step of estimating the evaluated bit usage. When the evaluated bit image reaches or exceeds the bit warning value, an ICEM final processing is executed according to the significant map array.

The above coding processing includes the following steps. By an array sequential scanning method and accommodating a bit plane coding method, the transform coefficient array is scanned. When L=Lmax, the status bits P, S, R are coded unconditionally. When L=Lmax-1 the status bits P, S, R, C are coded unconditionally, and when L<Lmax-1 and L>1, the status bit P, S, R, C coded according to Cij that is possibly the significant. The foregoing ICEM final processing includes the following steps. Using the array sequential scan and the bit plane coding, the above transform coefficient array is scanned. The coding status bit P, S are coded according to the above signal map array. When the actual consumed bit usage for coding does not reach the coding estimated value, status bits P, S, C of the residual transform coefficient are coded. When the actual bit usage for coding does not reach the coding estimated value, the status bit R is coded.

The coding logic for status bit P, S is:

If |Cij|<2T

If |Cij|≧T

P=1

If Cij>0

S=0

Else

S=1

Else

P=0

The logic for determining the status bit R:

If |Cij|≧2T

If |Cij|& T

R=1

Else

R=0

The logic for determining the status C:

If MAXMAGij<2T

If MAXMAGij≧T

C=1

Else

C=0

Wherein

The status bit P is the significant bit of mother tree.

The status bit S is the sign bit of the mother tree.

The status bit R is the refinement bit of the mother tree.

The status bit C is the significant bit of the subtree.

Cij is the transform coefficient at the coordinate (i, j).

MAXMAGij is the maximum absolute value of the node located at (i, j) of the subtree.

T is the threshold value.

L is the level, Lmax locates at the highest level of the hierarchical tree, and Lmin locates at the lowest level of the hierarchic tree.

The transform coefficient are scanned with the array sequential scanning method and the following formula are applied recursively to obtain the scaling auxiliary array:

M[Tn]=count of {Cij|Tn|<=|Cij|<Tn-1}

MM[Tn]=count of {MAXMAGij|Tn<=|MAXMAGij|Tn-1}

MM2[Tn]=count of {MAXMAGij|Tn|<=|MAXMAGij|<Tn-1, L>1|}

The evaluated bit image consumed by estimating coding can be obtained by the following formula:

Pn=Pn-1+MM[Tn]·4-M[Tn-1]

Sn=M[Tn]

Rn=Rn-1+M[Tn-1]

Cn=Cn-1+MM2[Tn]·4 -MM[Tn-1]

Wherein

M[Tn], MM[Tn], MM2[Tn] are scaling auxiliary array.

Cij is the maximum absolute value of the node located at (i, j) of the subtree.

Tn is threshold value of the nth iteration.

L is the level.

Pn, Sn, Rn, Cn are the maximum coding length of the plurality of status bits P, S. R, C at the threshold values Tn.

In another embodiment of the invention, a status bit coding apparatus is provided. A significant bit filter uses an array sequential scanning method and the bit plane coding method to continuously scan the transform coefficient array. The possibly significant transform coefficient is output. The status bit P coding unit is coupled to the significant bit filter to code the above possibly significant transform coefficient as the status bit P. The status bit S coding unit is coupled to the significant bit filter to code the above possibly significant transform coefficient into the status bit S. The status bit C coding unit is coupled to the significant bit filter to code the above possibly significant transform coefficient into the status bit C. A bit budget controller is coupled to the status bit R coding unit and the status bit C coding unit to estimate the consumed evaluated bit usage for coding. When the evaluated coding usage reaches a warning value, the status bit R coding unit and the status bit C coding unit are controlled to stop coding status bits R, C.

The method of matrix-type image coding merges sorting and refinement processes based on an array and accommodate the stream control mechanism to achieve a novel concept for embedded image compression within a single stage. The status bit coding apparatus uses a simple algorithm logic, for example, comparison and logic computation, so that a small and fixed memory is required to accomplish and accelerate the embedded image compression in a singe stage. The design of bit budget control further enhances the compression efficiency. This is thus particular suitable for implementation of VLSI chip hardware or DSP chip firmware.

Both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the invention, as claimed.

FIG. 1 shows a diagram for using bit plane coding method to achieve a progressive transmission;

FIG. 2 shows a triadic hierarchic tree after wavelet transform;

FIG. 3 shows a scanning path using an array sequential scanning method;

FIG. 4 is a flow chart showing image coding method embedded in a matrix operation; and

FIG. 5 is a block diagram showing a status bit coding apparatus.

Currently, for image compression/decompression, the RGB data format is not used for the compression process. Instead, YCrCb or YUV is used as the data processing format. This is because human being is more sensitive of contrast compared to chromatics and saturation. Using the YCrCb or YUV format for compression, a high image data processing efficiency can be obtained, and the image processing is straightforward. It is the same in one preferred embodiment of the invention. If the pixel data is not in a YCrCb or YUV data format, for example, is an RGB data format, the pixel data has to be converted into the YCrCb or YUV data format first, followed by the processing step for transform stage. In the invention, the wavelet transform algorithm including versatile advantages is employed in the transform stage.

FIG. 1 shows a method of bit plane coding method to achieve the progressive transmission. In FIG. 1, each row represents a transform coefficient after wavelet transform. The transform coefficients have been sorted according to their magnitude, that is, the transform coefficients are degressive from the top row to the bottom row. Each column represents a bit plane. If absolute value of the error of the transform coefficient caused by coding is equivalent to the actual pixel error, according to the transmission bandwidth, the sorted transform coefficients are output sequentially. The data stream thus comprises the advantages of embedded properties, progressive transmission, precision in controlling coding length, and error tolerance.

The actual coding further includes two steps. According to certain threshold value, coefficient with an absolute value no less than the threshold value, that is, the bit plane denoted by 1 in FIG. 1, that is, the significant coordinate (the status bit P, C in the ICEM method of the invention) is indirectly output according to the zero tree structure. The sign bit is directly output (the status bit S in the ICEM method of the invention). The previous output significant coefficient is directly output with the bit located at the current bit plane, that is, the reference notation R in FIG. 1 (the status bit R in the ICEM method of the invention). From the above description, the relationship between the embedded coding and bit plane coding can be realized. The embodiment employs the bit plane coding method.

FIG. 2 shows a diagram of a triadic hierarchic tree obtained from the wavelet transform. In addition to the properties in the frequency domain, the coefficient array further has a spatial ratio relationship between the upper and lower level of an identical frequency band. That is, the coefficient node in a scale has four children, which correspond to the wavelets at the next finer scale having the same location in space. This particular relationship between the frequency and time domains is called the hierarchic tree. The concept of hierarchic plays a very important role in the coding theory of the invention. Since a large amount of zero trees with a zero value can be found, the subtree based on the zero tree does not need further computation and operation. The compression ratio can thus be enhanced, and the unnecessary decision is not required to accelerate the coding.

FIG. 3 shows a scanning path for an array sequential scanning method. The conventional coding method employs the list with sorting process, that is, the precise two-stage alternate coding. However, the ICEM method used in the invention employs the above hierarchic tree concept, as shown as the array sequential scanning method in FIG. 3, and the bit plane coding method to accomplish the coding processing within one stage.

FIG. 4 is a flow chart showing an image coding method embedded in matrix operation. The method includes the following steps.

In step 42, a wavelet transform is performed on the pixels data of the image 40 to obtain a transform coefficient array. In step 44, the DC grain in the coefficient array is removed. Typically, the method of the mean value computation is used to remove the DC grain. Based on the frequency domain properties of wavelet transform and the concept of hierarchic tree, the upper left corner of the array coefficient is removed to remove the DC grain, that is, the node of mother tree with the lower frequency is remained. The step 46 is then performed to scan the coefficient array, so as to build up a significant map array and a plurality of scaling auxiliary array.

The significant map array is used to find out which is the zero tree. The significant map array can be constructed according to the array sequential scanning method in FIG. 3 to scan the transform coefficient array with the following formula to recursively construct the significant map array: MAXMAG i &it; &it; j &LeftBracketingBar; = max &it; { &LeftBracketingBar; C 2 &it; i , 2 &it; j &RightBracketingBar; , &LeftBracketingBar; C 2 &it; i + 1 , 2 &it; j &RightBracketingBar; , &it; &LeftBracketingBar; C 2 &it; i , 2 &it; j + 1 &RightBracketingBar; , &LeftBracketingBar; C 2 &it; i + 1 , 2 &it; j + 1 &RightBracketingBar; , MAXMAG 2 &it; i , 2 &it; j , MAXMAG 2 &it; i + 1 , 2 &it; j , MAXMAG 2 &it; i , 2 &it; j + 1 , MAXMAG 2 &it; i + 1 , 2 &it; j + 1 } ( 1 )

Wherein:

Cij is the transform coefficient at the coordinate (i, j) in the transform coefficient array.

MAXMAGij is the maximum absolute value of the node located at (i, j) in the subtree.

The scaling auxiliary array is mainly applied to estimation of the required bit length for coding each status bit (the data bit after coding) in each recursion. The construction of the above scaling auxiliary array uses the array sequential scanning method to scan the transform coefficient array with the formula:

M[Tn]=count of {Cij|Tn<=|Cij|<Tn-1}

MM[Tn]=count of {MAXMAGij|Tn<=|MAXMAGij|<Tn-1}

MM2[Tn]=count of {MAXMAGij|Tn<=|MAXMAGij|<Tn-1, L>1} (2)

Wherein

M[Tn], MM[Tn], MM2[Tn] are the scaling auxiliary array

Cij is the transform coefficient of transform coefficient array at (i, j)

MAXMAGij is the maximum absolute value of the node of the subtree located at (i, j)

Tn is the threshold value of the nth recursion

L is the level number.

The scaling auxiliary array can thus be built up recursively. In this stage, only tens of storing spaces of the memory is used for the scaling auxiliary array. The significant map array can be used, while the relative array element is computed. The obtained resultant array does not need to be computed by the equation (2) in each recursion. The coding end does not require the computation of equation (2) either.

The step 48 is performed. According to the scaling auxiliary arrays, the evaluated bit usage consumed by the coding processing is estimated. The purpose of estimating the coding length for each status bit is to predict when the coding processing is finished. In the final processing recursion, the transmission ratio for each status bit is distributed according to the residual coding budget. By this manner of optimization, the ICEM method in the invention can maintain a high compression under the estimation of coding length budget. The estimation of the evaluated bit image consumed by coding can be computed by the formula:

Pn=Pn-1+MM[Tn]·4+M[Tn]

Sn=M[Tn]

Rn=Rn-1+M[Tn-1]

Cn=Cn-1+MM2[Tn]·4-MM[Tn-1] (3)

Wherein

M[Tn], MM[Tn] Mm2[Tn] are the scaling auxiliary array.

Tn is the threshold value of the nth recursion.

Pn, Sn, Rn, Cn are the required maximum coding length when the status bit P, S, R and S are at the threshold values, respectively.

Since the end of the coding process can be predicted, the subsequent ICEM coding operation can be separated into to a final coding processing path 52 and a normal coding processing path 54. In step 50, whether the coding process is the final recursion is decided. If it is not the last recursion, that is, if the coding warning value is not reached, the step 54, the normal coding process 54 is executed according to the significant map array, followed by jumping to the step 48 for estimating the above evaluation bit usage. If the final recursion is reached, the evaluated bit image exceeds the coding warning value, the final coding process 52 is performed according to the significant map array. It is worth noting that for the actual hardware implementation, as long as the register achieves the objective of controlling stream of each status bit, two streams can be combined into one.

The above coding process 54 comprises the following steps. Using the array sequential scanning method with the bit plane coding method, the above transform coefficient array is scanned. When L=Lmax, the status bits P, S, R are coded unconditionally. When L=Lmax-1, the status bits P, S, R, C are coded unconditionally. When L<Lmax-1 and L>1, the P, S, R, C are coded according to the possibly significant Cij. The final coding process 52 also including the following steps. An array sequential scanning method with a bit plane coding method is performed to scan the above transform coefficient. Using the MAXMAG significant map array in the current decoding end (the coded results are to be decoded by the decoding end), the status bits P, S are coded. When the actual consumed bit usage for coding reaches the coding budge, the status bit C is coded. Meanwhile, the MSXAMG array at the decoding end is refreshed synchronously, and the status bits P, S of the residual transform coefficient which is not transmitted are coded. When the actual consumed bit usage required by coding does not reach the estimated coding value is judged, the status bit is C is coded.

The above decision logic is:

If |Cij|<2T

If |Cij|≧T

P=1

If Cij>0

S=0

Else

S=1

Else

P=0 (4)

The logic for judging the status bit R is:

If |Cij|≧2T

If |Cij|& T

R=1

Else

R=0 (5)

The logic for judging the status C is:

If MAXMAGij<2T

If MAXMAGij≧T

C=1

Else

C=0 (6)

Wherein

The status bit P is the significant bit of mother tree.

The status bit S is the sign bit of the mother tree.

The status bit R is the refinement bit of the mother tree.

The status bit C is the significant bit of the subtree.

Cij is the transform coefficient at the coordinate (i, j).

MAXMAGij is the maximum absolute value of the node located at (i, j) of the subtree.

T is the threshold value.

L is the scale, Lmax locates at the highest scale of the hierarchical tree, and Lmin locates at the lowest scale of the hierarchic tree.

FIG. 5 shows a block diagram of a status bit coding apparatus. By applying the above image coding embedded in matrix, a status bit coding processing apparatus is provided. A significant bit filter 60, a status bit P coding unit 62, a status bit S unit 64, a status bit R coding unit 66, a status bit C coding unit 68 and a bit budget controller 70 are included.

The significant bit filter 60 consecutively scans the transform coefficient using the array sequential scanning method as shown in FIG. 3 with the bit plane coding method. According to specific design, the output may be significant transform coefficient. The status bit P, S, R, C coding units 62, 64, 66, 68 are coupled to the significant bit filter 60. According to the judging logic of formula (4), (5) and (6), the above possibly significant transform coefficients are coded into the status bits P, S, R, C.

The bit budget controller 70 is a characteristic feature of the invention. The bit budget controller 70 is coupled to the status bit coding units R and C. According to the formula (2) and (3), the evaluated bit usage consumed by coding is estimated. When it is judge that the final recursion is not reached, that is, the evaluation bit usage does not reach the coding warning value, a normal coding process is performed. Otherwise, a final coding step is performed according to the significant map array. That is, the status bits R and C coding units are controlled to stop coding the status bits R and C.

The invention uses a relatively small and fixed array space, by merging sorting and refining process into one simplified array computation logic, to achieve high efficient compression. In fact, there is a process conflict between the embedding coding technique and the array sequential computation. Especially for the final recursion of the coding processing procedure, the bit information to be output in the original plan has to be output with priority, so that that compression performance can be enhanced. Thus, the ICEM algorithm also provides an estimation and a control mechanism of the status bit length, that is, the bit budget controller to ensure a highest compression efficiency.

Other embodiments of the invention will appear to those skilled in the art from consideration of the specification and practice of the invention disclosed herein. It is intended that the specification and examples to be considered as exemplary only, with a true scope and spirit of the invention being indicated by the following claims.

Wu, Jiann-Shong

Patent Priority Assignee Title
7193537, Mar 07 2002 Aware, Inc. Interlaced sign bit coding
8595478, Jul 10 2000 AlterWAN Inc. Wide area network with high quality of service
9015471, Jul 10 2000 AlterWAN, Inc. Inter-autonomous networking involving multiple service providers
9241094, Mar 18 2008 Intel Corporation Capturing event information using a digital video camera
9251423, Mar 21 2008 Intel Corporation Estimating motion of an event captured using a digital video camera
9256789, Mar 21 2008 Intel Corporation Estimating motion of an event captured using a digital video camera
9525620, Jul 10 2000 AlterWAN, Inc. Private tunnel usage to create wide area network backbone over the internet
9667534, Jul 10 2000 AlterWAN, Inc. VPN usage to create wide area network backbone over the internet
9985800, Jul 10 2000 AlterWAN, Inc. VPN usage to create wide area network backbone over the internet
Patent Priority Assignee Title
5412741, Jan 22 1993 MEDIATEK INC Apparatus and method for compressing information
5748786, Sep 21 1994 RICOH COMPANY, LTD , A CORPORATION OF JAPAN; Ricoh Corporation Apparatus for compression using reversible embedded wavelets
5758092, Nov 14 1995 Intel Corporation Interleaved bitrate control for heterogeneous data streams
5995080, Jun 21 1996 Hewlett Packard Enterprise Development LP Method and apparatus for interleaving and de-interleaving YUV pixel data
6310973, Oct 01 1998 Cirrus Logic, INC Method and apparatus for digital data compression
6370197, Jul 23 1999 MIND FUSION, LLC Video compression scheme using wavelets
6466698, Mar 25 1999 The United States of America as represented by the Secretary of the Navy Efficient embedded image and video compression system using lifted wavelets
6483543, Jul 27 1998 CISCO SYSTEMS, INC , A CORPORATION OF CALIFORNIA System and method for transcoding multiple channels of compressed video streams using a self-contained data unit
6493023, Mar 12 1999 The United States of America as represented by the Administrator of the National Aeronautics and Space Administration; Administrator of the National Aeronautics and Space Administration Method and apparatus for evaluating the visual quality of processed digital video sequences
6529868, Mar 28 2000 TELECOM HOLDING PARENT LLC Communication system noise cancellation power signal calculation techniques
////
Executed onAssignorAssigneeConveyanceFrameReelDoc
Jun 09 2000WU, JIANN-SHONGAVXING INTERNATIONAL LTD CAYMANASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0109230029 pdf
Jun 21 2000Avxing International Ltd. Cayman(assignment on the face of the patent)
Dec 22 2000WU, JIANN-SHONGAVXING INC CHANGE OF NAME SEE DOCUMENT FOR DETAILS 0133190196 pdf
Oct 23 2007AVXING INC MIKTAM TECHNOLOGIES AMERICAS INC ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0248380946 pdf
Date Maintenance Fee Events
Dec 13 2006M2551: Payment of Maintenance Fee, 4th Yr, Small Entity.
Dec 23 2010M2552: Payment of Maintenance Fee, 8th Yr, Small Entity.
Jan 08 2015ASPN: Payor Number Assigned.
Jan 30 2015REM: Maintenance Fee Reminder Mailed.
Jun 24 2015EXP: Patent Expired for Failure to Pay Maintenance Fees.
Jul 20 2015EXP: Patent Expired for Failure to Pay Maintenance Fees.


Date Maintenance Schedule
Jun 24 20064 years fee payment window open
Dec 24 20066 months grace period start (w surcharge)
Jun 24 2007patent expiry (for year 4)
Jun 24 20092 years to revive unintentionally abandoned end. (for year 4)
Jun 24 20108 years fee payment window open
Dec 24 20106 months grace period start (w surcharge)
Jun 24 2011patent expiry (for year 8)
Jun 24 20132 years to revive unintentionally abandoned end. (for year 8)
Jun 24 201412 years fee payment window open
Dec 24 20146 months grace period start (w surcharge)
Jun 24 2015patent expiry (for year 12)
Jun 24 20172 years to revive unintentionally abandoned end. (for year 12)