The invention relates to audio encoding in general. More particularly, the invention relates to a rate-distortion control scheme for encoding of digital data.
The standardized body, Motion Picture Experts Group (MPEG), discloses conventional data compression methods in their standards such as, for example, the MPEG-2 advanced audio coding (AAC) standard (see ISO/IEC 13818-7) and the MPEG-4 AAC standard (see ISO/IEC 14496-3). These standards are collectively referred to herein as the MPEG standard.
An audio encoder defined by the MPEG standard receives an input pulse code modulation (PCM) signal, converts it through a modified discrete cosine transform (MDCT) operation into frequency spectral data, and determines optimal scale factors for quanitizing the frequency spectral data using a rate-distortion control mechanism. The audio encoder further quantizes the frequency spectral data using the optimal scale factors, groups the resulting quantized spectral coefficients into scalefactor bands, and then subjects the grouped quantized coefficients to Huffman encoding.
According to the MPEG standard, the rate-distortion control mechanism operates iteratively to select scale factors that can produce spectral data satisfying two major requirements. Firstly, the quantization noise (audio quality) may not exceed allowed distortion that indicates the maximum amount of noise that can be injected into the spectral data without becoming audible. The allowed distortion is typically determined based on psychoacoustic modeling of human hearing. Secondly, the amount of used bits resulting from the Huffman encoding may not exceed an allowable amount of bits calculated from the bit rate specified upon encoding.
The rate-distortion control mechanism typically defines individual scale factors and a common scale factor. Individual scale factors vary for different scalefactor bands within the frame and a common scale factor is not changed within the frame. According to the MPEG standard, the rate-distortion control process iteratively increments an initial (the smallest possible) common scale factor to minimize the difference between the amount of used bits resulting from the Huffman encoding and the allowable amount of bits calculated from the bit rate specified upon encoding. Then, the rate-distortion control process checks the distortion of each individual scalefactor band and, if the allowed distortion is exceeded, amplifies the scalefactor bands, and calls the common scale factor loop again. This rate-distortion control process is reiterated until the noise of the quantized frequency spectrum becomes lower than the allowed distortion and the amount of bits required for quantization becomes lower than the allowable amount of bits.
The above-described conventional rate-distortion control process takes a large amount of computation because it has to process a wide range of possible scale factors. In addition, it lacks the ability to choose optimal scale factors when a low bit-rate (below 64 kbits/sec) is required.
An initial number of bits associated with an initial common scale factor is determined, an initial increment is computed using the initial number of bits and a target number of bits, and the initial scale factor is incremented by the initial increment. Further, the incremented common scale factor is adjusted based on the target number of bits, and individual scale factors are computed based on the adjusted common scale factor and allowed distortion. If a current number of bits associated with the computed individual scale factors exceeds the target number of bits, the adjusted common scale factor is modified until a resulting number of bits no longer exceeds the target number of bits.
The present invention will be understood more fully from the detailed description given below and from the accompanying drawings of various embodiments of the invention, which, however, should not be taken to limit the invention to the specific embodiments, but are for explanation and understanding only.
In the following detailed description of embodiments of the invention, reference is made to the accompanying drawings in which like references indicate similar elements, and in which is shown, by way of illustration, specific embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that logical, mechanical, electrical, functional and other changes may be made without departing from the scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the present invention is defined only by the appended claims.
Beginning with an overview of the operation of the invention,
The filterbank module 102 receives a pulse code modulation (PCM) signal, modulates it using a window function, and then performs a modified discrete cosine transform operation (MDCT). The window function modulates the signal using two types of operation, one being a long window type in which a signal to be analyzed is expanded in time for improved frequency resolution, the other being a short window type in which a signal to be analyzed is shortened in time for improved time resolution. The long window type is used in the case where there exists only a stationary signal, and the short window type is used when there is a rapid signal change. By using these two types of operation according to the characteristics of a signal to be analyzed, it is possible to prevent the generation of unpleasant noise called a pre-echo, which would otherwise result from an insufficient time resolution. The MDCT operation is performed to convert the time-domain signal into a number of samples of frequency spectral data.
The coding tools 104 include a set of optional tools for spectral processing. For example, the coding tools may include a temporal noise shaping (TNS) tool and a prediction tool. The TNS tool may be used to control the temporal shape of the noise within each window of the transform and to solve the pre-echo problem. The prediction tool may be used to remove the correlation between the samples.
The psychoacoustic modeler 106 analyzes the samples to determine an auditory masking curve. The auditory masking curve indicates the maximum amount of noise that can be injected into each respective sample without becoming audible. What is audible in this respect is based on psychoacoustic models of human hearing. The auditory masking curve serves as an estimate of a desired noise spectrum.
The quantization module 110 is responsible for selecting optimal scale factors for the frequency spectral data. As will be discussed in more detail below, the scale factor selection process is based on allowed distortion computed from the masking curve and the allowable number of bits (referred to as a target number of bits) calculated from the bit rate specified upon encoding. Once the optimal scale factors are selected, the quantization module 110 uses them to quantize the frequency spectral data. The resulting quantized spectral coefficients are grouped into scalefactor bands (SFBs). Each SFB includes coefficients that resulted from the use of the same scale factor.
The Huffman encoding module 114 is responsible for selecting an optimal Huffman codebook for each group of quantized spectral coefficients and performing the Huffman-encoding operation using the optimal Huffman codebook. The resulting variable length code (VLC), data identifying the codebook used in the encoding, the scale factors selected by the quantization module 110, and some other information are subsequently assembled into a bit stream.
In one embodiment, the quantization module 110 includes a rate-distortion control section 108 and a quantization/dequantization section 112. The rate-distortion control section 108 performs an iterative scale factor selection process for each frame of spectral data. In this process, the rate-distortion control section 108 finds an optimal common scale factor for the entire frame and optimal individual scale factors for different scalefactor bands within the frame.
In one embodiment, the rate-distortion control section 108 begins with setting an initial common scale factor to the value of a common scale factor of a previous frame or another channel. The quantization/dequantization section 112 quantizes the spectral data within the frame using the initial common scale factor and passes the quantized spectral data to the Huffman encoding module 114 that subjects the quantized spectral data to Huffman encoding to determine the number of bits used by the resulting VLC. Based on this number of used bits and the target number of bits calculated from the bit rate specified upon encoding, the rate-distortion control section 108 determines a first increment for the initial common scale factor. When the first increment is added to the initial common scale factor, the incremented common scale factor produces the number of bits that is relatively close to the target number of bits. Then, the rate-distortion control section 108 further adjusts the incremented common scale factor to achieve a more precise proximity of the resulting number of used bits to the target number of bits.
Further, the rate-distortion control section 108 computes individual scale factors for scalefactor bands within the frame. As will be discussed in more detail below, the individual scale factors are computed based on the adjusted common scale factor and allowed distortion. In one embodiment, the computation of each individual scale factor involves iterative modification of each individual scale factor until an energy error associated with a specific individual scale factor is below the allowed distortion. In one embodiment, the energy error is calculated by the quantization/dequantization section 112 by quantizing frequency spectral data of a scalefactor band using a given scale factor, then dequantizing this quantized data with the given scale factor, and then computing the difference between the original (pre-quantized) frequency spectral data and the dequantized spectral data.
Once individual scale factors are computed, the rate-distortion control section 108 determines whether a number of bits produced by use of the individual scale factors and the adjusted common scale factor exceeds the target number of bits. If so, the rate-distortion control section 108 further modifies the adjusted common scale factor until a resulting number of used bits no longer exceeds the target number of bits. Because the computed individual scale factors produce the desired profile of the quantization noise shape, they do not need to be recomputed when the adjusted common scale factor is modified.
Referring to
Next, processing logic quantizes the data in the frame using the initial common scale factor (processing block 204) and tests the validity of the resulting quantized data (decision box 206). In one embodiment, a quantized spectral coefficient is valid if its absolute value does not exceed a threshold number (e.g., 8191 according to the MPEG standard). If the resulting quantized data is not valid, processing logic increments the initial common scale factor by a constant (e.g., 5) that may be determined experimentally (processing block 208).
If the resulting quantized data is valid, processing logic determines the number of bits that are to be used by Huffman-encoded quantized data (processing block 210), computes a first increment for the initial common scale factor based on the number of used bits and a target number of bits (processing block 212), and adds the first increment to the to the initial common scale factor (processing block 214). As discussed above, the target number of bits may be calculated from the bit rate specified upon encoding.
In one embodiment, the first increment is calculated using the following expression:
Next, processing logic further adjusts the incremented common scale factor to achieve a more precise proximity of the resulting number of used bits to the target number of bits (processing block 220). One embodiment of the adjustment process will be discussed in more detail below in conjunction with
At processing block 222, processing logic computes individual scale factors for scalefactor bands within the frame using the adjusted common scale factor and allowed distortion. In one embodiment, the allowed distortion is calculated based on a masking curve obtained from a psychoacoustic modeler 106 of
Further, processing logic determines a number of bits produced by use of the computed individual scale factors and the adjusted common scale factor (processing block 224) and determines whether this number of used bits exceeds the target number of bits (decision box 226). If so, processing logic further modifies the adjusted common scale factor until the resulting number of used bits no longer exceeds the target number of bits (processing block 226). One embodiment of a process for determining a final common scale factor will be discussed in more detail below in conjunction with
Referring to
Next, processing logic checks whether the quantized data is valid (decision box 304). If not, processing logic increments the current scale factor by a constant (e.g., 5) (processing block 306). If so, processing logic determines a number of bits be used by the quantized spectral data upon Huffman-encoding (processing block 308).
Further, processing logic determines whether the number of used bits exceeds the target number of bits (decision box 310). If not, then more bits can be added to the data transmitted after Huffman encoding. Hence, processing logic modifies the current common scale factor using increase-bit modification logic (processing block 312). If the determination made at decision box 310 is positive, then processing logic modifies the current common scale factor using decrease-bit modification logic (processing block 314).
Referring to
At decision box 403, processing logic determines whether the current value of the quantizer change field is equal to 0. If so, process 400 ends. If not, process 400 continues with processing logic quantizing the spectral data within the frame being processed using a current common scale factor and determining a number of bits used by the quantized spectral data upon Huffman encoding (processing block 404).
At decision box 406, processing logic determines whether the number of used bits is below the target number of bits. If yes, and this is not the first iteration (decision box 408), the rate change flag remains to be set to the value indicating the increase bit direction (e.g., over_budget=1). If not, or this is the first iteration (decision box 408), processing logic updates the rate change flag with the value indicating the decrease bit direction (e.g., over_budget=0) (processing block 410).
Further, if the rate change flag indicates the increase bit direction (decision box 412), processing logic determines whether the upcrossed flag is set to 1 (decision box 414). If so, processing logic calculates the current value of the quantizer change field as quantizer_change=quantizer_change>>1 (processing block 416) and determines whether the number of used bits is below the target number of bits (decision box 418). If so, processing logic subtracts the value of the quanitzer change field from the current common scale factor (processing block 420) and proceeds to decision box 404. If not, processing logic adds the value of the quanitzer change field to the current common scale factor (processing block 422) and proceeds to decision box 404.
If the upcrossed flag is set to 0 (decision box 414), processing logic determines whether the number of used bits is below the target number of bits (decision box 424). If so, processing logic subtracts the current value of the quanitzer change field from the current common scale factor (processing block 426) and proceeds to decision box 404. If not, processing logic sets the upcrossed flag to 1, calculates the new value of the quantizer change field as quantizer_change=quantizer_change>>1, subtracts the new value of the quanitzer change field from the current common scale factor (processing block 428), and proceeds to decision box 404.
If the rate change flag indicates the decrease bit direction (decision box 412), processing logic determines whether the downcrossed flag is set to 1 (decision box 430). If so, processing logic calculates the current value of the quantizer change field as quantizer_change=quantizer_change>>1 (processing block 432) and determines whether the number of used bits is below the target number of bits (decision box 434). If not, processing logic adds the current value of the quanitzer change field to the current common scale factor (processing block 436) and proceeds to decision box 404. If so, processing logic subtracts the current value of the quanitzer change field from the current common scale factor (processing block 438) and proceeds to decision box 404.
If the downcrossed flag is set to 0 (decision box 430), processing logic determines whether the number of used bits is below the target number of bits (decision box 440). If not, processing logic adds the current value of the quanitzer change field to the current common scale factor (processing block 442) and proceeds to decision box 404. If so, processing logic sets the downcrossed flag to 1, calculates the new value of the quantizer change field as quantizer_change=qiantizer_change>>1, subtracts the new value of the quanitzer change field from the current common scale factor (processing block 444), and proceeds to decision box 404.
Referring to
At decision box 512, processing logic determines whether the computed energy error is greater than K*allowed_distortion_energy, where K is a constant and allowed_distortion_energy is an allowed quantization error (also referred to as allowed distortion). In one embodiment, the allowed distortion is calculated based on the masking curve provided by the psychoacoustic modeler 106 of
If the determination made at decision box 512 is negative, processing logic sets the current increment field to the first constant A (processing block 514). Otherwise, processing logic sets the current increment field to a second constant B (e.g., B=3) (processing block 516). In one embodiment, parameters A, B and K are determined experimentally, choosing the values that are likely to provide good performance.
Further, processing logic determines whether the computed energy error is lower than the allowed distortion (decision box 518). If not, processing logic returns to processing block 504 and repeats blocks 504 through 518. If so, the value of this individual scale factor is considered final, and processing logic moves to the next individual scalefactor (processing block 522). If all scale factors of this frame are processed (decision box 520), process 500 ends.
Referring to
Further, processing logic determines whether the number of used bits exceeds the target number of bits (decision box 608). If so, processing logic adds the offset value to the current common scale factor (processing block 610), sets the offset value to a second constant (e.g., offset=1), and returns to processing block 604. Otherwise, if the number of used bits exceeds the target number of bits, process 600 ends.
The following description of
The computer system 740 includes a processor 750, memory 755 and input/output capability 760 coupled to a system bus 765. The memory 755 is configured to store instructions which, when executed by the processor 750, perform the methods described herein. Input/output 760 also encompasses various types of computer-readable media, including any type of storage device that is accessible by the processor 750. One of skill in the art will immediately recognize that the term “computer-readable medium/media” further encompasses a carrier wave that encodes a data signal. It will also be appreciated that the system 740 is controlled by operating system software executing in memory 755. Input/output and related media 760 store the computer-executable instructions for the operating system and methods of the present invention. The quantization module 110 shown in
It will be appreciated that the computer system 740 is one example of many possible computer systems that have different architectures. A typical computer system will usually include at least a processor, memory, and a bus coupling the memory to the processor. One of skill in the art will immediately appreciate that the invention can be practiced with other computer system configurations, including multiprocessor systems, minicomputers, mainframe computers, and the like. The invention can also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network.
Various aspects of selecting optimal scale factors have been described. Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement which is calculated to achieve the same purpose may be substituted for the specific embodiments shown. This application is intended to cover any adaptations or variations of the present invention.
A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever. The following notice applies to the software and data as described below and in the drawings hereto: Copyright © 2001, Sony Electronics, Inc., All Rights Reserved.