The present invention relates to methods of coding data, for example to a method of coding audio and/or image data utilizing variable angle rotation of data components. Moreover, the invention also relates to encoders employing such methods, and to decoders operable to decode data generated by these encoders. Furthermore, the invention is concerned with encoded data communicated via data carriers and/or communication networks, the encoded data being generated according to the methods.
Numerous contemporary methods are known for encoding audio and/or image data to generate corresponding encoded output data. An example of a contemporary method of encoding audio is MPEG-1 Layer III known as MP3 and described in ISO/IEC JTC1/SC29/WG11 MPEG, IS 11172-3, Information Technology—Coding of Moving Pictures and Associated Audio for Digital Storage Media at up to about 1.5 Mbit/s, Part 3: Audio, MPEG-1, 1992. Some of these contemporary methods are arranged to improve coding efficiency, namely provide enhanced data compression, by employing mid/side (M/S) stereo coding or sum/difference stereo coding as described by J. D. Johnston and A. J. Ferreira, “Sum-difference stereo transform coding”, in Proc. IEEE, Int. Conf. Acoust., Speech and Signal Proc., San Francisco, Calif., March 1992, pp. II: pp. 569-572.
In M/S coding, a stereo signal comprises left and right signals l[n], r[n] respectively which are coded as a sum signal m[n] and a difference signal s[n], for example by applying processing as described by Equations 1 and 2 (Eq. 1 and 2):
m[n]=r[n]+l[n] Eq. 1
s[n]=r[n]−l[n] Eq. 2
When the signals l[n] and r[n] are almost identical, the M/S coding is capable of providing significant data compression on account of the difference signal s[n] approaching zero and thereby conveying relatively little information whereas the sum signal effectively includes most of the signal information content. In such a situation, a bit rate required to represent the sum and difference signals is close to half that required for independently coding the signals l[n] and r[n].
Equations 1 and 2 are susceptible to being represented by way of a rotation matrix as in Equation 3 (Eq. 3):
wherein c is a constant scaling coefficient often used to prevent clipping.
Whereas Equation 3 effectively corresponds to a rotation of the signals l[n], r[n] by an angle of 45°, other rotation angles are possible as provided in Equation 4 (Eq. 4) wherein α is a rotation angle applied to the signals l[n], r[n] to generate corresponding coded signals m′[n], s′[n] hereinafter described as relating to dominant and residual signals respectively:
The angle α is beneficially made variable to provide enhanced compression for a wide class of signals l[n], r[n] by reducing information content present in the residual signal s′[n] and concentrating information content in the dominant signal m′[n], namely minimize power in the residual signal s′[n] and consequently maximize power in the dominant signal m′[n].
Coding techniques represented by Equations 1 to 4 are conventionally not applied to broadband signals but to sub-signals each representing only a smaller part of a full bandwidth used to convey audio signals. Moreover, the techniques of Equations 1 to 4 are also conventionally applied to frequency domain representations of the signals l[n], r[n].
In a published U.S. Pat. No. 5,621,855, there is described a method of sub-band coding a digital signal having first and second signal components, the digital signal being sub-band coded to produce a first sub-band signal having a first q-sample signal block in response to the first signal component, and a second sub-band signal having a second q-sample signal block in response to the second signal component, the first and second sub-band signals being in the same sub-band and the first and second signal blocks being time equivalent.
The first and second signal blocks are processed to obtain a minimum distance value between point representations of time-equivalent samples. When the minimum distance value is less than or equal to a threshold distance value, a composite block composed of q samples is obtained by adding the respective pairs of time-equivalent samples in the first and second signal blocks together after multiplying each of the samples of the first block by cos(α) and each of the samples of the second signal block by −sin(α).
Although application of the aforementioned rotation angle α is susceptible to eliminating many disadvantages of M/S coding where only a 45° rotation is employed, such approaches are found to be problematic when applied to groups of signals, for example stereo signal pairs, when considerable relative mutual phase or time offsets in these signals occur. The present invention is directed at addressing this problem.
An object of the present invention is to provide a method of encoding data.
According to a first aspect of the present invention, there is provided a method of encoding a plurality of input signals (l, r) to generate corresponding encoded data, the method comprising steps of:
The invention is of advantage in that it is capable of providing for more efficient encoding of data.
Preferably, in the method, only a part of the residual signal (s) is included in the encoded data. Such partial inclusion of the residual signal (s) is capable of enhancing data compression achievable in the encoded data.
More preferably, in the method, the encoded data also includes one or more parameters indicative of parts of the residual signal included in the encoded data. Such indicative parameters are susceptible to rendering subsequent decoding of the encoded data less complex.
Preferably, steps (a) and (b) of the method are implemented by complex rotation with the input signals (l[n], r[n]) represented in the frequency domain (l[k], r[k]). Implementation of complex rotation is capable of more efficiently coping with relative temporal and/or phase differences arising between the plurality of input signals. More preferably, steps (a) and (b) are performed in the frequency domain or a sub-band domain. “Sub-band” is to be construed to be a frequency region smaller than a full frequency bandwidth required for a signal.
Preferably, the method is applied in a sub-part of a full frequency range encompassing the input signals (l, r). More preferably, other sub-parts of the full frequency range are encoded using alternative encoding techniques, for example conventional M/S encoding as described in the foregoing.
Preferably, the method includes an additional step after step (c) of losslessly coding the quantized data to provide the data for multiplexing in step (d) to generate the encoded data. More preferably, the lossless coding is implemented using Huffman coding. Utilizing lossless coding enables potentially higher audio quality to be achieved.
Preferably, the method includes a step of manipulating the residual signal (s) by discarding perceptually non-relevant time-frequency information present in the residual signal (s), said manipulated residual signal (s) contributing to the encoded data (100), and said perceptually non-relevant information corresponding to selected portions of a spectro-temporal representation of the input signals. Discarding perceptually non-relevant information enables the method to provide a greater degree of data compression in the encoded data.
Preferably, in step (b) of the method, the second parameters (α; IID, ρ) are derived by minimizing the magnitude or energy of the residual signal (s). Such an approach is computationally efficient for generating the second parameters in comparison to alternative approaches to deriving the parameters.
Preferably, in the method, the second parameters (α; IID, ρ) are represented by way of inter-channel intensity difference parameters and coherence parameters (IID, ρ). Such implementation of the method is capable of providing backward compatibility with existing parametric stereo encoding and associated decoding hardware or software.
Preferably, in steps (c) and (d) of the method, the encoded data is arranged in layers of significance, said layers including a base layer conveying the dominant signal (m), a first enhancement layer including first and/or second parameters corresponding to stereo imparting parameters, a second enhancement layer conveying a representation of the residual signal (s). More preferably, the second enhancement layer is further subdivided into a first sub-layer for conveying most relevant time-frequency information of the residual signal (s) and a second sub-layer for conveying less relevant time-frequency information of the residual signal (s). Representation of the input signals by these layers, and sub-layers as required is capable of enhancing robustness to transmission errors of the encoded data and rendering it backward compatible with simpler decoding hardware.
According to a second aspect of the invention, there is provided an encoder for encoding a plurality of input signals (l, r) to generate corresponding encoded data, the encoder comprising:
The encoder is of advantage in that it is capable of providing for more efficient encoding of data.
Preferably, the encoder comprises processing means for manipulating the residual signal (s) by discarding perceptually non-relevant time-frequency information present in the residual signal (s), said transformed residual signal (s) contributing to the encoded data (100) and said perceptually non-relevant information corresponding to selected portions of a spectro-temporal representation of the input signals. Discarding perceptually non-relevant information enables the encoder to provide a greater degree of data compression in the encoded data.
According to a third aspect of the present invention, there is provided a method of decoding encoded data to regenerate corresponding representations of a plurality of input signals (l′, r′), said input signals (l, r) being previously encoded to generate said encoded data, the method comprising steps of:
The method provides an advantage of being capable of efficiently decoding data which has been efficiently coding using a method according to the first aspect of the invention.
Preferably, step (b) of the method includes a further step of appropriately supplementing missing time-frequency information of the residual signal (s) with a synthetic residual signal derived from the dominant signal (m). Generation of the synthetic signal is capable of resulting in efficient decoding of encoded data.
Preferably, in the method, the encoded data includes parameters indicative of which parts of the residual signal (s) are encoded into the encoded data. Inclusion of such indicative parameters is capable of rendering decoding for efficient and less computationally demanding.
According to a fourth aspect of the present invention, there is provided a decoder for decoding encoded data to regenerate corresponding representations of a plurality of input signals (l′, r′), said input signals (l, r) being previously encoded to generate the encoded data, the decoder comprising:
Preferably, the second processing means is operable to generate a supplementary synthetic signal derived from the decoded dominant signal (m) for providing information missing from the decoded residual signal.
According to a fifth aspect of the invention, there is provided encoded data generated according to the method of the first aspect of the invention, the data being at least one of recorded on a data carrier and communicable via a communication network.
According to a sixth aspect of the invention, there is provided software for executing the method of the first aspect of the invention on computing hardware.
According to a seventh aspect of the invention, there is provided software for executing the method of the third aspect of the invention on computing hardware.
According to an eighth aspect of the invention, there is provided encoded data at least one of recorded on a data carrier and communicable via a communication network, said data comprising a multiplex of quantizing first parameters, quantized second parameters, and quantized data corresponding to at least a part of a dominant signal (m) and a residual signal (s), wherein the dominant signal (m) has a magnitude or energy greater than the residual signal (s), said dominant signal (m) and said residual signal (s) being derivable by rotating intermediate signals according to the second parameters, said intermediate signals being generated by processing a plurality of input signals to compensate for relative phase and/or temporal delays therebetween as described by the first parameters.
It will be appreciated that features of the invention are susceptible to being combined in any combination without departing from the scope of the invention as defined in the accompanying claims.
Embodiments of the invention will now be described, by way of example only, with reference to the following diagrams wherein:
In overview, the present invention is concerned with a method of coding data which represents an advance to M/S coding methods described in the foregoing employing a variable rotation angle. The method is devised by the inventors to be better capable of coding data corresponding to groups of signals subject to considerable phase and/or time offset. Moreover, the method provides advantages in comparison to conventional coding techniques by employing values for the rotation angle ax which can be used when the signals l[n], r[n] are represented by their equivalent complex-valued frequency domain representations l[k], r[k] respectively.
The angle α can be arranged to be real-valued and a real-valued phase rotation applied to mutually “cohere” the l[n], r[n] signals to accommodate mutual temporal and/or phase delays between these signals. However, use of complex values for the rotation angle α renders the present invention easier to implement. Such an alternative approach to implementing rotation by angle α is to be construed to be within the scope of the present invention.
Frequency-domain representations of the aforesaid time-domain signals l[n], r[n] are preferably derived by applying a temporal windowing procedure as described by Equations 5 and 6 (Eq. 5 and 6) to provide windowed signals lq[n], rq[n]:
lq[n]=l[n+qH]·h[n] Eq. 5
rq[n]=r[n+qH]·h[n] Eq. 6
wherein
The windowed signals lq[n], rq[n] are transformable to the frequency domain by using a Discrete Fourier Transform (DFT), or functionally equivalent transform, as described in Equations 7 and 8 (Eq. 7 and 8):
wherein a parameter N represents a DFT length such that N≧L. On account of the DFT of a real-valued sequence being symmetrical, only the first N/2+1 points are preserved after the transform. In order to preserve signal energy when implementing the DFT, the following scaling as described in Equations 9 and 10 (Eq. 9 and 10) is preferably employed:
The method of the invention performs signal processing operations as depicted by Equation 11 (Eq. 11) to convert the frequency domain signal representations l[k], r[k] in Equations 7 and 8 to corresponding rotated sum and difference signals m″[k], s″[k] in the frequency domain:
wherein
Use of the angle φ1 is optional. Moreover, rotations pursuant to Equation 11 are preferably executed on a frame-by-frame basis, namely dynamically in frame steps. However, such dynamic changes in rotation from frame-to-frame can potentially cause signal discontinuities in the sum signal m″[k] which can be at least partially removed by suitable selection of the angle φ1.
Furthermore, the frequency range k=0 . . . N/2+1 of Equation 11 is preferably divided into sub-ranges, namely regions. For each region during encoding, its corresponding angle parameters α, φ1 and φ2 are then independently determined, coded and then transmitted or otherwise conveyed to a decoder for subsequent decoding. By arranging for the frequency range to be sub-divided, signal properties can be better captured during encoding resulting potentially in higher compression ratios.
After implementing mappings pursuant to Equations 7 to 11, the signals m″[k], s″[k] are subjected to an inverse Discrete Fourier Transform as described in Equations 12 and 13 (Eq. 12 & 13):
wherein
The dominant and residual representations are then converted in the method to representations on a windowed basis to which overlap is applied as provided by processing operations as described by Equations 14 and 15 (Eq. 14 and 15):
m[n+qH]=m[n+qH]+2Re{mq[n]·h[n]} Eq. 14
s[n+qH]=s[n+qH]+2Re{sq[n]·h[n]} Eq. 15
Alternatively, processing operations of the method of the invention as described by Equations 5 to 15 are susceptible, at least in part, to being implemented in practice by employing complex-modulated filter banks. Digital processing applied in computer processing hardware can be employed to implement the invention.
In order to illustrate the method of the invention, a signal processing example of the invention will now be described. For the example, two temporal signals are used as initial signals to be processed using the method, the two signals being defined by Equations 16 and 17 (Eq. 16 and 17):
l[n]=0.5 cos(0.32n+0.4)+0.05·z1[n]+0.06·z2[n] Eq. 16
r[n]=0.25 cos(0.32n+1.8)+0.03·z1[n]+0.05·z3 [n] Eq. 17
wherein z1[n], z2[n] and z3[n] are mutually independent white noise sequences of unity variance. In order to better appreciate operation of the method of the invention, portions of the signals l[n], r[n] described by Equations 16 and 17 are shown in
In
By employing a rotation transform as described by Equation 4, it is possible for the example signals l[n], r[n] to reduce the residual energy in their corresponding residual signal s[n] and correspondingly enhance their dominant signal m[n] as illustrated in
When the sample signals l[n], r[n] of Equations 16 and 17 are subjected to transformation to the frequency domain, then subjected to a complex optimizing rotation pursuant to the Equations 5 to 15, it is feasible to reduce the energy of the residual signal s[n] to a comparatively small magnitude as illustrated in
Embodiments of encoder hardware operable to implement signals processing as described by Equations 5 to 15 will next be described.
In
The input signals l, r are coupled to inputs of the phase rotation unit 20 whose corresponding outputs are connected to the signal rotation unit 30. Dominant and residual signals of the signal rotation unit 30 are denoted by m, s respectively. The dominant signal m is conveyed via the first coder 50 to the multiplexer unit 80. Moreover, the residual signal s is coupled via the time/frequency selector 40 to the second coder 60 and thereafter to the multiplexer unit 80. Angle parameter outputs φ1, φ2 from the phase rotation unit 20 are coupled via the processing unit 70 to the multiplexer unit 80. Additionally, an angle parameter output α is coupled from the signal rotation unit 30 via the processing unit 70 to the multiplexer unit 80. The multiplexer unit 80 comprises the aforementioned encoded bit stream output (bs) 100.
In operation, the phase rotation unit 20 applies processing to the signals l, r to compensate for relative phase differences therebetween and thereby generate the parameters φ1, φ2 wherein the parameter φ2 is representative of such relative phase difference, the parameters φ1, φ2 being passed to the processing unit 70 for quantizing and thereby including as corresponding parameter data in the encoded bit stream 100. The signals l, r compensated for relative phase difference pass to the signal rotation unit 30 which determines an optimized value for the angle α to concentrate a maximum amount of signal energy in the dominant signal m and a minimum amount of signal energy in the residual signal s. The dominant and residual signals m, s then pass via the coders 50, 60 to be converted to a suitable format for inclusion in the bit stream 100. The processing unit 70 receives the angle signals α, φ1, φ2 and multiplexes them together with the output from the coders 50, 60 to generate the bit-stream output (bs) 100. Thus, the bit-stream (bs) 100 thereby comprises a stream of data including representations of the dominant and residual signals m, s together with angle parameter data α, φ1, φ2 wherein the parameter φ2 is essential and the parameters φ1 are optional but nevertheless beneficial to include.
The coders 50, 60 are preferably implemented as two mono audio encoders, or alternatively as one dual mono encoder. Optionally, certain parts of the residual signal s, for example identified when represented in a time-frequency plane, not perceptibly contributing to the bit stream 100 can be discarded in the time/frequency selector 40, thereby providing scalable data compression as elucidated in more detail below.
The encoder 10 is optionally capable of being used for processing the input signals (l, r) over a part of a full frequency range encompassing the input signals. Those parts of the input signals (l, r) not encoded by the encoder 10 are then in parallel encoded using other methods, for example using conventional M/S encoding as described in the foregoing. If required individual encoding of left (l) and right (r) input signals can be implemented if required.
The encoder 10 is susceptible to being implemented in hardware, for example as an application specific integrated circuit or group of such circuits. Alternatively, the encoder 10 can be implemented in software executing on computing hardware, for example on a proprietary software-driven signal processing integrated circuit or group of such circuits.
In
In operation, the decoder 200 performs an inverse of encoding steps executed within the encoder 10. Thus, in the decoder 200, the bit-stream 100 is demultiplexed in the demultiplexer 210 to isolate data corresponding to the dominant and residual signals which are reconstituted by the decoders 220, 230 to generate the decoded dominant and residual signals m′, s′. These signals m′, s′ are then rotated according to the angle α′ and then corrected for relative phase using the angles φ1′, φ2′ to regenerate the left and right signals l′, r′. The angles φ1′, φ2′, α′ are regenerated from parameters demultiplexed in the demultiplexer 210 and isolated in the processing unit 240.
In the encoder 10, and hence also in the decoder 200, it is preferable to transmit in the bit-stream 100 an IID value and a coherence value ρ rather than the aforementioned angle α. The IID value is arranged to represent an inter-channel difference, namely denoting frequency and time variant magnitude differences between the left and right signals l, r. The coherence value ρ denotes frequency variant coherence, namely similarity, between the left and right signals l, r after phase synchronization. However, for example in the decoder 200, the angle α is readily derivable from the IID and ρ values by applying Equation 18 (Eq. 18):
A parametric decoder is indicated generally by 400 in
The decoder 400 is distinguished from the decoder 200 of
Referring next to
In the encoder 500, the residual signal s is encoded directly into the bit-stream 100. Optionally, the time/frequency selector unit 530 is operable to determine which parts of the time/frequency plane of the residual signal s are encoded into the bit-stream (bs) 100, the unit 530 thereby determining a degree to which residual information is included the bit-stream 100 and hence affecting a compromise between compression attainable in the encoder 500 and degree of information included within the bit-stream 100.
In
In the decoder 600, the bit-stream 100 is de-multiplexed into separate streams for the dominant signal m′, for the residual signal s′ and for stereo parameters. The dominant and residual signals m′, s′ are then decoded by the decoders 620, 640 respectively. Those spectral/temporal parts of the residual signal s′ which have been encoded into the bit-stream 100 are communicated in the bit-stream 100 either implicitly, namely by detecting “empty” areas in the time-frequency plane, or explicitly, namely by means of representative signaling parameters decoded from the bit stream 100. The de-correlation unit 630 and the combiner unit 650 are operable to fill empty time-frequency areas in the decoded residual signal s′ effectively with a synthetic residual signal. This synthetic signal is generated by using the decoded dominant signal m′ and output from the de-correlation unit 650. For all other time-frequency areas, the residual signal s is applied to construct the decoded residual signal s′; for these areas, no scaling is applied in the scaling unit 660. Optionally, for these areas, it is beneficial to transmit the aforementioned angle α in the encoder 500 instead of IID and coherence ρ data as data rate required to convey the single angle parameter α is less than required to convey equivalent IID and coherence ρ parameter data. However, transmission of the angle α parameter in the bit stream 100 instead of the IID and ρ parameter data renders the encoder 500 and decoder 600 non-backwards compatible with regular conventional Parametric Stereo (PS) systems which utilize such IID and coherence ρ data.
The selector units 40, 530 of the encoders 10, 500 respectively are preferably arranged to employ a perceptual model when selecting which time-frequency areas of the residual signal s need to be encoded into the bit-stream 100. By coding various time-frequency aspects of the residual signal s in the encoders 10, 500, it is possible to thereby achieve bit-rate scalable encoders and decoders. When layers in the bit-stream 100 are mutually dependent, coded data corresponding to perceptually most relevant time-frequency aspects are included in a base layer included in the layers, with perceptually less important data moved to refinement or enhancement layers included in the layers; “enhancement layer” is also referred to as being “refinement layer”. In such an arrangement, the base layer preferably comprises a bit stream corresponding to the dominant signal m, a first enhancement layer comprises a bit stream corresponding to stereo parameters such as aforementioned angles α, φ1, φ2, and a second enhancement layer comprises a bit stream corresponding to the residual signal s.
Such an arrangement of layers in the bit-stream data 100 allows for the second enhancement layer conveying the residual signal s to be optionally lost or discarded; moreover, the decoder 600 illustrated in
Further bit rate reductions in the bit stream (bs) 100 in the foregoing are possible by discarding encoded angle parameters φ1, φ2 therein. In such a situation, the phase rotation unit 680 in the decoder 600 reconstructs the regenerated output signals l′, r′ using a default rotation angles of fixed value, for example zero value; such further bit rate reduction exploits a characteristic that the human auditory system is relative phase-insensitive at higher audio frequencies. As an example, the parameters φ2 are transmitted in the bit stream (bs) 100 and the parameters φ1 are discarded therefrom for achieving bit rate reduction.
Encoders and complementary decoders according to the invention described in the foregoing are potentially useable in a broad range of electronic apparatus and systems, for example in at least one of: Internet radio, Internet streaming, Electronic Music Distribution (EMD), solid state audio players and recorders as well as television and audio products in general.
Although a method of encoding the input signals (l, r) to generate the bit-stream 100 is described in the foregoing, and complementary methods of decoding the bit-stream 100 elucidated, it will be appreciated that the invention is susceptible to being adapted to encode more than two input signals. For example, the invention is capable of being adapted for providing data encoding and corresponding decoding for multi-channel audio, for example 5-channel domestic cinema systems.
In the accompanying claims, numerals and other symbols included within brackets are included to assist understanding of the claims and are not intended to limit the scope of the claims in any way.
It will be appreciated that embodiments of the invention described in the foregoing are susceptible to being modified without departing from the scope of the invention as defined by the accompanying claims.
Expressions such as “comprise”, “include”, “incorporate”, “contain”, “is” and “have” are to be construed in a non-exclusive manner when interpreting the description and its associated claims, namely construed to allow for other items or components which are not explicitly defined also to be present. Reference to the singular is also to be construed to be a reference to the plural and vice versa.
Number | Date | Country | Kind |
---|---|---|---|
04103168.3 | Jul 2004 | EP | regional |
04101405.1 | Apr 2004 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB05/51058 | 3/29/2005 | WO | 10/2/2006 |