The present invention relates generally to a signal processing device and an image processing device. More particularly, the present invention relates to a signal processing device and an image processing device for Discrete Cosine Transformation (DCT)-II, Haar, and Slant transforms.
Discrete Cosine Transformation (DCT)-II, Haar, and Slant transform techniques are applied variously in signal processing. In particular, these signal transform techniques are used for image encoding processing or signal modulation.
The DCT, specifically, the DCT-II is used to process signals and images. The DCT is widely used for lossy compression because it has an energy compaction property in which most of signal energy components tend to be concentrated in a few low-frequency components. For example, JPEG image compression, MJPEG, MPEG, and DV video compression adopt the DCT. Two-dimensional DCT-II is applied to N×N blocks and its results are quantized and entropy-coded.
The Haar transform and the Slant transform are also useful in various signal processing fields.
Circuits for the DCT-II, the Haar transform, and the Slant transform are implemented as separate circuits or separate chips. However, when the transform circuits are separately provided, a device including the circuits increases in volume and its processing rate is retarded.
In this respect, what is needed is a method for realizing a unified circuit for the DCT-II, the Haar transform, and the Slant transform.
To address the above-discussed deficiencies of the prior art, it is a primary aspect of the present invention to provide a signal processing device including a matrix calculator which performs a matrix operation selected by a switch part from a DCT matrix operation, a Haar matrix operation, and a Slant matrix operation, with respect to an input signal, and an image processing device using the same.
According to one aspect of the present invention, a signal processing device includes a switch part for selecting any one of a Discrete Cosine Transformation (DCT) matrix operation, a Haar matrix operation, and a Slant matrix operation; and a matrix calculator for performing a matrix operation selected by the switch part among the DCT matrix operation, the Haar matrix operation, and the Slant matrix operation, with respect to an input signal.
The matrix calculator may include one butterfly structure shared and used in the DCT-II matrix operation, the Haar matrix operation, and the Slant matrix operation.
The matrix calculator may include a row permutation matrix calculator for processing a row permutation matrix operation for the input signal and sending the operated signal to the switch part; a DCT-II matrix calculator for processing the DCT-II matrix operation for the signal output from the switch part; a Haar matrix calculator for processing the Haar matrix operation for the signal output from the switch part; Slant matrix calculator for processing the Slant matrix operation for the signal output from the switch part; a butterfly structure calculator for processing a butterfly structure operation for a signal output from one of the DCT-II matrix calculator, the Haar matrix calculator, and the Slant matrix calculator; and a column permutation matrix calculator for processing a column permutation matrix operation for a signal output from the butterfly structure calculator.
The switch part may output the signal input from the row permutation matrix calculator to any one of the DCT-II matrix calculator, the Haar matrix calculator, and the Slant matrix calculator.
The DCT-II matrix calculator may perform the matrix operation for a matrix [C]N in the following equation:
where [C]N/2 denotes a
DCT-II matrix, [B]N/2=└(C2Nf(m,n))m,n┘N/2, and
The Haar matrix calculator may perform the matrix operation for a matrix HT (N) in the following equation:
The Slant matrix calculator may perform the matrix operation for a matrix S(N) in the following equation:
The matrix calculator may include a hybrid architecture for selectively performing the DCT-II matrix operation, the Haar matrix operation, and the Slant matrix operation.
The switch part and the matrix calculator may be implemented as a single chip.
According to another aspect of the present invention, an image processing device encodes an image signal using the signal processing device.
Other aspects, advantages, and salient features of the invention will become apparent to those skilled in the art from the following detailed description, which, taken in conjunction with the annexed drawings, discloses exemplary embodiments of the invention.
Before undertaking the DETAILED DESCRIPTION OF THE INVENTION below, it may be advantageous to set forth definitions of certain words and phrases used throughout this patent document: the terms “include” and “comprise,” as well as derivatives thereof, mean inclusion without limitation; the term “or,” is inclusive, meaning and/or; the phrases “associated with” and “associated therewith,” as well as derivatives thereof, may mean to include, be included within, interconnect with, contain, be contained within, connect to or with, couple to or with, be communicable with, cooperate with, interleave, juxtapose, be proximate to, be bound to or with, have, have a property of, or the like. Definitions for certain words and phrases are provided throughout this patent document, those of ordinary skill in the art should understand that in many, if not most instances, such definitions apply to prior, as well as future uses of such defined words and phrases.
For a more complete understanding of the present disclosure and its advantages, reference is now made to the following description taken in conjunction with the accompanying drawings, in which like reference numerals represent like parts:
Throughout the drawings, like reference numerals will be understood to refer to like parts, components and structures.
Reference will now be made in detail to the embodiment of the present general inventive concept, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to the like elements throughout. The embodiment is described below in order to explain the present general inventive concept by referring to the drawings.
Exemplary embodiments of the present invention provide equations for a new representation of Discrete Cosine Transformation (DCT)-II, Haar transform, and Slant transform matrices decomposed based on block-inverse processing. Based on the equations, the DCT-II, the Haar transform, and the Slant transform matrices have similar recursive computational pattern, and are decomposed to one orthogonal character matrix and a special sparse matrix. The special sparse matrix belongs includes Jacket matrices. The DCT-II, Haar, and Slant transform matrices are decomposed to reveal their common part, and the common part can be implemented using a butterfly structure. Thus, a hybrid signal processing device capable of selectively processing the DCT-II, the Haar transform, and the Slant transform in a single circuit structure can be implemented. The matrix decomposition for the hybrid signal processing device is now illustrated based on equations.
1. Concept and Properties of Jacket Matrix
Normal matrices (for example, real symmetric, Hermitian, and unitary matrix) can be diagonalized by unitary transform. In a general case, any matrix with linearly independent columns can be factorized into AE=QR. Such factorization can be applied to orthogonal matrices such as DCT/Haar/Slant transform via a Jacket matrix. Herein, R denotes a sparse matrix and Q denotes the unitary matrix. As a special case of QR decomposition, the matrix Q can be fixed to a trigonometric transform matrix.
The Jacket matrix includes a Hadamard matrix having weights c. c is j (j denotes an imaginary unit j=√{square root over (−1)}) or 2k (k is an integer). The Jacket matrix [J]N (N=2n, nε{2,3, . . . }) is symmetric.
According to a general definition, when an inverse matrix of a square matrix [J]N=└aij┘N is an element-wise inverse (that is,
the matrix [J]N is a Jacket matrix.
Orthogonal matrices such as Hadamard, DFT, DCT, Haar, and Slant matrices belong to the Jacket matrices family. N×N Jacket matrices can be obtained using a recursive equation.
[J]N=[J]N/2[H]2, N=2n, nε{2,3, . . . } (1)
denotes the Kronecker product.
2. Decomposition of DCT/Haar/Slant Matrix
A. Recursive Factorization of DCT Matrix Via Jacket Matrix
Each element in the DCT-II matrix [CN] is defined as Equation 2.
Based on Equation 2, a 2×2 DCT-II matrix can be simply written as Equation 3.
is a special element inverse matrix of order 1 and its inverse is √{square root over (2)}. Cji=cos(iπ/l) denotes a cosine unit for DCT computations.
A 4×4 DCT-II matrix is given by Equation 4.
By exploiting a row permutation matrix [Pr]4, Equation 5 is produced.
The row permutation matrix is given by Equation 6.
Since C81=−C87, C82=−C86, C83=−C85 according to the Cosine properties, Equation 5 can be rewritten as Equation 7.
A 4×4 column permutation matrix is defined as
By multiplying the column permutation matrix to Equation 7, Equation 8 is obtained.
corresponds to the 2×2 DCT-II matrix, and
Hence, Equation 8 can be rewritten as Equation 9.
is a block inverse matrix, of which the inverse is given by Equation 10.
The Equation 10 is Jacket-like sparse matrix with block inverse.
In general, the DCT-II matrix [C]N can be constructed recursively based on Equation 11.
In Equation 11, [C]N/2 denotes a
DCT-II matrix. [B]N/2 can be calculated based on Equation 12.
[B]N/2=└(C2Nf(m,n))m,n┘N/2 (12)
The inverse of [Pr]N[C]N[Pc]N is given by Equation 14.
In Equation 14, the top left block matrix [C]N/2 of [C]N has the recursive factorization. By contrast, the bottom right [B]N/2 is not recursively factorized.
The present algorithm explains the recursive form and relations using Equation 12 and trigonometric identities. According to Equation 12, an N×N matrix [B]N is defined based on the following trigonometric identities and Equation 14.
where mε{0,1,2, . . . }.
Using the trigonometric identities, [B]N is given by Equation 14.
The 8×8 DCT-II matrix is given by Equation 15.
Equation 15 can be represented as Equation 16.
By removing all permutation matrices, Equation 16 is written as Equation 17.
The DCT-II matrix is represented as stated above.
B. Recursive Factorization of Haar Matrix Via Jacket Matrix
The Haar matrix HT(N) is obtained using a set of Haar functions {har(r,m,t)} defined by Equation 18.
For example, a 2×2 Haar matrix can be given by
It is Jacket-like sparse matrix.
A 8×8 Haar matrix is given by Equation 19.
HT(8) is rearranged to the matrix Har(N) multiplying row and column permutation matrices based on Equation 20.
[Pr]8HT(8)[Pc]8=
Equation 20 can be decomposed to Equation 21.
In Equation 21, Har(4)=H4S4, H4 denotes the Hadamard matrix, and [S]4 is given by Equation 22.
The inverse of Equation 21 is the block inverse as expressed in Equation 23.
In general, HT(N) is obtained based on Equation 24.
The inverse of HT(N) is given by Equation 25.
As above, the Haar matrix can be decomposed to the recursive factorization.
C. Recursive Factorization of Haar Matrix Via Jacket Matrix
When S(N) denotes the N×N slant matrix, the lowest-order slant matrix is given by Equation 26.
The slant matrix for N=4 is given by Equation 27.
By multiplying Equation 27 by a row permutation matrix [Pr]4 and a column permutation matrix [Pc]4, Equation 28 is yielded.
Hence, Equation 27 can be rewritten as Equation 29.
Herein, the inverse of the sparse matrix
is the block inverse. Thus, the inverse of Equation 29 is given by Equation 30.
Similarly, the higher-order Slant matrix can be derived from the lower-order Slant matrix and the sparse matrix. An N-order Slant matrix can be obtained based on
For example, the 8×8 Slant matrix is given by Equation 31.
By multiplying the following row permutation matrix and column permutation matrix, Equation 32 is obtained.
[Pr]8S(8)[Pc]8 can be simplified to the following equation.
The inverse of the sparse matrix
is the block inverse. H4 satisfies
By removing the permutation matrices on both sides, S(8) is given by Equation 33.
The inverse of [Pr]8 S(8)[Pc]8 is given by Equation 34.
The recursive basis in Equation 34 can be derived from S(N).
In general, Equation 35 is obtained.
Its inverse is given by Equation 36.
As such, the Slant matrix S(N) can be decomposed to the recursive factorization.
As stated above, all of the DCT-II matrix [C]N, the Haar matrix HT(N), and the slant matrix S(N) are decomposed to the multiplication of
and the sparse matrix as expressed in Equation 11, Equation 24, and Equation 35.
When a circuit is designed using the equations of the decomposed DCT-II matrix, Haar matrix, and Slant matrix, a hybrid circuit allowing all of the DCT-II, the Haar transform, and the Slant transform can be designed.
When the DCT-II, the Haar transform, and the Slant transform are conducted based on Equation 11, Equation 24, and Equation 35, computational complexity is summarized in the following table.
3. Structure of Hybrid Signal Processing Device
Now, a hybrid signal processing device 100 is explained by referring to
As shown in
The row permutation matrix calculator 110, the DCT-II matrix calculator 130, the Haar matrix calculator 140, the Slant matrix calculator 150, the butterfly structure calculator 160, and the column permutation matrix calculator 170 constitute a matrix calculator. That is, the matrix calculator conducts the matrix operation selected by the switch part 120 among the DCT matrix operation, the Haar matrix operation, and the Slant matrix operation, on the input signal. The matrix calculator includes a single butterfly structure shared and used by the DCT-II matrix operation, the Haar matrix operation, and the Slant matrix operation. Hereafter, the matrix calculator is explained in more detail by referring to
The row permutation matrix calculator 110 performs the row permutation matrix operation on the input signal, and sends the operated signal to the switch part 120. That is, the row permutation matrix calculator 110 calculates the matrix [Pr]N in the above-mentioned equations.
The switch part 120 outputs the signal by selecting one of the DCT matrix operation, the Haar matrix operation, and the Slant matrix operation. In other words, the switch part 120 is connected to one of the DCT matrix calculator 130, the Haar matrix calculator 140, and the Slant matrix calculator 150.
According to a switch control signal input from outside, the switch part 120 selects the unit to connect among the DCT matrix calculator 130, the Haar matrix calculator 140, and the Slant matrix calculator 150. The switch control signal is a control signal for selecting any one of the DCT matrix operation, the Haar matrix operation, and the Slant matrix operation, and may be determined by a command input by a user.
As such, the signal processing device 100 including the switch part 120 can select and process any one of the DCT matrix operation, the Haar matrix operation, and the Slant matrix operation.
The DCT-II matrix calculator 130 conducts the DCT-II matrix operation on the signal output from the switch part 120. That is, the DCT-II matrix calculator 130 performs the matrix operation on the matrix [C]N in the following equations, which correspond to Equations 11, 12 and 13.
In Equation 11, [C]N/2 denotes the
DCT-II matrix. [B]N/2 can be calculated based on Equation 12.
[B]N/2=└(C2Nf(m,n))m,n┘N/2 (12)
As such, the DCT-II matrix calculator 130, which includes the circuit corresponding to Equation, carries out the signal processing corresponding to the equation.
The Haar matrix calculator 140 conducts the Haar matrix operation on the signal output from the switch part 120. That is, the Haar matrix calculator 140 applies the matrix operation to the matrix HT(N) in Equation 24.
The Haar matrix calculator 140, which includes the circuit corresponding to Equation 24, carries out the signal processing corresponding to Equation 24.
The Slant matrix calculator 150 conducts the Slant matrix operation on the signal output from the switch part 120. That is, the Slant matrix calculator 150 applies the matrix operation to the matrix S(N) in Equation 35.
The Slant matrix calculator 150, which includes the circuit corresponding to Equation 35, carries out the signal processing corresponding to Equation 35.
The butterfly structure calculator 160 performs the butterfly structure operation on the signal output from any one of the DCT matrix calculator 130, the Haar matrix calculator 140, and the Slant matrix calculator 150. The butterfly structure calculator 160 includes the structure shared by all of the DCT matrix operation, the Haar matrix operation, and the Slant matrix operation. For example, the butterfly structure calculator 160 includes the butterfly structure to calculate
in all of the DCT matrix operation, the Haar matrix operation, and the Slant matrix operation.
The column permutation matrix calculator 170 applies the column permutation matrix operation to the signal output from the butterfly structure calculator 170. That is, the column permutation matrix calculator 170 calculates the matrix [Pc]N in the above equations.
By means of the hybrid architecture, the signal processing device 100 performs the DCT-II matrix operation, the Haar matrix operation, and the Slant matrix operation using the common butterfly structure. Thus, the signal processing device 100 can selectively carry out the DCT-II matrix operation, the Haar matrix operation, and the Slant matrix operation with respect to the input signal.
When the signal processing device is implemented with a single chip, it is possible to implement the single circuit chip for selectively processing the DCT-II matrix operation, the Haar matrix operation, and the Slant matrix operation.
By referring to
In the butterfly data flow diagrams for the three matrices in
As the circuit includes only one command part and selects the different pats of the DCT matrix calculator 130, the Haar matrix calculator 140, and the Slant matrix calculator 150 using the switch part 120, the hybrid signal processing device capable of selectively calculating the DCT-II matrix, the Haar matrix, and the Slant matrix can be designed.
By selectively processing the DCT-II, the Haar transform, and the Slant transform with the signal processing device 100, an image processing device for encoding image signals can be fabricated.
Note that the signal processing device is applicable to any signal processing device adopting the DCT-II, the Haar transform, and the Slant transform besides the image processing device.
The signal processing method for the DCT-II, the Haar transform, and the Slant transform based on the above-described equations can be recorded to a computer-readable recording medium which is realized with program commands executable through various computer means. The computer-readable recording medium can contain program commands, data files, and data structures alone or in combination. Meanwhile, the program commands recorded to the recording medium can be specifically designed or constructed for exemplary embodiments of the present invention, or well-known to those skilled in computer software.
The computer-readable recording medium includes magnetic media such as hard disk, floppy disk, and magnetic tape, optical recording media such as CD and DVD, magneto-optical media such as floptical disk, and hardware devices containing and executing program commands, such as ROM, RAM, and flash memory. The recording medium can be a transmission medium, such as optical or metallic line and waveguide, including subcarriers which carry signals to define program commands and data structure.
The program commands include a machine language created by a compiler and a high-level language executable by the computer using an interpreter. The hardware device can function as one or more software module for the present invention, and vice versa.
In light of the foregoing as set forth above, the signal processing device includes the matrix calculator for processing the matrix operation selected by the switch part from the DCT matrix operation, the Haar matrix operation, and the Slant matrix operation, with respect to the input signal, and the image processing device adopts the signal processing device. Therefore, the signal processing device can be implemented in the hybrid architecture capable of selectively carrying out the DCT-II, the Haar transform, and the Slant transform with the single chip.
Although the present disclosure has been described with an exemplary embodiment, various changes and modifications may be suggested to one skilled in the art. It is intended that the present disclosure encompass such changes and modifications as fall within the scope of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
1020100094212 | Sep 2010 | KR | national |