1. Field
Apparatuses, devices, and articles of manufacture consistent with the present disclosure relate to audio encoding and decoding, and more particularly, to a method and apparatus for efficiently allocating bits to a perceptively important frequency area based on sub-bands, an audio encoding method and apparatus, an audio decoding method and apparatus, a recording medium and a multimedia device employing the same.
2. Description of the Related Art
When an audio signal is encoded or decoded, it is required to efficiently use a limited number of bits to restore an audio signal having the best sound quality in a range of the limited number of bits. In particular, at a low bit rate, a technique of encoding and decoding an audio signal is required to evenly allocate bits to perceptively important spectral components instead of concentrating the bits to a specific frequency area.
In particular, at a low bit rate, when encoding is performed with bits allocated to each frequency band such as a sub-band, a spectral hole may be generated due to a frequency component, which is not encoded because of an insufficient number of bits, thereby resulting in a decrease in sound quality.
It is an aspect to provide a method and apparatus for efficiently allocating bits to a perceptively important frequency area based on sub-bands, an audio encoding method and apparatus, an audio decoding method and apparatus, a recording medium and a multimedia device employing the same.
It is an aspect to provide a method and apparatus for efficiently allocating bits to a perceptively important frequency area with a low complexity based on sub-bands, an audio encoding method and apparatus, an audio decoding method and apparatus, a recording medium and a multimedia device employing the same.
According to an aspect of one or more exemplary embodiments, there is provided a bit allocating method comprising: determining the allocated number of bits in decimal point units based on each frequency band so that a Signal-to-Noise Ratio (SNR) of a spectrum existing in a predetermined frequency band is maximized within a range of the allowable number of bits for a given frame; and adjusting the allocated number of bits based on each frequency band.
According to another aspect of one or more exemplary embodiments, there is provided a bit allocating apparatus comprising: a transform unit that transforms an audio signal in a time domain to an audio spectrum in a frequency domain; and a bit allocating unit that estimates the allowable number of bits in decimal point units by using a masking threshold based on frequency bands included in a given frame in the audio spectrum, estimates the allocated number of bits in decimal point units by using spectral energy, and adjusts the allocated number of bits not to exceed the allowable number of bits.
According to another aspect of one or more exemplary embodiments, there is provided an audio encoding apparatus comprising: a transform unit that transforms an audio signal in a time domain to an audio spectrum in a frequency domain; a bit allocating unit that determines the allocated number of bits in decimal point units based on each frequency band so that a Signal-to-Noise Ratio (SNR) of a spectrum existing in a predetermined frequency band is maximized within a range of the allowable number of bits for a given frame of the audio spectrum and adjusts the allocated number of bits determined based on each frequency band; and an encoding unit that encodes the audio spectrum by using the number of bits adjusted based on each frequency band and spectral energy.
According to another aspect of one or more exemplary embodiments, there is provided an audio decoding apparatus comprising: a transform unit that transforms an audio signal in a time domain to an audio spectrum in a frequency domain; a bit allocating unit that determines the allocated number of bits in decimal point units based on each frequency band so that a Signal-to-Noise Ratio (SNR) of a spectrum existing in a predetermined frequency band is maximized within a range of the allowable number of bits for a given frame of the audio spectrum and adjusts the allocated number of bits determined based on each frequency band; and an encoding unit that encodes the audio spectrum by using the number of bits adjusted based on each frequency band and spectral energy.
According to another aspect of one or more exemplary embodiments, there is provided an audio decoding apparatus comprising: a bit allocating unit that estimates the allowable number of bits in decimal point units by using a masking threshold based on frequency bands included in a given frame, estimates the allocated number of bits in decimal point units by using spectral energy, and adjusts the allocated number of bits not to exceed the allowable number of bits; a decoding unit that decodes an audio spectrum included in a bitstream by using the number of bits adjusted based on each frequency band and spectral energy; and an inverse transform unit that transforms the decoded audio spectrum to an audio signal in a time domain.
The above and other aspects will become more apparent by describing in detail exemplary embodiments thereof with reference to the attached drawings in which:
The present inventive concept may allow various kinds of change or modification and various changes in form, and specific exemplary embodiments will be illustrated in drawings and described in detail in the specification. However, it should be understood that the specific exemplary embodiments do not limit the present inventive concept to a specific disclosing form but include every modified, equivalent, or replaced one within the spirit and technical scope of the present inventive concept. In the following description, well-known functions or constructions are not described in detail since they would obscure the invention with unnecessary detail.
Although terms, such as ‘first’ and ‘second’, can be used to describe various elements, the elements cannot be limited by the terms. The terms can be used to classify a certain element from another element.
The terminology used in the application is used only to describe specific exemplary embodiments and does not have any intention to limit the present inventive concept. Although general terms as currently widely used as possible are selected as the terms used in the present inventive concept while taking functions in the present inventive concept into account, they may vary according to an intention of those of ordinary skill in the art, judicial precedents, or the appearance of new technology. In addition, in specific cases, terms intentionally selected by the applicant may be used, and in this case, the meaning of the terms will be disclosed in corresponding description of the invention. Accordingly, the terms used in the present inventive concept should be defined not by simple names of the terms but by the meaning of the terms and the content over the present inventive concept.
An expression in the singular includes an expression in the plural unless they are clearly different from each other in a context. In the application, it should be understood that terms, such as ‘include’ and ‘have’, are used to indicate the existence of implemented feature, number, step, operation, element, part, or a combination of them without excluding in advance the possibility of existence or addition of one or more other features, numbers, steps, operations, elements, parts, or combinations of them.
Hereinafter, the present inventive concept will be described more fully with reference to the accompanying drawings, in which exemplary embodiments are shown. Like reference numerals in the drawings denote like elements, and thus their repetitive description will be omitted.
As used herein, expressions such as “at least one of,” when preceding a list of elements, modify the entire list of elements and do not modify the individual elements of the list.
The audio encoding apparatus 100 of
Referring to
The bit allocating unit 150 may determine a masking threshold obtained by using spectral energy or a psych-acoustic model with respect to the audio spectrum and the number of bits allocated based on each sub-band by using the spectral energy. Here, a sub-band is a unit of grouping samples of the audio spectrum and may have a uniform or non-uniform length by reflecting a threshold band. When sub-bands have non-uniform lengths, the sub-bands may be determined so that the number of samples from a starting sample to a last sample included in each sub-band gradually increases per frame. Here, the number of sub-bands or the number of samples included in each sub-frame may be previously determined. Alternatively, after one frame is divided into a predetermined number of sub-bands having a uniform length, the uniform length may be adjusted according to a distribution of spectral coefficients. The distribution of spectral coefficients may be determined using a spectral flatness measure, a difference between a maximum value and a minimum value, or a differential value of the maximum value.
According to an exemplary embodiment, the bit allocating unit 150 may estimate an allowable number of bits by using a Norm value obtained based on each sub-band, i.e., average spectral energy, allocate bits based on the average spectral energy, and limit the allocated number of bits not to exceed the allowable number of bits.
According to an exemplary embodiment of, the bit allocating unit 150 may estimate an allowable number of bits by using a psycho-acoustic model based on each sub-band, allocate bits based on average spectral energy, and limit the allocated number of bits not to exceed the allowable number of bits.
The encoding unit 170 may generate information regarding an encoded spectrum by quantizing and lossless encoding the audio spectrum based on the allocated number of bits finally determined based on each sub-band.
The multiplexing unit 190 generates a bitstream by multiplexing the encoded Norm value provided from the bit allocating unit 150 and the information regarding the encoded spectrum provided from the encoding unit 170.
The audio encoding apparatus 100 may generate a noise level for an optional sub-band and provide the noise level to an audio decoding apparatus (700 of
The bit allocating unit 200 of
Referring to
In Equation 1, when P sub-bands or sub-sectors exist in one frame, N(p) denotes a Norm value of a pth sub-band or sub-sector, Lp denotes a length of the pth sub-band or sub-sector, i.e., the number of samples or spectral coefficients, sp and ep denote a starting sample and a last sample of the pth sub-band, respectively, and y(k) denotes a sample size or a spectral coefficient (i.e., energy).
The Norm value obtained based on each sub-band may be provided to the encoding unit (170 of
The Norm encoder 230 may quantize and lossless encode the Norm value obtained based on each sub-band. The Norm value quantized based on each sub-band or the Norm value obtained by dequantizing the quantized Norm value may be provided to the bit estimator and allocator 250. The Norm value quantized and lossless encoded based on each sub-band may be provided to the multiplexing unit (190 of
The bit estimator and allocator 250 may estimate and allocate a required number of bits by using the Norm value. Preferably, the dequantized Norm value may be used so that an encoding part and a decoding part can use the same bit estimation and allocation process. In this case, a Norm value adjusted by taking a masking effect into account may be used. For example, the Norm value may be adjusted using psych-acoustic weighting applied in ITU-T G.719 as in Equation 2 but is not limited thereto.
ĨNq(p)=INq(p)+WSpe(p) (2)
In Equation 2, INq(p) denotes an index of a quantized Norm value of the pth sub-band, ĨNq(p) denotes an index of an adjusted Norm value of the pth sub-band, and WSpe(p) denotes an offset spectrum for the Norm value adjustment.
The bit estimator and allocator 250 may calculate a masking threshold by using the Norm value based on each sub-band and estimate a perceptually required number of bits by using the masking threshold. To do this, the Norm value obtained based on each sub-band may be equally represented as spectral energy in dB units as shown in Equation 3.
As a method of obtaining the masking threshold by using spectral energy, various well-known methods may be used. That is, the masking threshold is a value corresponding to Just Noticeable Distortion (JND), and when a quantization noise is less than the masking threshold, perceptual noise cannot be perceived. Thus, a minimum number of bits required not to perceive perceptual noise may be calculated using the masking threshold. For example, a Signal-to-Mask Ratio (SMR) may be calculated by using a ratio of the Norm value to the masking threshold based on each sub-band, and the number of bits satisfying the masking threshold may be estimated by using a relationship of 6.025 dB≈1 bit with respect to the calculated SMR. Although the estimated number of bits is the minimum number of bits required not to perceive the perceptual noise, since there is no need to use more than the estimated number of bits in terms of compression, the estimated number of bits may be considered as a maximum number of bits allowable based on each sub-band (hereinafter, an allowable number of bits). The allowable number of bits of each sub-band may be represented in decimal point units.
The bit estimator and allocator 250 may perform bit allocation in decimal point units by using the Norm value based on each sub-band. In this case, bits are sequentially allocated from a sub-band having a larger Norm value than the others, and it may be adjusted that more bits are allocated to a perceptually important sub-band by weighting according to perceptual importance of each sub-band with respect to the Norm value based on each sub-band. The perceptual importance may be determined through, for example, psycho-acoustic weighting as in ITU-T G.719.
The bit estimator and allocator 250 may sequentially allocate bits to samples from a sub-band having a larger Norm value than the others. In other words, firstly, bits per sample are allocated for a sub-band having the maximum Norm value, and a priority of the sub-band having the maximum Norm value is changed by decreasing the Norm value of the sub-band by predetermined units so that bits are allocated to another sub-band. This process is repeatedly performed until the total number B of bits allowable in the given frame is clearly allocated.
The bit estimator and allocator 250 may finally determine the allocated number of bits by limiting the allocated number of bits not to exceed the estimated number of bits, i.e., the allowable number of bits, for each sub-band. For all sub-bands, the allocated number of bits is compared with the estimated number of bits, and if the allocated number of bits is greater than the estimated number of bits, the allocated number of bits is limited to the estimated number of bits. If the allocated number of bits of all sub-bands in the given frame, which is obtained as a result of the bit-number limitation, is less than the total number B of bits allowable in the given frame, the number of bits corresponding to the difference may be uniformly distributed to all the sub-bands or non-uniformly distributed according to perceptual importance.
Since the number of bits allocated to each sub-band can be determined in decimal point units and limited to the allowable number of bits, a total number of bits of a given frame may be efficiently distributed.
According to an exemplary embodiment, a detailed method of estimating and allocating the number of bits required for each sub-band is as follows. According to this method, since the number of bits allocated to each sub-band can be determined at once without several repetition times, complexity may be lowered.
For example, a solution, which may optimize quantization distortion and the number of bits allocated to each sub-band, may be obtained by applying a Lagrange's function represented by Equation 4.
L=D+λ(ΣNbLb−B) (4)
In Equation 4, L denotes the Lagrange's function, D denotes quantization distortion, B denotes the total number of bits allowable in the given frame, Nb denotes the number of samples of a b-th sub-band, and Lb denotes the number of bits allocated to the b-th sub-band. That is, NbLb denotes the number of bits allocated to the bth sub-band. Λ denotes the Lagrange multiplier being an optimization coefficient.
By using Equation 4, Lb for minimizing a difference between the total number of bits allocated to sub-bands included in the given frame and the allowable number of bits for the given frame may be determined while considering the quantization distortion.
The quantization distortion D may be defined by Equation 5.
In Equation 5, xi denotes an input spectrum, and {tilde over (x)}i denotes a decoded spectrum. That is, the quantization distortion D may be defined as a Mean Square Error (MSE) with respect to the input spectrum xi and the decoded spectrum {tilde over (x)}i in an arbitrary frame.
The denominator in Equation 5 is a constant value determined by a given input spectrum, and accordingly, since the denominator in Equation 5 does not affect optimization, Equation 7 may be simplified by Equation 6.
A Norm value gb, which is average spectral energy of the bth sub-band with respect to the input spectrum xi, may be defined by Equation 7, a Norm value nb quantized by a log scale may be defined by Equation 8, and a dequantized Norm value {tilde over (g)}b may be defined by Equation 9.
In Equation 7, sb and eb denote a starting sample and a last sample of the bth sub-band, respectively.
A normalized spectrum yi is generated by dividing the input spectrum xi by the dequantized Norm value {tilde over (g)}b as in Equation 10, and a decoded spectrum is generated by multiplying a restored normalized spectrum {tilde over (y)}i by the dequantized Norm value {tilde over (g)}b as in Equation 11.
The quantization distortion term may be arranged by Equation 12 by using Equations 9 to 11.
Commonly, from a relationship between quantization distortion and the allocated number of bits, it is defined that a Signal-to-Noise Ratio (SNR) increases by 6.02 dB every time 1 bit per sample is added, and by using this, quantization distortion of the normalized spectrum may be defined by Equation 13.
In a case of actual audio coding, Equation 14 may be defined by applying a dB scale value C, which may vary according to signal characteristics, without fixing the relationship of 1 bit/sample≈6.025 dB.
In Equation 14, when C is 2, 1 bit/sample corresponds to 6.02 dB, and when C is 3, 1 bit/sample corresponds to 9.03 dB.
Thus, Equation 6 may be represented by Equation 15 from Equations 12 and 14.
To obtain optimal Lb and λ from Equation 15, a partial differential is performed for Lb and λ as in Equation 16.
When Equation 16 is arranged, Lb may be represented by Equation 17.
By using Equation 17, the allocated number of bits Lb per sample of each sub-band, which may maximize the SNR of the input spectrum, may be estimated in a range of the total number B of bits allowable in the given frame.
The allocated number of bits based on each sub-band, which is determined by the bit estimator and allocator 250 may be provided to the encoding unit (170 of
The bit allocating unit 300 of
Referring to
The bit estimator and allocator 330 may estimate a perceptually required number of bits by using a masking threshold based on each sub-band. That is, an SMR may be calculated based on each sub-band, and the number of bits satisfying the masking threshold may be estimated by using a relationship of 6.025 dB≈1 bit with respect to the calculated SMR. Although the estimated number of bits is the minimum number of bits required not to perceive the perceptual noise, since there is no need to use more than the estimated number of bits in terms of compression, the estimated number of bits may be considered as a maximum number of bits allowable based on each sub-band (hereinafter, an allowable number of bits). The allowable number of bits of each sub-band may be represented in decimal point units.
The bit estimator and allocator 330 may perform bit allocation in decimal point units by using spectral energy based on each sub-band. In this case, for example, the bit allocating method using Equations 7 to 20 may be used.
The bit estimator and allocator 330 compares the allocated number of bits with the estimated number of bits for all sub-bands, if the allocated number of bits is greater than the estimated number of bits, the allocated number of bits is limited to the estimated number of bits. If the allocated number of bits of all sub-bands in a given frame, which is obtained as a result of the bit-number limitation, is less than the total number B of bits allowable in the given frame, the number of bits corresponding to the difference may be uniformly distributed to all the sub-bands or non-uniformly distributed according to perceptual importance.
The scale factor estimator 350 may estimate a scale factor by using the allocated number of bits finally determined based on each sub-band. The scale factor estimated based on each sub-band may be provided to the encoding unit (170 of
The scale factor encoder 370 may quantize and lossless encode the scale factor estimated based on each sub-band. The scale factor encoded based on each sub-band may be provided to the multiplexing unit (190 of
The bit allocating unit 400 of
Referring to
The bit estimator and allocator 430 may obtain a masking threshold by using spectral energy based on each sub-band and estimate the perceptually required number of bits, i.e., the allowable number of bits, by using the masking threshold.
The bit estimator and allocator 430 may perform bit allocation in decimal point units by using spectral energy based on each sub-band. In this case, for example, the bit allocating method using Equations 7 to 20 may be used.
The bit estimator and allocator 430 compares the allocated number of bits with the estimated number of bits for all sub-bands, if the allocated number of bits is greater than the estimated number of bits, the allocated number of bits is limited to the estimated number of bits. If the allocated number of bits of all sub-bands in a given frame, which is obtained as a result of the bit-number limitation, is less than the total number B of bits allowable in the given frame, the number of bits corresponding to the difference may be uniformly distributed to all the sub-bands or non-uniformly distributed according to perceptual importance.
The scale factor estimator 450 may estimate a scale factor by using the allocated number of bits finally determined based on each sub-band. The scale factor estimated based on each sub-band may be provided to the encoding unit (170 of
The scale factor encoder 470 may quantize and lossless encode the scale factor estimated based on each sub-band. The scale factor encoded based on each sub-band may be provided to the multiplexing unit (190 of
The encoding unit 500 of
Referring to
The spectrum encoder 530 may quantize the normalized spectrum by using the allocated number of bits of each sub-band and lossless encode the quantization result. For example, factorial pulse coding may be used for the spectrum encoding but is not limited thereto. According to the factorial pulse coding, information, such as a pulse position, a pulse magnitude, and a pulse sign, may be represented in a factorial form within a range of the allocated number of bits.
The information regarding the spectrum encoded by the spectrum encoder 530 may be provided to the multiplexing unit (190 of
The audio encoding apparatus 600 of
Referring to
The transform unit 630 may determine a window size used for transform according to the transient interval detection result and perform time-domain to frequency-domain transform based on the determined window size. For example, a short window may be applied to a sub-band from which a transient interval is detected, and a long window may be applied to a sub-band from which a transient interval is not detected.
The bit allocating unit 650 may be implemented by one of the bit allocating units 200, 300, and 400 of
The encoding unit 670 may determine a window size used for encoding according to the transient interval detection result.
The audio encoding apparatus 600 may generate a noise level for an optional sub-band and provide the noise level to an audio decoding apparatus (700 of
The audio decoding apparatus 700 of
Referring to
The bit allocating unit 730 may obtain a dequantized Norm value from the quantized and lossless-encoded Norm value based on each sub-band and determine the allocated number of bits by using the dequantized Norm value. The bit allocating unit 730 may operate substantially the same as the bit allocating unit 150 or 650 of the audio encoding apparatus 100 or 600. When the Norm value is adjusted by the psycho-acoustic weighting in the audio encoding apparatus 100 or 600, the dequantized Norm value may be adjusted by the audio decoding apparatus 700 in the same manner.
The decoding unit 750 may lossless decode and dequantize the encoded spectrum by using the information regarding the encoded spectrum provided from the demultiplexing unit 710. For example, pulse decoding may be used for the spectrum decoding.
The inverse transform unit 770 may generate a restored audio signal by transforming the decoded spectrum to the time domain.
The bit allocating unit 800 of
Referring to
The bit estimator and allocator 830 may determine the allocated number of bits by using the dequantized Norm value. In detail, the bit estimator and allocator 830 may obtain a masking threshold by using spectral energy, i.e., the Norm value, based on each sub-band and estimate the perceptually required number of bits, i.e., the allowable number of bits, by using the masking threshold.
The bit estimator and allocator 830 may perform bit allocation in decimal point units by using the spectral energy, i.e., the Norm value, based on each sub-band. In this case, for example, the bit allocating method using Equations 7 to 20 may be used.
The bit estimator and allocator 830 compares the allocated number of bits with the estimated number of bits for all sub-bands, if the allocated number of bits is greater than the estimated number of bits, the allocated number of bits is limited to the estimated number of bits. If the allocated number of bits of all sub-bands in a given frame, which is obtained as a result of the bit-number limitation, is less than the total number B of bits allowable in the given frame, the number of bits corresponding to the difference may be uniformly distributed to all the sub-bands or non-uniformly distributed according to perceptual importance.
The decoding unit 900 of
Referring to
The envelope shaping unit 930 may restore a spectrum before the normalization by performing envelope shaping on the normalized spectrum provided from the spectrum decoder 910 by using the dequantized Norm value provided from the bit allocating unit (730 of
The decoding unit 1000 of
Referring to
The envelope shaping unit 1030 may restore a spectrum before the normalization by performing envelope shaping on the normalized spectrum provided from the spectrum decoder 1010 by using the dequantized Norm value provided from the bit allocating unit (730 of
When a sub-band, including a part dequantized to 0, exists in the spectrum provided from the envelope shaping unit 1030, the spectrum filling unit 1050 may fill a noise component in the part dequantized to 0 in the sub-band. According to an exemplary embodiment, the noise component may be randomly generated or generated by copying a spectrum of a sub-band dequantized to a value not 0, which is adjacent to the sub-band including the part dequantized to 0, or a spectrum of a sub-band dequantized to a value not 0. According to another exemplary embodiment, energy of the noise component may be adjusted by generating a noise component for the sub-band including the part dequantized to 0 and using a ratio of energy of the noise component to the dequantized Norm value provided from the bit allocating unit (730 of
The decoding unit 1100 of
Referring to
The envelope shaping unit 1150 may restore a spectrum before the normalization for the spectrum including the sub-band in which the noise component is filled by using the dequantized Norm value provided from the bit allocating unit (730 of
The audio decoding apparatus 1200 of
Referring to
The scale factor decoder 1230 may lossless decode and dequantize the quantized and lossless-encoded scale factor based on each sub-band.
The spectrum decoder 1250 may lossless decode and dequantize the encoded spectrum by using the information regarding the encoded spectrum and the dequantized scale factor provided from the demultiplexing unit 1210. The spectrum decoding unit 1250 may include the same components as the decoding unit 1000 of
The inverse transform unit 1270 may generate a restored audio signal by transforming the spectrum decoded by the spectrum decoder 1250 to the time domain.
The audio decoding apparatus 1300 of
Since there is a difference in that transient signaling information is provided to the decoding unit 1350 and the inverse transform unit 1370 when the audio decoding apparatus 1300 of
Referring to
The inverse transform unit 1370 may generate a restored audio signal by transforming the decoded spectrum to the time domain. In this case, a window size may vary according to the transient signaling information.
Referring to
In operation 1420, a masking threshold is acquired by using the spectral energy based on each sub-band.
In operation 1430, the allowable number of bits is estimated in decimal point units by using the masking threshold based on each sub-band.
In operation 1440, bits are allocated in decimal point units based on the spectral energy based on each sub-band.
In operation 1450, the allowable number of bits is compared with the allocated number of bits based on each sub-band.
In operation 1460, if the allocated number of bits is greater than the allowable number of bits for a given sub-band as a result of the comparison in operation 1450, the allocated number of bits is limited to the allowable number of bits.
In operation 1470, if the allocated number of bits is less than or equal to the allowable number of bits for a given sub-band as a result of the comparison in operation 1450, the allocated number of bits is used as it is, or the final allocated number of bits is determined for each sub-band by using the allowable number of bits limited in operation 1460.
Although not shown, if a sum of the allocated numbers of bits determined in operation 1470 for all sub-bands in a given frame is less or more than the total number of bits allowable in the given frame, the number of bits corresponding to the difference may be uniformly distributed to all the sub-bands or non-uniformly distributed according to perceptual importance.
Referring to
In operation 1510, a masking threshold is acquired by using the dequantized Norm value based on each sub-band.
In operation 1520, an SMR is acquired by using the masking threshold based on each sub-band.
In operation 1530, the allowable number of bits is estimated in decimal point units by using the SMR based on each sub-band.
In operation 1540, bits are allocated in decimal point units based on the spectral energy (or the dequantized Norm value) based on each sub-band.
In operation 1550, the allowable number of bits is compared with the allocated number of bits based on each sub-band.
In operation 1560, if the allocated number of bits is greater than the allowable number of bits for a given sub-band as a result of the comparison in operation 1550, the allocated number of bits is limited to the allowable number of bits.
In operation 1570, if the allocated number of bits is less than or equal to the allowable number of bits for a given sub-band as a result of the comparison in operation 1550, the allocated number of bits is used as it is, or the final allocated number of bits is determined for each sub-band by using the allowable number of bits limited in operation 1560.
Although not shown, if a sum of the allocated numbers of bits determined in operation 1570 for all sub-bands in a given frame is less or more than the total number of bits allowable in the given frame, the number of bits corresponding to the difference may be uniformly distributed to all the sub-bands or non-uniformly distributed according to perceptual importance.
Referring to
for all sub-bands.
In operation 1620, the allocated number of bits for each sub-band is estimated in decimal point units by using Equation 17. The allocated number of bits for each sub-band may be obtained by multiplying the allocated number Lb of bits per sample by the number of samples per sub-band. When the allocated number Lb of bits per sample of each sub-band is calculated by using Equation 17, Lb may have a value less than 0. In this case, 0 is allocated to Lb having a value less than 0 as in Equation 18.
As a result, a sum of the allocated numbers of bits estimated for all sub-bands included in a given frame may be greater than the number B of bits allowable in the given frame.
In operation 1630, the sum of the allocated numbers of bits estimated for all sub-bands included in the given frame is compared with the number B of bits allowable in the given frame.
In operation 1640, bits are redistributed for each sub-band by using Equation 19 until the sum of the allocated numbers of bits estimated for all sub-bands included in the given frame is the same as the number B of bits allowable in the given frame.
In Equation 19, Lbk-1 denotes the number of bits determined by a (k−1)th repetition, and Lbk denotes the number of bits determined by a kth repetition. The number of bits determined by every repetition must not be less than 0, and accordingly, operation 1640 is performed for sub-bands having the number of bits greater than 0.
In operation 1650, if the sum of the allocated numbers of bits estimated for all sub-bands included in the given frame is the same as the number B of bits allowable in the given frame as a result of the comparison in operation 1630, the allocated number of bits of each sub-band is used as it is, or the final allocated number of bits is determined for each sub-band by using the allocated number of bits of each sub-band, which is obtained as a result of the redistribution in operation 1640.
Referring to
In operation 1730, the minimum number of bits required for each sub-band is defined in terms of SNR, and the allocated number of bits in operation 1720 greater than 0 and less than the minimum number of bits is adjusted by limiting the allocated number of bits to the minimum number of bits. As such, by limiting the allocated number of bits of each sub-band to the minimum number of bits, the possibility of decreasing sound quality may be reduced. For example, the minimum number of bits required for each sub-band is defined as the minimum number of bits required for pulse coding in factorial pulse coding. The factorial pulse coding represents a signal by using all combinations of a pulse position not 0, a pulse magnitude, and a pulse sign. In this case, an occasional number N of all combinations, which can represent a pulse, may be represented by Equation 20.
In Equation 20, 2i denotes an occasional number of signs representable with +/− for signals at i non-zero positions.
In Equation 20, F(n, i) may be defined by Equation 21, which indicates an occasional number for selecting the i non-zero positions for given n samples, i.e., positions.
In Equation 20, D(m, i) may be represented by Equation 22, which indicates an occasional number for representing the signals selected at the i non-zero positions by m magnitudes.
The number M of bits required to represent the N combinations may be represented by Equation 23.
M=┌log2N┐ (23)
As a result, the minimum number Lb_min of bits required to encode a minimum of 1 pulse for Nb samples in a given bth sub-band may be represented by Equation 24.
Lb_min=1+log2Nb (24)
In this case, the number of bits used to transmit a gain value required for quantization may be added to the minimum number of bits required in the factorial pulse coding and may vary according to a bit rate. The minimum number of bits required based on each sub-band may be determined by a larger value from among the minimum number of bits required in the factorial pulse coding and the number Nb of samples of a given sub-band as in Equation 25. For example, the minimum number of bits required based on each sub-band may be set as 1 bit per sample.
Lb_min=max(Nb,1+log2Nb+Lgain) (25)
When bits to be used are not sufficient in operation 1730 since a target bit rate is small, for a sub-band for which the allocated number of bits is greater than 0 and less than the minimum number of bits, the allocated number of bits is withdrawn and adjusted to 0. In addition, for a sub-band for which the allocated number of bits is smaller than those of equation 24, the allocated number of bits may be withdrawn, and for a sub-band for which the allocated number of bits is greater than those of equation 24 and smaller than the minimum number of bits of equation 25, the minimum number of bits may be allocated.
In operation 1740, a sum of the allocated numbers of bits estimated for all sub-bands in a given frame is compared with the number of bits allowable in the given frame.
In operation 1750, bits are redistributed for a sub-band to which more than the minimum number of bits is allocated until the sum of the allocated numbers of bits estimated for all sub-bands in the given frame is the same as the number of bits allowable in the given frame.
In operation 1760, it is determined whether the allocated number of bits of each sub-band is changed between a previous repetition and a current repetition for the bit redistribution. If the allocated number of bits of each sub-band is not changed between the previous repetition and the current repetition for the bit redistribution, or until the sum of the allocated numbers of bits estimated for all sub-bands in the given frame is the same as the number of bits allowable in the given frame, operations 1740 to 1760 are performed.
In operation 1770, if the allocated number of bits of each sub-band is not changed between the previous repetition and the current repetition for the bit redistribution as a result of the determination in operation 1760, bits are sequentially withdrawn from the top sub-band to the bottom sub-band, and operations 1740 to 1760 are performed until the number of bits allowable in the given frame is satisfied.
That is, for a sub-band for which the allocated number of bits is greater than the minimum number of bits of equation 25, an adjusting operation is performed while reducing the allocated number of bits, until the number of bits allowable in the given frame is satisfied. In addition, if the allocated number of bits is equal to or smaller than the minimum number of bits of equation 25 for all sub-bands and the sum of the allocated number of bits is greater than the number of bits allowable in the given frame, the allocated number of bits may be withdrawn from a high frequency band to a low frequency band.
According to the bit allocating methods of
The methods of
Referring to
The communication unit 1810 may receive at least one of an audio signal or an encoded bitstream provided from the outside or transmit at least one of a restored audio signal or an encoded bitstream obtained as a result of encoding by the encoding module 1830.
The communication unit 1810 is configured to transmit and receive data to and from an external multimedia device through a wireless network, such as wireless Internet, wireless intranet, a wireless telephone network, a wireless Local Area Network (LAN), Wi-Fi, Wi-Fi Direct (WFD), third generation (3G), fourth generation (4G), Bluetooth, Infrared Data Association (IrDA), Radio Frequency Identification (RFID), Ultra WideBand (UWB), Zigbee, or Near Field Communication (NFC), or a wired network, such as a wired telephone network or wired Internet.
According to an exemplary embodiment, the encoding module 1830 may generate a bitstream by transforming an audio signal in the time domain, which is provided through the communication unit 1810 or the microphone 1870, to an audio spectrum in the frequency domain, determining the allocated number of bits in decimal point units based on frequency bands so that an SNR of a spectrum existing in a predetermined frequency band is maximized within a range of the number of bits allowable in a given frame of the audio spectrum, adjusting the allocated number of bits determined based on frequency bands, and encoding the audio spectrum by using the number of bits adjusted based on frequency bands and spectral energy.
According to another exemplary embodiment, the encoding module 1830 may generate a bitstream by transforming an audio signal in the time domain, which is provided through the communication unit 1810 or the microphone 1870, to an audio spectrum in the frequency domain, estimating the allowable number of bits in decimal point units by using a masking threshold based on frequency bands included in a given frame of the audio spectrum, estimating the allocated number of bits in decimal point units by using spectral energy, adjusting the allocated number of bits not to exceed the allowable number of bits, and encoding the audio spectrum by using the number of bits adjusted based on frequency bands and the spectral energy.
The storage unit 1850 may store the encoded bitstream generated by the encoding module 1830. In addition, the storage unit 1850 may store various programs required to operate the multimedia device 1800.
The microphone 1870 may provide an audio signal from a user or the outside to the encoding module 1830.
The multimedia device 1900 of
Referring to
According to an exemplary embodiment, the decoding module 1930 may generate a restored audio signal by receiving a bitstream provided through the communication unit 1910, determining the allocated number of bits in decimal point units based on frequency bands so that an SNR of a spectrum existing in a each frequency band is maximized within a range of the allowable number of bits in a given frame, adjusting the allocated number of bits determined based on frequency bands, decoding an audio spectrum included in the bitstream by using the number of bits adjusted based on frequency bands and spectral energy, and transforming the decoded audio spectrum to an audio signal in the time domain.
According to another exemplary embodiment, the decoding module 1930 may generate a bitstream by receiving a bitstream provided through the communication unit 1910, estimating the allowable number of bits in decimal point units by using a masking threshold based on frequency bands included in a given frame, estimating the allocated number of bits in decimal point units by using spectral energy, adjusting the allocated number of bits not to exceed the allowable number of bits, decoding an audio spectrum included in the bitstream by using the number of bits adjusted based on frequency bands and the spectral energy, and transforming the decoded audio spectrum to an audio signal in the time domain.
The storage unit 1950 may store the restored audio signal generated by the decoding module 1930. In addition, the storage unit 1950 may store various programs required to operate the multimedia device 1900.
The speaker 1970 may output the restored audio signal generated by the decoding module 1930 to the outside.
The multimedia device 2000 shown in
Since the components of the multimedia device 2000 shown in
Each of the multimedia devices 1800, 1900, and 2000 shown in
When the multimedia device 1800, 1900, or 2000 is, for example, a mobile phone, although not shown, the multimedia device 1800, 1900, or 2000 may further include a user input unit, such as a keypad, a display unit for displaying information processed by a user interface or the mobile phone, and a processor for controlling the functions of the mobile phone. In addition, the mobile phone may further include a camera unit having an image pickup function and at least one component for performing a function required for the mobile phone.
When the multimedia device 1800, 1900, or 2000 is, for example, a TV, although not shown, the multimedia device 1800, 1900, or 2000 may further include a user input unit, such as a keypad, a display unit for displaying received broadcasting information, and a processor for controlling all functions of the TV. In addition, the TV may further include at least one component for performing a function of the TV.
The methods according to the exemplary embodiments can be written as computer programs and can be implemented in general-use digital computers that execute the programs using a computer-readable recording medium. In addition, data structures, program commands, or data files usable in the exemplary embodiments may be recorded in a computer-readable recording medium in various manners. The computer-readable recording medium is any data storage device that can store data which can be thereafter read by a computer system. Examples of the computer-readable recording medium include magnetic media, such as hard disks, floppy disks, and magnetic tapes, optical media, such as CD-ROMs and DVDs, and magneto-optical media, such as floptical disks, and hardware devices, such as ROMs, RAMs, and flash memories, particularly configured to store and execute program commands. In addition, the computer-readable recording medium may be a transmission medium for transmitting a signal in which a program command and a data structure are designated. The program commands may include machine language codes edited by a compiler and high-level language codes executable by a computer using an interpreter.
While the present inventive concept has been particularly shown and described with reference to exemplary embodiments thereof, it will be understood by those of ordinary skill in the art that various changes in form and details may be made therein without departing from the spirit and scope of the present inventive concept as defined by the following claims.
This application is a continuation of U.S. application Ser. No. 13/471,046, filed on May 14, 2012, which is set to issue as U.S. Pat. No. 9,159,331 on Oct. 13, 2015, which claims the benefits of U.S. Provisional Application No. 61/485,741, filed on May 13, 2011, and U.S. Provisional Application No. 61/495,014, filed on Jun. 9, 2011, in the U.S. Patent Trademark Office, the disclosures of which are incorporated by reference herein in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
5079547 | Fuchigama et al. | Jan 1992 | A |
5214741 | Akamine et al. | May 1993 | A |
5471558 | Tsutsui | Nov 1995 | A |
5583967 | Akagiri | Dec 1996 | A |
5627938 | Johnston | May 1997 | A |
5721806 | Lee | Feb 1998 | A |
5864802 | Kim et al. | Jan 1999 | A |
5893065 | Fukuchi | Apr 1999 | A |
5930750 | Tsutsui | Jul 1999 | A |
5956674 | Smyth et al. | Sep 1999 | A |
6098039 | Nishida | Aug 2000 | A |
6138101 | Fujii | Oct 2000 | A |
6308150 | Neo et al. | Oct 2001 | B1 |
6792402 | Chen | Sep 2004 | B1 |
7272566 | Vinton | Sep 2007 | B2 |
7873510 | Kurniawati et al. | Jan 2011 | B2 |
7933769 | Bessette | Apr 2011 | B2 |
7979721 | Westerinen et al. | Jul 2011 | B2 |
8731949 | Jiang et al. | May 2014 | B2 |
9165567 | Visser et al. | Oct 2015 | B2 |
20010018650 | DeJaco | Aug 2001 | A1 |
20010053973 | Tsuzuki | Dec 2001 | A1 |
20020004718 | Hasegawa et al. | Jan 2002 | A1 |
20030233234 | Truman et al. | Dec 2003 | A1 |
20060069555 | Konda et al. | Mar 2006 | A1 |
20070016414 | Mehrotra et al. | Jan 2007 | A1 |
20070185711 | Jang et al. | Aug 2007 | A1 |
20070225971 | Bessette | Sep 2007 | A1 |
20070244699 | Mogi et al. | Oct 2007 | A1 |
20070282603 | Bessette | Dec 2007 | A1 |
20100114585 | Yoon et al. | May 2010 | A1 |
20100198587 | Ramabadran et al. | Aug 2010 | A1 |
20100241437 | Taleb et al. | Sep 2010 | A1 |
20100286990 | Biswas et al. | Nov 2010 | A1 |
20100286991 | Hedelin et al. | Nov 2010 | A1 |
20110035212 | Briand et al. | Feb 2011 | A1 |
20110264447 | Visser et al. | Oct 2011 | A1 |
20120288117 | Kim et al. | Nov 2012 | A1 |
20120323582 | Peng et al. | Dec 2012 | A1 |
20120328122 | Oh et al. | Dec 2012 | A1 |
20130289981 | Ragot et al. | Oct 2013 | A1 |
20130346087 | Grancharov et al. | Dec 2013 | A1 |
Number | Date | Country |
---|---|---|
101208489 | Jun 2008 | CN |
101239368 | Aug 2008 | CN |
101957398 | Jan 2011 | CN |
102884575 | Jan 2013 | CN |
3181232 | Aug 1991 | JP |
4168500 | Jun 1992 | JP |
05-91061 | Apr 1993 | JP |
05-114863 | May 1993 | JP |
9214355 | Aug 1997 | JP |
2000148191 | May 2000 | JP |
2000293199 | Oct 2000 | JP |
2005265865 | Sep 2005 | JP |
200926147 | Jun 2009 | TW |
200935402 | Aug 2009 | TW |
201013640 | Apr 2010 | TW |
Entry |
---|
Jin Wang; Ning Ning; Ji, Xuan; Jingming Kuang, “Perceptual Norm Adjustment with Segmental Weighted Smr for ITU-T G. 719 Audio Codec,” Multimedia and Signal Processing (CMSP), 2011 International Conference on, vol. 2, no., pp. 282,285, May 14-15, 2011. |
Minjie Xie; Chu, P.; Taleb, A; Briand, M., “ITU-T G. 719: A New low-complexity full-band (20kHZ) audio coding standard for high-quality conversational applications,” Applications of Signal Processing to Audio and Acoustics, 2009. WASPAA'09. IEEE Workshop on, vol., no., pp. 265,268, Oct. 18-21, 2009. |
Written Opinion (PCT/ISA/237) dated Nov. 30, 2012 in counterpart application No. PCT/KR2012003776. |
Written Opinion (PCT/ISA/237) dated Nov. 30, 2012 in counterpart application No. PCT/KR/2012/003777. |
Voran, Stephen, “Perception-Based Bit-Allocation Algorithms for Audio Coding”, Applications of Signal Processing to Audio and Acoustics, Oct. 19, 1997, IEEE ASSP Workshop on New Paltz, NY, 4 pages. |
ITU-T G.719, “Series G: Transmission Systems and Media. Digital Systems and Networks—Digital terminal equipments—Coding of analogue signals—Low-complexity, full band audio coding for high-quality, conversational applications,” Jun. 2008. |
International Search Report (PCT/ISA/220 & PCT/ISA/210) dated Nov. 30, 2012 in counterpart application No. PCT/KR2012003776. |
International Search Report (PCT/ISA/220 & PCT/ISA/210) dated Nov. 30, 2012 in counterpart application No. PCT/KR/2012/003777. |
Communication, Issued by the European Patent Office, Dated Oct. 30, 2014, in counterpart European Application No. 12785222.6. |
“Low-complexity, full-band audio coding for high-quality, conversational applications,” Series G: Transmission Systems and Media, Digital Systems and Networks, Digital terminal equipments—Coding of analogue signals, ITU-T, G.719, Jun. 2008, 58 pages. |
Communication dated Jan. 18, 2016 issued by the Taiwanese Patent Office in counterpart Taiwanese Patent Application No. 101117138 English Translation. |
Communication dated Jan. 27, 2016 issued by the Taiwanese Patent Office in counterpart Taiwanese Patent Application No. 101117139 English Translation. |
Communication dated Mar. 8, 2016 issued by by the Chinese Patent Office in counterpart Chinese Patent Application No. 201280034734.0 English Translation. |
Communication dated Jun. 28, 2016, issued by the Japanese Patent Office in counterpart Japanese Application No. 2014-511291. |
Number | Date | Country | |
---|---|---|---|
20160035354 A1 | Feb 2016 | US |
Number | Date | Country | |
---|---|---|---|
61495014 | Jun 2011 | US | |
61485741 | May 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13471046 | May 2012 | US |
Child | 14879739 | US |