The present technology relates to gain correction in audio coding based on quantization schemes where the quantization is divided into a gain representation and a shape representation, so called gain-shape audio coding, and especially to post-quantization gain correction.
Modern telecommunication services are expected to handle many different types of audio signals. While the main audio content is speech signals, there is a desire to handle more general signals such as music and mixtures of music and speech. Although the capacity in telecommunication networks is continuously increasing, it is still of great interest to limit the required bandwidth per communication channel. In mobile networks, smaller transmission bandwidths for each call yields lower power consumption in both the mobile device and the base station. This translates to energy and cost saving for the mobile operator, while the end user will experience prolonged battery life and increased talk-time. Further, with less consumed bandwidth per user, the mobile network can service a larger number of users in parallel.
Today, the dominating compression technology for mobile voice services is CELP (Code Excited Linear Prediction), which achieves good audio quality for speech at low bandwidths. It is widely used in deployed codecs such as AMR (Adaptive MultiRate), AMR-WB (Adaptive MultiRate WideBand) and GSM-EFR (Global System for Mobile communications—Enhanced FullRate). However, for general audio signals such as music the CELP technology has poor performance. These signals can often be better represented by using frequency transform based coding, for example, the ITU-T codecs 6.722.1. [1] and G.719 [2]. However, transform domain codecs generally operate at a higher bitrate than the speech codecs. There is a gap between the speech and general audio domains in terms of coding, and it is desirable to increase the performance of transform domain codecs at lower bitrates.
Transform domain codecs require a compact representation of the frequency domain transform coefficients. These representations often rely on vector quantization (VQ), where the coefficients are encoded in groups. Among the various methods for vector quantization is the gain-shape VQ. This approach applies normalization to the vectors before encoding the individual coefficients. The normalization factor and the normalized coefficients are referred to as the gain and the shape of the vector, which may be encoded separately. The gain-shape structure has many benefits. By dividing the gain and the shape, the codec can easily be adapted to varying source input levels by designing the gain quantizer. It is also beneficial from a perceptual perspective where the gain and shape may carry different importance in different frequency regions. Finally, the gain-shape division simplifies the quantizer design and makes it less complex in terms of memory and computational resources compared to an unconstrained vector quantizer. A functional overview of a gain-shape quantizer can be seen in
If applied to a frequency domain spectrum, the gain-shape structure can be used to form a spectral envelope and fine structure representation. The sequence of gain values forms the envelope of the spectrum while the shape vectors give the spectral detail. From a perceptual perspective, it is beneficial to partition the spectrum using a non-uniform band structure which follows the frequency resolution of the human auditory system. This generally means that narrow bandwidths are used for low frequencies while larger bandwidths are used for high frequencies. The perceptual importance of the spectral fine structure varies with the frequency but is also dependent on the characteristics of the signal itself. Transform coders often employ an auditory model to determine the important parts of the fine structure and assign the available resources to the most important parts. The spectral envelope is often used as input to this auditory model. The shape encoder quantizes the shape vectors using the assigned bits. See
Depending on the accuracy of the shape quantizer, the gain value used to reconstruct the vector may be more or less appropriate. Especially when the allocated bits are few, the gain value drifts away from the optimal value. One way to solve this is to encode a correcting factor which accounts for the gain mismatch after the shape quantization. Another solution is to encode the shape first and then compute the optimal gain factor given the quantized shape.
The solution to encode a gain correction factor after shape quantization may consume considerable bitrate. If the rate is already low, this means more bits have to be taken elsewhere and may perhaps reduce the available bitrate for the fine structure.
To encode the shape before encoding the gain is a better solution, but if the bitrate for the shape quantizer is decided from the quantized gain value, then the gain and shape quantization would depend on each other. An iterative solution could likely solve this co-dependency, but it could easily become too complex to run in real-time on a mobile device.
An object is to obtain a gain adjustment in decoding of audio that has been encoded with separate gain and shape representations.
This object is achieved in accordance with the attached claims.
A first aspect involves a gain adjustment method that includes the following steps:
A second aspect involves a gain adjustment apparatus that includes:
A third aspect involves a decoder including a gain adjustment apparatus in accordance with the second aspect.
A fourth aspect involves a network node including a decoder in accordance with the third aspect.
The proposed scheme for gain correction improves the perceived quality of a gain-shape audio coding system. The scheme has low computational complexity and does require few additional bits if any.
The present technology, together with further objects and advantages thereof, may best be understood by making reference to the following description taken together with the accompanying drawings, in which:
In the following description the same reference designations will be used for elements performing the same or similar function.
Before the present technology is described in detail, gain-shape coding will be illustrated with reference to
The lower part of
The lower part of
However, as illustrated in
Thus, it is appreciated that depending on the accuracy of the shape quantizer, the gain value Ê(b) used to reconstruct the vector X(b) on the decoder side may be more or less appropriate. In accordance with the present technology, a gain correction can be based on an accuracy measure of the quantized shape.
The accuracy measure used to correct the gain may be derived from parameters already available in the decoder, but it may also depend on additional parameters designated for the accuracy measure. Typically, the parameters would include the number of allocated bits for the shape vector and the shape vector itself, but it may also include the gain value associated with the shape vector and pre-stored statistics about the signals that are typical for the encoding and decoding system. An overview of a system incorporating an accuracy measure and gain correction or adjustment is shown in
As indicated above, the gain correction may in some embodiments be performed without spending additional bits. This is done by estimating the gain correction from parameters already available in the decoder. This process can be described as an estimation of the accuracy of the encoded shape. Typically, this estimation includes deriving the accuracy measure A(b) from shape quantization characteristics indicating the resolution of the shape quantization.
In one embodiment, the present technology is used in an audio encoder/decoder system. The system is transform based and the transform used is the Modified Discrete Cosine Transform (MDCT) using sinusoidal windows with 50% overlap. However, it is understood that any transform suitable for transform coding may be used together with appropriate segmentation and windowing.
The input audio is extracted into frames using 50% overlap and windowed with a symmetric sinusoidal window. Each windowed frame is then transformed to an MDCT spectrum X. The spectrum is partitioned into subbands for processing, where the subband widths are non-uniform. The spectral coefficients of frame m belonging to band b are denoted X(b,m) and have the bandwidth BW(b). Since most encoder and decoder steps can be described within one frame, we omit the frame index and just use the notation X(b). The bandwidths should preferably increase with increasing frequency to comply with the frequency resolution of the human auditory system. The root-mean-square (RMS) value of each band is used as a normalization factor and is denoted E(b):
where X(b)T denotes the transpose of X(b).
The RMS value can be seen as the energy value per coefficient. The sequence of normalization factors E(b) for b=1, 2, . . . , Nbands forms the envelope of the MDCT spectrum, where denotes the number of bands. Next, the sequence is quantized in order to be transmitted to the decoder. To ensure that the normalization can be reversed in the decoder, the quantized envelope E(b) is obtained. In this example embodiment the envelope coefficients are scalar quantized in log domain using a step size of 3 dB and the quantizer indices are differentially encoded using Huffman coding. The quantized envelope is used for normalization of the spectral bands, i.e.:
Note that if the non-quantized envelope E(b) is used for normalization, the shape would have RMS=1, i.e.:
By using the quantized envelope E(b), the shape vector will have an RMS value close to 1. This feature will be used in the decoder to create an approximation of the gain value.
The union of the normalized shape vectors N(b) forms the fine structure of the MDCT spectrum. The quantized envelope is used to produce a bit allocation R(b) for encoding of the normalized shape vectors N(b) The bit allocation algorithm preferably uses an auditory model to distribute the bits to the perceptually most relevant parts. Any quantizer scheme may be used for encoding the shape vector. Common for all is that they may be designed under the assumption that the input is normalized, which simplifies quantizer design. In this embodiment the shape quantization is done using a pulse coding scheme which constructs the synthesis shape from a sum of signed integer pulses [3]. The pulses may be added on top of each other to form pulses of different height. In this embodiment the bit allocation R(b) denotes the number of pulses assigned to band b.
The quantizer indices from the envelope quantization and shape quantization are multiplexed into a bitstream to be stored or transmitted to a decoder.
The decoder demultiplexes the indices from the bitstream and forwards the relevant indices to each decoding module. First, the quantized envelope E(b) is obtained. Next, the fine structure bit allocation is derived from the quantized envelope using a bit allocation identical the one used in the encoder. The shape vectors {circumflex over (N)}(b) of the fine structure are decoded using the indices and the obtained bit allocation R(b).
Now, before scaling the decoded fine structure with the envelope, additional gain correction factors are determined. First, the RMS matching gain is obtained as:
The gRMS (b) factor is a scaling factor that normalizes the RMS value to 1, i.e.:
In this embodiment we seek to minimize the mean squared error (MSE) of the synthesis:
with the solution
Since gMSE(b) depends on the input shape N(b), it is not known in the decoder. In this embodiment the impact is estimated by using an accuracy measure. The ratio of these gains is defined as a gain correction factor gc(b):
When the accuracy of the shape quantization is good, the correction factor is close to 1, i.e.:
{circumflex over (N)}(b)→N(b)⇒gc(b)→1 (9)
However, when the accuracy of {circumflex over (N)}(b) is low, gMSE(b) and gRMS (b) will diverge. In this embodiment, where the shape is encoded using a pulse coding scheme, a low rate will make the shape vector sparse and GRMS (b) will give an overestimate of the appropriate gain in terms of MSE. For this case gc(b) should be lower than 1 to compensate for the overshoot. See
On the other hand, a peaky or sparse target signal can be well represented with a pulse shape. While the sparseness of the input signal may not be known in the synthesis stage, the sparseness of the synthesis shape may serve as an indicator of the accuracy of the synthesized shape vector. One way to measure the sparseness of the synthesis shape is the height of the maximum peak in the shape. The reasoning behind this is that a sparse input signal is more likely to generate high peaks in the synthesis shape. See
In
As noted above, the input shape N(b) is not known by the decoder. Since gMSE (b) depends on the input shape N(b), this means that the gain correction or compensation gc(b) can in practice not be based on the ideal equation (8). In this embodiment the gain correction g (b) is instead decided based on the bit-rate in terms of the number of pulses R(b), the height of the largest pulse in the shape vector pmax(b) and the frequency band b, i.e.:
g
c(b)=f(R(b),pmax(b),b) (10)
It has been observed that the lower rates generally require an attenuation of the gain to minimize the MSE. The rate dependency may be implemented as a lookup table t(R(b)) which is trained on relevant audio signal data. An example lookup table can be seen in
Another example lookup table is given in Table 2.
The estimated sparseness can be implemented as another lookup table u(R(b),pmax (b)) based on both the number of pulses R(b) and the height of the maximum pulse pmax(b). An example lookup table is shown in
A(b)=u(R(b),pmax(b)) (11)
It was noted that the approximation of gMSE was more suitable for the lower frequency range from a perceptual perspective. For the higher frequencies the fine structure becomes less perceptually important and the matching of the energy or RMS value becomes vital. For this reason, the gain attenuation may be applied only below a certain band number bTHR. In this case the gain correction gc(b) will have an explicit dependence on the frequency band b. The resulting gain correction function can in this case be defined as:
The description up to this point may also be used to describe the essential features of the example embodiment of
As an alternative the function u(R(b),pmax(b)) may be implemented as a linear function of the maximum pulse height pmax and the allocated bit rate R(b), for example as:
u(R(b),pmax(b))=k·(pmax(b)−R(b))+1 (14)
where the inclination k is determined by:
The function depends on the tuning parameter amin which gives the initial attenuation factor for R(b)=1 and pmax(b)=1. The function is illustrated in
The bitrate for a given band may change drastically for a given band between adjacent frames. This may lead to fast variations of the gain correction. Such variations are especially critical when the envelope is fairly stable, i.e. the total changes between frames are quite small. This often happens for music signals which typically have more stable energy envelopes. To avoid that the gain attenuation introduces instability, an additional adaptation may be added. An overview of such an embodiment is given in
The adaptation can, for example, be based on a stability measure of the envelope Ê(b). An example of such a measure is to compute the squared Euclidian distance between adjacent log2 envelope vectors:
Here, ΔE(m) denotes the squared Euclidian distance between the envelope vectors for frame m and frame m−1. The stability measure may also be lowpass filtered to have a smoother adaptation:
Δ{tilde over (E)}(m)=αΔE(m)+(1−α)ΔE(m−1) (17)
A suitable value for the forgetting factor α may be 0.1. The smoothened stability measure may then be used to create a limitation of the attenuation using, for example, a sigmoid function such as:
where the parameters may be set to C1=6, C2=2 and C3=1.9. It should be noted that these parameters are to be seen as examples, while the actual values may be chosen with more freedom. For instance:
C
1∈[1,10]
C
2∈[1,4]
C
3∈[−5,10]
The attenuation limitation variable gmin∈[0,1] may be used to create a stability adapted gain modification {tilde over (g)}c(b) as:
{tilde over (g)}
c(b)=max(gc(b),gmin) (20)
After the estimation of the gain, the final synthesis {circumflex over (X)}(b) is calculated as:
In the described variations of embodiment 1 the union of the synthesized vectors {circumflex over (X)}(b) forms the synthesized spectrum {circumflex over (X)}, which is further processed using the inverse MDCT transform, windowed with the symmetric sine window and added to the output synthesis using the overlap-and-add strategy.
In another example embodiment, the shape is quantized using a QMF (Quadrature Mirror Filter) filter bank and an ADPCM (Adaptive Differential Pulse-Code Modulation) scheme for shape quantization. An example of a subband ADPCM scheme is the ITU-T G.722 [4]. The input audio signal is preferably processed in segments. An example ADPCM scheme is shown in
An ADPCM dequantizer 90 includes a step size decoder 92, which decodes the received quantization step size S and forwards it to a dequantizer 94. The dequantizer 94 decodes the error estimate e, which is forwarded to an adder 98, the other input of which receives the output signal from the adder delayed by a delay element 96.
The encoder applies the QMF filter bank to obtain the subband signals. The RMS values of each subband signal are calculated and the subband signals are normalized. The envelope E(b), subband bit allocation R(b) and normalized shape vectors N(b) are obtained as in embodiment 1. Each normalized subband is fed to the ADPCM quantizer. In this embodiment the ADPCM operates in a forward adaptive fashion, and determines a scaling step S(b) to be used for subband b. The scaling step is chosen to minimize the MSE across the subband frame. In this embodiment the step is chosen by trying all possible steps and selecting the one which gives the minimum MSE:
where Q(x,s) is the ADPCM quantizing function of the variable x using a step size of s. The selected step size may be used to generate the quantized shape:
{circumflex over (N)}(b)=Q(N(b),S(b)) (23)
The quantizer indices from the envelope quantization and shape quantization are multiplexed into a bitstream to be stored or transmitted to a decoder.
The decoder demultiplexes the indices from the bitstream and forwards the relevant indices to each decoding module. The quantized envelope Ê(b) and the bit allocation R(b) are obtained as in embodiment 1. The synthesized shape vectors {circumflex over (N)}(b) are obtained from the ADPCM decoder or dequantizer together with the adaptive step sizes S(b). The step sizes indicate an accuracy of the quantized shape vector, where a smaller step size corresponds to a higher accuracy and vice versa. One possible implementation is to make the accuracy A(b) inversely proportional to the step size using a proportionality factor γ:
where γ should be set to achieve the desired relation. One possible choice is γ=Smin where Smin is the minimum step size, which gives accuracy 1 for S(b)=Smin.
The gain correction factor gc may be obtained using a mapping function:
g
c(b)=h(R(b),b)·A(b) (25)
The mapping function h may be implemented as a lookup table based on the rate R(b) and frequency band b. This table may be defined by clustering the optimal gain correction values gMSE/gRMS by these parameters and computing the table entry by averaging the optimal gain correction values for each cluster.
After the estimation of the gain correction, the subband synthesis {circumflex over (X)}(b) is calculated as:
The output audio frame is obtained by applying the synthesis QMF filter bank to the subbands.
In the example embodiment illustrated in
The accuracy measure could be complemented with a signal class parameter derived in the encoder. This may for instance be a speech/music discriminator or a background noise level estimator. An overview of a system incorporating a signal classifier is shown in
The signal class could be incorporated in the gain correction for instance by having a class dependent adaptation. If we assume the signal classes are speech or music corresponding to the values C=1 and C=0 respectively, we can constrain the gain adjustment to be effective only during speech, i.e.:
In another alternative embodiment the system can act as a predictor together with a partially coded gain correction or compensation. In this embodiment the accuracy measure is used to improve the prediction of the gain correction or compensation such that the remaining gain error may be coded with fewer bits.
When creating the gain correction or compensation factor gc one might want to do a trade-off between matching the RMS value or energy and minimizing the MSE. In some cases matching the energy becomes more important than an accurate waveform. This is for instance true for higher frequencies. To accommodate this, the final gain correction may, in a further embodiment, be formed by using a weighted sum of the different gain values:
where gc is the gain correction obtained in accordance with one of the approaches described above. The weighting factor β can be made adaptive to e.g. the frequency, bitrate or signal type.
The steps, functions, procedures and/or blocks described herein may be implemented in hardware using any conventional technology, such as discrete circuit or integrated circuit technology, including both general-purpose electronic circuitry and application-specific circuitry.
Alternatively, at least some of the steps, functions, procedures and/or blocks described herein may be implemented in software for execution by a suitable processing device, such as a micro processor, Digital Signal Processor (DSP) and/or any suitable programmable logic device, such as a Field Programmable Gate Array (FPGA) device.
It should also be understood that it may be possible to reuse the general processing capabilities of the decoder. This may, for example, be done by reprogramming of the existing software or by adding new software components.
The stability detection described with reference to
In the network node in
Although the description above focuses on transform based audio coding, the same principles may also be applied to time domain audio coding with separate gain and shape representations, for example CELP coding.
It will be understood by those skilled in the art that various modifications and changes may be made to the present technology without departure from the scope thereof, which is defined by the appended claims.
ADPCM Adaptive Differential Pulse-Code Modulation
AMR Adaptive MultiRate
AMR-WB Adaptive MultiRate WideBand
CELP Code Excited Linear Prediction
GSM-EFR Global System for Mobile communications-Enhanced FuliRate
DSP Digital Signal Processor
FPGA Field Programmable Gate Array
IP Internet Protocol
MDCT Modified Discrete Cosine Transform
MSE Mean Squared Error
QMF Quadrature Mirror Filter
RMS Root-Mean-Square
VQ Vector Quantization
This application is a continuation of U.S. application Ser. No. 15/668,766 filed 4 Aug. 2017, now U.S. Pat. No. 10,121,481, which is a continuation of U.S. application Ser. No. 14/002,509 filed 30 Aug. 2013, which is a U.S. National Phase Application of PCT/SE2011/050899 filed 4 Jul. 2011, which claims benefit of U.S. Provisional Application No. 61/449,230 filed 4 Mar. 2011. The entire contents of each aforementioned application is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
61449230 | Mar 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15668766 | Aug 2017 | US |
Child | 16565920 | US | |
Parent | 14002509 | Aug 2013 | US |
Child | 15668766 | US |