DESCRIPTION OF PREFERRED EMBODIMENTSThe below-described embodiments are merely illustrative and may provide a lower complexity of a QMF transposer by efficient time and frequency domain operations, and improved audio quality of both QMF and DFT based harmonic SBR by spectral alignment. It is understood that modifications and variations of the arrangements and the details described herein will be apparent to others skilled in the art. It is the intent, therefore, to be limited only by the scope of the impending patent claims and not by the specific details presented by way of description and explanation of the embodiments herein.
Fig. 23 illustrates a preferred implementation of the apparatus for processing an input audio signal, where the input audio signal can be a time domain input signal on line 2300 output by, for example, a core audio decoder 2301. The input audio signal is input into a first analysis filterbank 2302 which is, for example, an analysis filterbank having M channels. Particularly, the analysis filterbank 2302 therefore outputs M subband signals 2303, which have a sampling rate fS = fS/M. This means that the analysis filterbank is a critically sampled analysis filterbank. This means that the analysis filterbank 2302 provides, for each block of M input samples on line 2300 a single sample for each subband channel. Preferably, the analysis filterbank 2302 is a complex modulated filterbank which means that each subband sample has a magnitude and a phase or equivalently a real part and an imaginary part. Hence, the input audio signal on line 2300 is represented by a plurality of first subband signals 2303 which are generated by the analysis filterbank 2302.
A subset of all first subband signals is input into a synthesis filterbank 2304. The synthesis filterbank 2304 has Ms channels, where Ms is smaller than M. Hence, not all the subband signals generated by filterbank 2302 are input into synthesis filterbank 2304, but only a subset, i.e. a certain smaller amount of channels as indicated by 2305. In theFig. 23 embodiment, the subset 2305 covers a certain intermediate bandwidth, but alternatively, the subset can also cover a bandwidth starting with filterbank channel 1 of the filterbank 2302 until a channel having a channel number smaller than M, or alternatively the subset 2305 can also cover a group of subband signals aligned with the highest channel M and extended to a lower channel having a channel number higher than channel number 1. Alternatively, the channel indexing can be started with zero depending on the actually used notation. Preferably, however, for bandwidth extension operations a certain intermediate bandwidth represented by the group of subband signals indicated at 2305 is input into the synthesis filterbank 2304.
The other channels not belonging to the group 2305 are not input into the synthesis filterbank 2304. The synthesis filterbank 2304 generates an intermediate audio signal 2306, which has a sampling rate equal to fS · MS/M. Since MS is smaller than M, the sampling rate of the   intermediate signal 2306 will be smaller than the sampling rate of the input audio signal on line 2300. Therefore, the intermediate signal 2306 represents a downsampled and demodulated signal corresponding to the bandwidth signal represented by subbands 2305, where the signal is demodulated to the base band, since the lowest channel of group 2305 is input into channel 1 of the Ms synthesis filterbank and the highest channel of block 2305 is input into the highest input of block 2304, apart from some zero padding operations for the lowest or the highest channel in order to avoid aliasing problems at the borders of the subset 2305. The apparatus for processing an input audio signal furthermore comprises a further analysis filterbank 2307 for analyzing the intermediate signal 2306, and the further analysis filterbank has MA channels, where MA is different from Ms and preferably is greater than Ms. When MA is greater than Ms, then the sampling rate of the subband signals output by the further analysis filterbank 2307 and indicated at 2308 will be lower than the sampling rate of a subband signal 2303. However, when MA is lower than MS, then the sampling rate of a subband signal 2308 will be higher than a sampling rate of a subband signal of the plurality of first subband signals 2303.
Therefore, the cascade of filterbanks 2304 and 2307 (and preferably 2302) provides very efficient and high quality upsampling or downsampling operations or generally a very efficient resampling processing tool. The plurality of second subband signals 2308 are preferably further processed in a processor 2309 which performs the processing with the data resampled by the cascade of filterbanks 2304, 2307 (and preferably 2302). Additionally, it is preferred that block 2309 also performs an upsampling operation for bandwidth extension processing operations so that in the end the subbands output by block 2309 are at the same sampling rate as the subbands output by block 2302. Then, in a bandwidth extension processing application, these subbands are input together with additional subbands indicated at 2310, which are preferably the low band subbands as, for example, generated by the analysis filterbank 2302 into a synthesis filterbank 2311, which finally provides a processed time domain signal, for example a bandwidth extended signal having a sampling rate 2fS. This sampling rate output by the block 2311 is in this embodiment 2 times the sampling rate of the signal on line 2300, and this sampling rate output by block 2311 is large enough so that the additional bandwidth generated by the processing in block 2309 can be represented in the processed time domain signal with high audio quality.
Depending on the certain application of the present invention of cascaded filterbanks, the filterbank 2302 can be in a separate device and an apparatus for processing an input audio signal may only comprise the synthesis filterbank 2304 and the further analysis filterbank 2307. Stated differently, the analysis filterbank 2302 can be distributed separately from a   "post"-processor comprising blocks 2304, 2307 and, depending on the implementation, blocks 2309 and 2311, too.
In other embodiments, the application of the present invention implementing cascaded filterbanks can be different in that a certain device comprises the analysis filterbank 2302 and the smaller synthesis filterbank 2304, and the intermediate signal is provided to a different processor distributed by a different distributor or via a different distribution channel. Then, the combination of the analysis filterbank 2302 and the smaller synthesis filterbank 2304 represents a very efficient way of downsampling and at the same time demodulating the bandwidth signal represented by the subset 2305 to the base band. This downsampling and demodulation to the base band has been performed without any loss in audio quality, and particularly without any loss in audio information and therefore is a high quality processing.
The table inFig. 23 illustrates certain exemplary numbers for the different devices. Preferably, the analysis filterbank 2302 has 32 channels, the synthesis filterbank has 12 channels, the further analysis filterbank has 2 times the channels of the synthesis filterbank, such as 24 channels, and the final synthesis filterbank 2311 has 64 channels. Generally stated, the number of channels in the analysis filterbank 2302 is big, the number of channels in the synthesis filterbank 2304 is small, the number of channels in the further analysis filterbank 2307 is medium and the number of channels in the synthesis filterbank 2311 is very large. The sampling rates of the subband signals output by the analysis filterbank 2302 is fs/M. The intermediate signal has a sampling rate fS · MS/M. The subband channels of the further analysis filterbank indicated at 2308 have a sampling rate of fS · MS/(M · MA), and the synthesis filterbank 2311 provides an output signal having a sampling rate of 2fS, when the processing in block 2309 doubles the sampling rate. However, when the processing in block 2309 does not double the sampling rate, then the sampling rate output by the synthesis filterbank will be correspondingly lower. Subsequently, further preferred embodiments related to the present invention are discussed.
Fig. 14 illustrates the principle of subband block based transposition. The input time domain signal is fed to an analysis filterbank 1401 which provides a multitude of complex valued subband signals. These are fed to the subband processing unit 1402. The multitude of complex valued output subbands is fed to the synthesis filterbank 1403, which in turn outputs the modified time domain signal. The subband processing unit 1402 performs nonlinear block based subband processing operations such that the modified time domain signal is a transposed version of the input signal corresponding to a transposition order T > 1. The notion of a block based subband processing is defined by comprising nonlinear operations on   blocks of more than one subband sample at a time, where subsequent blocks are windowed and overlap added to generate the output subband signals.
The filterbanks 1401 and 1403 can be of any complex exponential modulated type such as QMF or a windowed DFT. They can be evenly or oddly stacked in the modulation and can be defined from a wide range of prototype filters or windows. It is important to know the quotient ΔfS / ΔfA of the following two filter bank parameters, measured inphysical units.
- ΔfA the subband frequency spacing of the analysis filterbank 1401;
- ΔfS : the subband frequency spacing of the synthesis filterbank 1403.
For the configuration of the subband processing 1402 it is necessary to find the correspondence between source and target subband indices. It is observed that an input sinusoid of physical frequency Ω will result in a main contribution occurring at input subbands with indexn ≈ Ω/ΔfA . An output sinusoid of the desired transposed physical frequencyT · Ω will result from feeding the synthesis subband with indexm ≈T · Ω/ΔfS. Hence, the appropriate source subband index values of the subband processing for a given target subband indexm must obey
Fig. 15 illustrates an example scenario for the application of subband block based transposition using several orders of transposition in a HFR enhanced audio codec. A transmitted bit-stream is received at the core decoder 1501, which provides a low bandwidth decoded core signal at a sampling frequencyfs. The low frequency is resampled to the output sampling frequency 2fs by means of a complex modulated 32 band QMF analysis bank 1502 followed by a 64 band QMF synthesis bank (Inverse QMF) 1505. The two filterbanks 1502 and 1505 have the same physical resolution parameters ΔfS = ΔfA and the HFR processing unit 1504 simply lets through the unmodified lower subbands corresponding to the low bandwidth core signal. The high frequency content of the output signal is obtained by feeding the higher subbands of the 64 band QMF synthesis bank 1505 with the output bands from the multiple transposer unit 1503, subject to spectral shaping and modification performed by the HFR processing unit 1504. The multiple transposer 1503 takes as input the decoded core signal and outputs a multitude of subband signals which represent the 64 QMF band analysis of a superposition or combination of several transposed signal components. The objective is   that if the HFR processing is bypassed, each component corresponds to an integer physical transposition of the core signal, (T = 2,3,... ).
Fig. 16 illustrates a prior art example scenario for the operation of a multiple order subband block based transposition 1603 applying a separate analysis filter bank per transposition order. Here three transposition orders T = 2,3,4 are to be produced and delivered in the domain of a 64 band QMF operating at output sampling rate2fs . The merge unit 1604 simply selects and combines the relevant subbands from each transposition factor branch into a single multitude of QMF subbands to be fed into the HFR processing unit.
Consider first the caseT = 2. The objective is specifically that the processing chain of a 64 band QMF analysis 1602-2, a subband processing unit 1603-2, and a 64 band QMF synthesis 1505 results in a physical transposition ofT = 2. Identifying these three blocks with 1401, 1402 and 1403 ofFig. 14, one finds that and ΔfS / ΔfA = 2 such that (1) results in the specification for 1603-2 that the correspondence between sourcen and target subbandsm is given byn =m.
For the caseT = 3, the exemplary system includes a sampling rate converter 1601-3 which converts the input sampling rate down by a factor 3/2 fromfs to 2fs/3. The objective is specifically that the processing chain of the 64 band QMF analysis 1602-3, the subband processing unit 1603-3, and a 64 band QMF synthesis 1505 results in a physical transposition ofT = 3. Identifying these three blocks with 1401, 1402 and 1403 ofFig. 14, one finds due to the resampling that ΔfS /ΔfA = 3 such that (1) provides the specification for 1603-3 that the correspondence between sourcen and target subbandsm is again given byn =m.
For the caseT = 4, the exemplary system includes a sampling rate converter 1601-4 which converts the input sampling rate down by a factor two fromfs tofs/2. The objective is specifically that the processing chain of the 64 band QMF analysis 1602-4, the subband processing unit 1603-4, and a 64 band QMF synthesis 1505 results in a physical transposition ofT = 4. Identifying these three blocks with 1401, 1402 and 1403 ofFig. 14, one finds due to the resampling that ΔfS / ΔfA = 4 such that (1) provides the specification for 1603-4 that the correspondence between sourcen and target subbandsm is also given byn =m.
Fig. 17 illustrates an inventive example scenario for the efficient operation of a multiple order subband block based transposition applying a single 64 band QMF analysis filter bank. Indeed, the use of three separate QMF analysis banks and two sampling rate converters inFig. 16 results in a rather high computational complexity, as well as some implementation disadvantages for frame based processing due to the sampling rate conversion 1601-3. The   current embodiments teaches to replace the two branches 1601-3 → 1602-3 → 1603-3 and 1601-4 → 1602-4 → 1603-4 by the subband processing 1703-3 and 1703-4, respectively, whereas the branch 1602-2 → 1603-2 is kept unchanged compared toFig 16. All three orders of transposition will now have to be performed in a filterbank domain with reference toFig. 14, whereΔfS /ΔfA = 2 . For the caseT = 3, the specification for 1703-3 given by (1) is that the correspondence between sourcen and target subbandsm is given byn ≈ 2m/3. For the caseT = 4, the specifications for 1703-4 given by (1) is that the correspondence between sourcen and target subbandsm is given byn ≈ 2m. To further reduce complexity, some transposition orders can be generated by copying already calculated transposition orders or the output of the core decoder.
Fig. 1 illustrates the operation of a subband block based transposer using transposition orders of 2, 3, and 4 in a HFR enhanced decoder framework, such as SBR [ISO/IEC 14496-3:2009, "Information technology - Coding of audio-visual objects - Part 3: Audio]. The bitstream is decoded to the time domain by the core decoder101 and passed to the HFR module103, which generates a high frequency signal from the base band core signal. After generation, the HFR generated signal is dynamically adjusted to match the original signal as close as possible by means of transmitted side information. This adjustment is performed by the HFR processor105 on subband signals, obtained from one or several analysis QMF banks. A typical scenario is where the core decoder operates on a time domain signal sampled at half the frequency of the input and output signals, i.e. the HFR decoder module will effectively resample the core signal to twice the sampling frequency. This sample rate conversion is usually obtained by the first step of filtering the core coder signal by means of a 32-band analysis QMF bank102. The subbands below the so-called crossover frequency, i.e. the lower subset of the 32 subbands that contains the entire core coder signal energy, are combined with the set of subbands that carry the HFR generated signal. Usually, the number of so combined subbands is 64, which, after filtering through the synthesis QMF bank106, results in a sample rate converted core coder signal combined with the output from the HFR module.
In the subband block based transposer of the HFR module103, three transposition ordersT = 2, 3 and 4, are to be produced and delivered in the domain of a 64 band QMF operating at output sampling rate 2fs . The input time domain signal is bandpass filtered in the blocks103-12, 103-13 and103-14. This is done in order to make the output signals, processed by the different transposition orders, to have non-overlapping spectral contents. The signals are further downsampled(103-23, 103-24) to adapt the sampling rate of the input signals to fit analysis filter banks of a constant size (in this case 64). It can be noted that the increase of the sampling rate, fromfs to 2fs, can be explained by the fact that the sampling rate converters   use downsampling factors ofT/2 instead ofT, in which the latter would result in transposed subband signals having equal sampling rate as the input signal. The downsampled signals are fed to separate HFR analysis filter banks(103-32, 103-33 and103-34), one for each transposition order, which provide a multitude of complex valued subband signals. These are fed to the non-linear subband stretching units(103-42, 103-43 and103-44). The multitude of complex valued output subbands are fed to the Merge/Combine module104 together with the output from the subsampled analysis bank102. The Merge/Combine unit simply merges the subbands from the core analysis filter bank102 and each stretching factor branch into a single multitude of QMF subbands to be fed into the HFR processing unit105.
When the signal spectra from different transposition orders are set to not overlap, i.e. the spectrum of theTth transposition order signal should start where the spectrum from theT-1 order signal ends, the transposed signals need to be of bandpass character. Hence the traditional bandpass filters103-12-103-14 inFig. 1. However, through a simple exclusive selection among the available subbands by the Merge/Combine unit104, the separate bandpass filters are redundant and can be avoided. Instead, the inherent bandpass characteristic provided by the QMF bank is exploited by feeding the different contributions from the transposer branches independently to different subband channels in104. It also suffices to apply the time stretching only to bands which are combined in 104.
Fig. 2 illustrates the operation of a nonlinear subband stretching unit. The block extractor201 samples a finite frame of samples from the complex valued input signal. The frame is defined by an input pointer position. This frame undergoes nonlinear processing in202 and is subsequently windowed by a finite length window in203. The resulting samples are added to previously output samples in the overlap and add unit204 where the output frame position is defined by an output pointer position. The input pointer is incremented by a fixed amount and the output pointer is incremented by the subband stretch factor times the same amount. An iteration of this chain of operations will produce an output signal with duration being the subband stretch factor times the input subband signal duration, up to the length of the synthesis window.
While the SSB transposer employed by SBR [ISO/IEC 14496-3:2009, "Information technology - Coding of audio-visual objects - Part 3: Audio] typically exploits the entire base band, excluding the first subband, to generate the high band signal, a harmonic transposer generally uses a smaller part of the core coder spectrum. The amount used, the so-called source range, depends on the transposition order, the bandwidth extension factor, and the rules applied for the combined result, e.g. if the signals generated from different transposition orders are allowed to overlap spectrally or not. As a consequence, just a limited   part of the harmonic transposer output spectrum for a given transposition order will actually be used by the HFR processing module105.
Fig. 18 illustrates another embodiment of an exemplary processing implementation for processing a single subband signal. The single subband signal has been subjected to any kind of decimation either before or after being filtered by an analysis filter bank not shown inFig. 18. Therefore, the time length of the single subband signal is shorter than the time length before forming the decimation. The single subband signal is input into a block extractor 1800, which can be identical to the block extractor 201, but which can also be implemented in a different way. The block extractor 1800 inFig. 18 operates using a sample/block advance value exemplarily called e. The sample/block advance value can be variable or can be fixedly set and is illustrated inFig. 18 as an arrow into block extractor box 1800. At the output of the block extractor 1800, there exists a plurality of extracted blocks. These blocks are highly overlapping, since the sample/block advance value e is significantly smaller than the block length of the block extractor. An example is that the block extractor extracts blocks of 12 samples. The first block comprises samples 0 to 11, the second block comprises samples 1 to 12, the third block comprises samples 2 to 13, and so on. In this embodiment, the sample/block advance value e is equal to 1, and there is a 11-fold overlapping.
The individual blocks are input into a windower 1802 for windowing the blocks using a window function for each block. Additionally, a phase calculator 1804 is provided, which calculates a phase for each block. The phase calculator 1804 can either use the individual block before windowing or subsequent to windowing. Then, a phase adjustment value p × k is calculated and input into a phase adjuster 1806. The phase adjuster applies the adjustment value to each sample in the block. Furthermore, the factor k is equal to the bandwidth extension factor. When, for example, the bandwidth extension by a factor 2 is to be obtained, then the phase p calculated for a block extracted by the block extractor 1800 is multiplied by the factor 2 and the adjustment value applied to each sample of the block in the phase adjustor 1806 is p multiplied by 2. This is an exemplary value/rule. Alternatively, the corrected phase for synthesis is k∗ p, p + (k-1)∗p. So in this example the correction factor is either 2, if multiplied or 1∗p if added. Other values/rules can be applied for calculating the phase correction value.
In an embodiment, the single subband signal is a complex subband signal, and the phase of a block can be calculated by a plurality of different ways. One way is to take the sample in the middle or around the middle of the block and to calculate the phase of this complex sample. It is also possible to calculate the phase for every sample.
Although illustrated inFig. 18 in the way that a phase adjustor operates subsequent to the windower, these two blocks can also be interchanged, so that the phase adjustment is performed to the blocks extracted by the block extractor and a subsequent windowing operation is performed. Since both operations, i.e., windowing and phase adjustment are real-valued or complex-valued multiplications, these two operations can be summarized into a single operation using a complex multiplication factor, which, itself, is the product of a phase adjustment multiplication factor and a windowing factor.
The phase-adjusted blocks are input into an overlap/add and amplitude correction block 1808, where the windowed and phase-adjusted blocks are overlap-added. Importantly, however, the sample/block advance value in block 1808 is different from the value used in the block extractor 1800. Particularly, the sample/block advance value in block 1808 is greater than the value e used in block 1800, so that a time stretching of the signal output by block 1808 is obtained. Thus, the processed subband signal output by block 1808 has a length which is longer than the subband signal input into block 1800. When the bandwidth extension of two is to be obtained, then the sample/block advance value is used, which is two times the corresponding value in block 1800. This results in a time stretching by a factor of two. When, however, other time stretching factors are necessary, then other sample/block advance values can be used so that the output of block 1808 has a required time length.
For addressing the overlap issue, an amplitude correction is preferably performed in order to address the issue of different overlaps in block 1800 and 1808. This amplitude correction could, however, be also introduced into the windower/phase adjustor multiplication factor, but the amplitude correction can also be performed subsequent to the overlap/processing.
In the above example with a block length of 12 and a sample/block advance value in the block extractor of one, the sample/block advance value for the overlap/add block 1808 would be equal to two, when a bandwidth extension by a factor of two is performed. This would still result in an overlap of five blocks. When a bandwidth extension by a factor of three is to be performed, then the sample/block advance value used by block 1808 would be equal to three, and the overlap would drop to an overlap of three. When a four-fold bandwidth extension is to be performed, then the overlap/add block 1808 would have to use a sample/block advance value of four, which would still result in an overlap of more than two blocks.
Large computational savings can be achieved by restricting the input signals to the transposer branches to solely contain the source range, and this at a sampling rate adapted to each transposition order. The basic block scheme of such a system for a subband block based HFR   generator is illustrated inFig. 3. The input core coder signal is processed by dedicated downsamplers preceding the HFR analysis filter banks.
The essential effect of each downsampler is to filter out the source range signal and to deliver that to the analysis filter bank at the lowest possible sampling rate. Here,lowest possible refers to the lowest sampling rate that is still suitable for the downstream processing, not necessarily the lowest sampling rate that avoids aliasing after decimation. The sampling rate conversion may be obtained in various manners. Without limiting the scope of the invention, two examples will be given: the first shows the resampling performed by multi-rate time domain processing, and the second illustrates the resampling achieved by means of QMF subband processing.
Fig. 4 shows an example of the blocks in a multi-rate time domain downsampler for a transposition order of 2. The input signal, having a bandwidthB Hz, and a sampling frequencyfs, is modulated by a complex exponential(401) in order to frequency-shift the start of the source range to DC frequency as
Examples of an input signal and the spectrum after modulation is depicted inFigs. 5(a) and (b). The modulated signal is interpolated(402) and filtered by a complex-valued lowpass filter with passband limits 0 and B/2 Hz(403). The spectra after the respective steps are shown inFigs. 5(c) and (d). The filtered signal is subsequently decimated(404) and the real part of the signal is computed(405). The results after these steps are shown inFigs. 5(e) and (f). In this particular example, whenT=2, B=0.6 (on a normalized scale, i.e.fs=2),P2 is chosen as 24 in order to safely cover the source range. The downsampling factor gets , where the fraction has been reduced by the common factor 8. Hence, the interpolation factor is 3 (as seen fromFig. 5(c)) and the decimation factor is 8. By using the Noble Identities ["Multirate Systems And Filter Banks," P.P. Vaidyanathan, 1993, Prentice Hall, Englewood Cliffs], the decimator can be moved all the way to the left, and the interpolator all the way to the right inFig. 4. In this way, the modulation and filtering are done on the lowest possible sampling rate and computational complexity is further decreased.
In accordance with the invention, the subband outputs from the subsampled 32-band analysis QMF bank102 already present in the SBR HFR method are used. The subbands covering the source ranges for the different transposer branches are synthesized to the time domain by small subsampled QMF banks preceding the HFR analysis filter banks. This type of HFR system is illustrated inFig. 6. The small QMF banks are obtained by subsampling the original   64-band QMF bank, where the prototype filter coefficients are found by linear interpolation of the original prototype filter. Following the notation inFig. 6, the synthesis QMF bank preceding the 2nd order transposer branch hasQ2=12 bands (the subbands with zero-based indices from 8 to 19 in the 32-band QMF). To prevent aliasing in the synthesis process, the first (index 8) and last (index 19) bands are set to zero. The resulting spectral output is shown inFig. 7. Note that the block based transposer analysis filter bank has 2Q2=24 bands, i.e. the same number of bands as in the multi-rate time domain downsampler based example (Fig. 3).
WhenFig. 6 andFig. 23 are compared, it becomes clear that element 601 ofFig. 6 corresponds to the analysis filterbank 2302 ofFig. 23. Furthermore, the synthesis filterbank 2304 ofFig. 23 corresponds to element 602-2, and the further analysis filterbank 2307 ofFig. 23 corresponds to element 603-2. Block 604-2 corresponds to block 2309 and the combiner 605 may correspond to the synthesis filterbank 2311, but in other embodiments, the combiner can be configured to output subband signals and, then, a further synthesis filterbank connected to the combiner can be used. However, depending on the implementation, a certain high frequency reconstruction as discussed in the context ofFig. 26 later on can be performed before synthesis filtering by synthesis filterbank 2311 or combiner 205, or can be performed subsequent to synthesis filtering in synthesis filterbank 2311 ofFig. 23 or subsequent to the combiner in block 605 ofFig. 6.
The other branches extending from 602-3 to 604-3 or extending from 602-T to 604-T are not illustrated inFig. 23, but can be implemented in a similar manner, but with different sizes of filterbanks where T inFig. 6 corresponds to a transposition factor. However, as discussed in the context ofFig. 27, the transposition by a transposition factor of 3 and the transposition by a transposition factor of 4 can be introduced into the processing branch consisting of element 602-2 to 604-2 so that block 604-2 does not only provide a transposition by a factor of 2 but also a transposition by a factor of 3 and a factor of 4, together with a certain synthesis filterbank is used as discussed in the context ofFigs. 26 and27.
In theFig. 6 embodiment, Q2 corresponds to MS and MS is equal to, for example, 12. Furthermore, the size of the further analysis filterbank 603-2 corresponding to element 2307 is equal to 2MS such as 24 in the embodiment.
Furthermore, as outlined before, the lowest subband channel and the highest subband channel of the synthesis filterbank 2304 can be fed with zeroes in order to avoid aliasing problems.
The system outlined inFig. 1 can be viewed as a simplified special case of the resampling outlined inFigs. 3 and 4. In order to simplify the arrangement, the modulators are omitted.   Further, all HFR analysis filtering are obtained using 64-band analysis filter banks. Hence,P2 =P3 =P4 = 64 ofFig. 3, and the downsampling factors are 1, 1.5 and 2 for the 2nd, 3rd and 4th order transposer branches respectively.
It is an advantage of the present invention that in the context of the inventive critical sampling processing, the subband signals from the 32-band analysis QMF bank corresponding to block 2302 ofFig. 23 or 601 ofFig. 6 as defined in MPEG4 (ISO/IEC 14496-3) can be used. The definition of this analysis filterbank in the MPEG-4 Standard is illustrated in the upper portion ofFig. 25a and is illustrated as a flowchart inFig. 25b, which is also taken from the MPEG-4 Standard. The SBR (spectral bandwidth replication) portion of this standard is incorporated herein by reference. Particularly, the analysis filterbank 2302 ofFig. 23 or the 32-band QMF 601 ofFig. 6 can be implemented as illustrated inFig. 25a, upper portion and the flowchart inFig. 25b.
Furthermore, the synthesis filterbank illustrated in block 2311 ofFig. 23 can also be implemented as indicated in the lower portion ofFig. 25a and as illustrated in the flowchart ofFig. 25c. However, any other filterbank definitions can be applied, but at least for the analysis filterbank 2302, the implementation illustrated inFigs. 25a and25b is preferred due to the robustness, stability and high quality provided by this MPEG-4 analysis filterbank having 32 channels at least in the context of bandwidth extension applications such as spectral bandwidth replication, or stated generally, high frequency reconstruction processing applications.
The synthesis filterbank 2304 is configured for synthesizing a subset of the subbands covering the source range for a transposer. This synthesis is done for synthesizing the intermediate signal 2306 in the time domain. Preferably, the synthesis filterbank 2304 is a small sub-sampled real-valued QMF bank.
The time domain output 2306 of this filterbank is then fed to a complex-valued analysis QMF bank of twice the filterbank size. This QMF bank is illustrated by block 2307 ofFig. 23. This procedure enables a substantial saving in computational complexity as only the relevant source range is transformed to the QMF subband domain having doubled frequency resolution. The small QMF banks are obtained by sub-sampling of the original 64-band QMF bank, where the prototype filter coefficients are obtained by linear interpolation of the original prototype filter. Preferably, the prototype filter associated with the MPEG-4 synthesis filterbank having 640 samples is used, where the MPEG-4 analysis filterbank has a window of 320 window samples.
The processing of the sub-sampled filterbanks is described inFigs. 24a and24b, illustrating flowcharts. The following variables are first determined: whereMs is the size of the sub-sampled synthesis filter bank andkL represents the subband index of the first channel from the 32-band QMF bank to enter the sub-sampled synthesis filter bank. The arraystartSubband2kL is listed in Table 1. The function floor{x} rounds the argument x to the nearest integer towards minus infinity.
Hence, the value Ms defines the size of the synthesis filterbank 2304 ofFig. 23 and KL is the first channel of the subset 2305 indicated atFig. 23. Specifically, the value in the equation ftableLow is defined in ISO/IEC 14496-3, section 4.6.18.3.2 which is also incorporated herein by reference. It is to be noted that the value Ms goes in increments of 4, which means that the size of the synthesis filterbank 2304 can be 4, 8, 12, 16, 20, 24, 28, or 32.
Preferably, the synthesis filterbank 2304 is a real-valued synthesis filter bank. To this end, a set of MS real-valued subband samples is calculated from the MS new complex-valued subband samples according to the first step ofFig. 24a. To this end, the following equation is used
In the equation, exp() denotes the complex exponential function,i is the imaginary unit andkL has been defined before.
- Shift the samples in the array v by 2Ms positions. The oldest 2MS samples are discarded.
- The Ms real-valued subband samples are multiplied by the matrix N, i.e. the matrix-vector product N·V is computed, where
The output from this operation is stored in the positions 0 to 2MS-1 of arrayv.
- Extract samples from v according to the flowchart in Fig. 24a to create the 10MS-element array g.
- Multiply the samples of array g by window ci to produce array w. The window coefficients ci are obtained by linear interpolation of the coefficients c, i.e. through the equation
whereµ(n) andp(n) are defined as the integer and fractional parts of 64·n /MS, respectively. The window coefficients ofc can be found in Table 4.A.87 of ISO/IEC 14496-3 :2009.Hence, the synthesis filterbank has a prototype window function calculator for calculating a prototype window function by subsampling or interpolating using a stored window function for a filterbank having a different size.
- Calculate Ms new output samples by summation of samples from array w according to the last step in the flowchart of in Fig. 24a.
Subsequently, the preferred implementation of the further analysis filterbank 2307 inFig. 23 is illustrated together with the flowchart inFig. 24b.
- Shift the samples in the array x by 2Ms positions according to the first step of Fig. 24b. The oldest 2Ms samples are discarded and 2Ms new samples are stored in positions 0 to 2MS-1.
- Multiply the samples of array x by the coefficients of window c2i. The window coefficients c2i are obtained by linear interpolation of the coefficients c, i.e. through the equation
whereµ(n) andp(n) are defined as the integer and fractional parts of 32·n /MS, respectively. The window coefficients of c can be found in Table 4.A.87 of ISO/IEC 14496-3:2009.Hence, the further analysis filterbank 2307 has a prototype window function calculator for calculating a prototype window function by subsampling or interpolating using a stored window function for a filterbank having a different size.
- Sum the samples according to the formula in the flowchart in Fig. 24b to create the 4MS-element array u.
- Calculate 2MS new complex-valued subband samples by the matrix-vector multiplication M·u, where
In the equation, exp() denotes the complex exponential function, andi is the imaginary unit.
A block diagram of a factor 2 downsampler is shown inFig. 8(a). The now real-valued low pass filter can be writtenH(z) =B(z)/A(z), whereB(z) is the non-recursive part (FIR) andA(z) is the recursive part (IIR). However, for an efficient implementation, using the Noble Identities to decrease computational complexity, it is beneficial to design a filter where all poles have multiplicity 2 (double poles) asA(z2). Hence the filter can be factored as shown inFig. 8(b). Using Noble Identity 1, the recursive part may be moved past the decimator as inFig. 8(c). The non-recursive filterB(z) can be implemented using standard 2-component polyphase decomposition as
Hence, the downsampler may be structured as inFig. 8(d). After using Noble Identity 1, the FIR part is computed at the lowest possible sampling rate as shown inFig. 8(e). FromFig. 8(e) it is easy to see that the FIR operation (delay, decimators and polyphase components) can be viewed as a window-add operation using an input stride of two samples. For two input samples, one new output sample will be produced, effectively resulting in a downsampling of a factor 2.
A block diagram of the factor 1.5=3/2 downsampler is shown inFig. 9(a). The real-valued low pass filter can again be writtenH(z) =B(z)/A(z), whereB(z) is the non-recursive part (FIR) andA(z) is the recursive part (IIR). As before, for an efficient implementation, using the Noble Identities to decrease computational complexity, it is beneficial to design a filter where all poles either have multiplicity 2 (double poles) or multiplicity 3 (triple poles) asA(z2) orA(z3) respectively. Here, double poles are chosen as the design algorithm for the low pass filter is more efficient, although the recursive part actually gets 1.5 times more complex to implement compared to the triple pole approach. Hence the filter can be factored as shown inFig. 9(b). Using Noble Identity 2, the recursive part may be moved in front of the interpolator as inFig. 9(c). The non-recursive filterB(z) can be implemented using standard 2·3 = 6 component polyphase decomposition as
Hence, the downsampler may be structured as inFig. 9(d). After using both Noble Identity 1 and 2, the FIR part is computed at the lowest possible sampling rate as shown inFig. 9(e). FromFig. 9(e) it is easy to see that the even-indexed output samples are computed using the lower group of three polyphase filters (E0(z),E2(z),E4(z)) while the odd-indexed samples are computed from the higher group (E1(z),E3(z), E5(z)). The operation of each group (delay chain, decimators and polyphase components) can be viewed as a window-add operation using an input stride of three samples. The window coefficients used in the upper group are the odd indexed coefficients, while the lower group uses the even index coefficients from the original filterB(z). Hence, for a group of three input samples, two new output samples will be produced, effectively resulting in a downsampling of a factor 1.5.
The time domain signal from the core decoder (101 inFig. 1) may also be subsampled by using a smaller subsampled synthesis transform in the core decoder. The use of a smaller synthesis transform offers even further decreased computational complexity. Depending on the cross-over frequency, i.e. the bandwidth of the core coder signal, the ratio of the synthesis transform size and the nominal sizeQ (Q < 1), results in a core coder output signal having a sampling rateQfs. To process the subsampled core coder signal in the examples outlined in the current application, all the analysis filter banks ofFig.1(102, 103-32, 103-33 and103-34) need to scaled by the factor Q, as well as the downsamplers(301-2, 301-3 and301-T) ofFig. 3, the decimator404 ofFig.4, and the analysis filter bank601 ofFig. 6. Apparently,Q has to be chosen so that all filter bank sizes are integers.
Fig. 10 illustrates the alignment of the spectral borders of the HFR transposer signals to the spectral borders of the envelope adjustment frequency table in a HFR enhanced coder, such as SBR [ISO/IEC 14496-3:2009, "Information technology - Coding of audio-visual objects -   Part 3: Audio].Fig. 10(a) shows a stylistic graph of the frequency bands comprising the envelope adjustment table, the so-called scale-factor bands, covering the frequency range from the cross-over frequencykx to the stop frequencyks. The scale-factor bands constitute the frequency grid used in a HFR enhanced coder when adjusting the energy level of the regenerated high-band frequency, i.e. the frequency envelope. In order to adjust the envelope, the signal energy is averaged over a time/frequency block constrained by the scale-factor band borders and selected time borders. If the signals generated by different transposition orders are unaligned to the scale-factor bands, as illustrated inFig. 10(b), artifacts may arise if the spectral energy drastically changes in the vicinity of a transposition band border, since the envelope adjustment process will maintain the spectral structure within one scale-factor band. Hence, the proposed solution is to adapt the frequency borders of the transposed signals to the borders of the scale-factor bands as shown inFig. 10(c). In the figure, the upper border of the signals generated by transposition orders of 2 and 3 (T=2, 3) are lowered a small amount, compared toFig. 10(b), in order to align the frequency borders of the transposition bands to existing scale-factor band borders.
A realistic scenario showing the potential artifacts when using unaligned borders is depicted inFig. 11. Fig. 11(a) again shows the scale-factor band borders.Fig. 11(b) shows the unadjusted HFR generated signals of transposition ordersT=2, 3 and 4 together with the core decoded base band signal.Fig. 11(c) shows the envelope adjusted signal when a flat target envelope is assumed. The blocks with checkered areas represent scale-factor bands with high intra-band energy variations, which may cause anomalies in the output signal.
Fig. 12 illustrates the scenario ofFig. 11, but this time using aligned borders.Fig. 12(a) shows the scale-factor band borders,Fig. 12(b) depicts the unadjusted HFR generated signals of transposition ordersT=2, 3 and 4 together with the core decoded base band signal and, in line withFig.11(c),Fig. 12(c) shows the envelope adjusted signal when a flat target envelope is assumed. As seen from this figure, there are no scale-factor bands with high intra-band energy variations due to misalignment of the transposed signal bands and the scale-factor bands, and hence the potential artifacts are diminished.
Fig. 13 illustrates the adaption of the HFR limiter band borders, as described in e.g. SBR [ISO/IEC 14496-3:2009, "Information technology - Coding of audio-visual objects - Part 3: Audio] to the harmonic patches in a HFR enhanced coder. The limiter operates on frequency bands having a much coarser resolution than the scale-factor bands, but the principle of operation is very much the same. In the limiter, an average gain-value for each of the limiter bands is calculated. The individual gain values, i.e. the envelope gain values calculated for each of the scale-factor bands, are not allowed to exceed the limiter average gain value by   more than a certain multiplicative factor. The objective of the limiter is to suppress large variations of the scale-factor band gains within each of the limiter bands. While the adaption of the transposer generated bands to the scale-factor bands ensures small variations of the intra-band energy within a scale-factor band, the adaption of the limiter band borders to the transposer band borders, handles the larger scale energy differences between the transposer processed bands.Fig. 13(a) shows the frequency limits of the HFR generated signals of transposition orders T=2, 3 and 4. The energy levels of the different transposed signals can be substantially different.Fig. 13(b) shows the frequency bands of the limiter which typically are of constant width on a logarithmic frequency scale. The transposer frequency band borders are added as constant limiter borders and the remaining limiter borders are recalculated to maintain the logarithmic relations as close as possible, as for example illustrated inFig. 13(c). Although some aspects have been described in the context of an apparatus, it is clear that these aspects also represent a description of the corresponding method, where a block or device corresponds to a method step or a feature of a method step. Analogously, aspects described in the context of a method step also represent a description of a corresponding block or item or feature of a corresponding apparatus.
Further examples employ a mixed patching scheme which is shown inFig. 21, where the mixed patching method within a time block is performed. For full coverage of the different regions of the HF spectrum, a BWE comprises several patches. In HBE, the higher patches require high transposition factors within the phase vocoders, which particularly deteriorate the perceptual quality of transients.
Thus examples generate the patches of higher order that occupy the upper spectral regions preferably by computationally efficient SSB copy-up patching and the lower order patches covering the middle spectral regions, for which the preservation of the harmonic structure is desired, preferably by HBE patching. The individual mix of patching methods can be static over time or, preferably, be signaled in the bitstream.
For the copy-up operation, the low frequency information can be used as shown inFig. 21. Alternatively, the data from patches that were generated using HBE methods can be used as illustrated inFig. 21. The latter leads to a less dense tonal structure for higher patches. Besides these two examples, every combination of copy-up and HBE is conceivable.
The advantages of the proposed concepts are
- Improved perceptual quality of transients
- Reduced computational complexity
Fig. 26 illustrates a preferred processing chain for the purpose of bandwidth extension, where different processing operations can be performed within the non-linear subband processing indicated at blocks 1020a, 1020b. The cascade of filterbanks 2302, 2304, 2307 is represented inFig. 26 by block 1010. Furthermore, block 2309 may correspond to elements 1020a, 1020b and the envelope adjuster 1030 can be placed between block 2309 and block 2311 ofFig. 23 or can be placed subsequent to the processing in block 2311. In this implementation, the band-selective processing of the processed time domain signal such as the bandwidth extended signal is performed in the time domain rather than in the subband domain, which exists before the synthesis filterbank 2311.
Fig. 26 illustrates an apparatus for generating a bandwidth extended audio signal from a lowband input signal 1000 in accordance with a further embodiment. The apparatus comprises an analysis filterbank 1010, a subband-wise non-linear subband processor 1020a, 1020b, a subsequently connected envelope adjuster 1030 or, generally stated, a high frequency reconstruction processor operating on high frequency reconstruction parameters as, for example, input at parameter line 1040. The envelope adjuster, or as generally stated, the high frequency reconstruction processor processes individual subband signals for each subband channel and inputs the processed subband signals for each subband channel into a synthesis filterbank 1050. The synthesis filterbank 1050 receives, at its lower channel input signals, a subband representation of the lowband core decoder signal. Depending on the implementation, the lowband can also be derived from the outputs of the analysis filterbank 1010 inFig. 26. The transposed subband signals are fed into higher filterbank channels of the synthesis filterbank for performing high frequency reconstruction.
The filterbank 1050 finally outputs a transposer output signal which comprises bandwidth extensions by transposition factors 2, 3, and 4, and the signal output by block 1050 is no longer bandwidth-limited to the crossover frequency, i.e. to the highest frequency of the core coder signal corresponding to the lowest frequency of the SBR or HFR generated signal components.
In theFig. 26 embodiment, the analysis filterbank performs a two times over sampling and has a certain analysis subband spacing 1060. The synthesis filterbank 1050 has a synthesis subband spacing 1070 which is, in this embodiment, double the size of the analysis subband spacing which results in a transposition contribution as will be discussed later in the context ofFig. 27.
Fig. 27 illustrates a detailed implementation of a preferred embodiment of a non-linear subband processor 1020a inFig. 26. The circuit illustrated inFig. 27 receives as an input a   single subband signal 108, which is processed in three "branches": The upper branch 110a is for a transposition by a transposition factor of 2. The branch in the middle ofFig. 27 indicated at 110b is for a transposition by a transposition factor of 3, and the lower branch inFig. 27 is for a transposition by a transposition factor of 4 and is indicated by reference numeral 110c. However, the actual transposition obtained by each processing element inFig. 27 is only 1 (i.e. no transposition) for branch 110a. The actual transposition obtained by the processing element illustrated inFig. 27 for the medium branch 110b is equal to 1.5 and the actual transposition for the lower branch 110c is equal to 2. This is indicated by the numbers in brackets to the left ofFig. 27, where transposition factors T are indicated. The transpositions of 1.5 and 2 represent a first transposition contribution obtained by having a decimation operations in branches 110b, 110c and a time stretching by the overlap-add processor. The second contribution, i.e. the doubling of the transposition, is obtained by the synthesis filterbank 105, which has a synthesis subband spacing 107 that is two times the analysis filterbank subband spacing. Therefore, since the synthesis filterbank has two times the analysis subband spacing, any decimations functionality does not take place in branch 110a.
Branch 110b, however, has a decimation functionality in order to obtain a transposition by 1.5. Due to the fact that the synthesis filterbank has two times the physical subband spacing of the analysis filterbank, a transposition factor of 3 is obtained as indicated inFig. 27 to the left of the block extractor for the second branch 110b.
Analogously, the third branch has a decimation functionality corresponding to a transposition factor of 2, and the final contribution of the different subband spacing in the analysis filterbank and the synthesis filterbank finally corresponds to a transposition factor of 4 of the third branch 110c.
Particularly, each branch has a block extractor 120a, 120b, 120c and each of these block extractors can be similar to the block extractor 1800 ofFig. 18. Furthermore, each branch has a phase calculator 122a, 122b and 122c, and the phase calculator can be similar to phase calculator 1804 ofFig. 18. Furthermore, each branch has a phase adjuster 124a, 124b, 124c and the phase adjuster can be similar to the phase adjuster 1806 ofFig. 18. Furthermore, each branch has a windower 126a, 126b, 126c, where each of these windowers can be similar to the windower 1802 ofFig. 18. Nevertheless, the windowers 126a, 126b, 126c can also be configured to apply a rectangular window together with some "zero padding". The transpose or patch signals from each branch 110a, 110b, 110c, in the embodiment ofFig. 27, is input into the adder 128, which adds the contribution from each branch to the current subband signal to finally obtain so-called transpose blocks at the output of adder 128. Then, an overlap-add procedure in the overlap-adder 130 is performed, and the overlap-adder 130 can   be similar to the overlap/add block 1808 ofFig. 18. The overlap-adder applies an overlap-add advance value of 2·e, where e is the overlap-advance value or "stride value" of the block extractors 120a, 120b, 120c, and the overlap-adder 130 outputs the transposed signal which is, in the embodiment ofFig. 27, a single subband output for channel k, i.e. for the currently observed subband channel. The processing illustrated inFig. 27 is performed for each analysis subband or for a certain group of analysis subbands and, as illustrated inFig. 26, transposed subband signals are input into the synthesis filterbank 1050 after being processed by block 1030 to finally obtain the transposer output signal illustrated inFig. 26 at the output of block 1050.
In an embodiment, the block extractor 120a of the first transposer branch 110a extracts 10 subband samples and subsequently a conversion of these 10 QMF samples to polar coordinates is performed. This output, generated by the phase adjuster 124a, is then forwarded to the windower 126a, which extends the output by zeroes for the first and the last value of the block, where this operation is equivalent to a (synthesis) windowing with a rectangular window of length 10. The block extractor 120a in branch 110a does not perform a decimation. Therefore, the samples extracted by the block extractor are mapped into an extracted block in the same sample spacing as they were extracted.
However, this is different for branches 110b and 110c. The block extractor 120b preferably extracts a block of 8 subband samples and distributes these 8 subband samples in the extracted block in a different subband sample spacing. The non-integer subband sample entries for the extracted block are obtained by an interpolation, and the thus obtained QMF samples together with the interpolated samples are converted to polar coordinates and are processed by the phase adjuster. Then, again, windowing in the windower 126b is performed in order to extend the block output by the phase adjuster 124b by zeroes for the first two samples and the last two samples, which operation is equivalent to a (synthesis) windowing with a rectangular window of length 8.
The block extractor 120c is configured for extracting a block with a time extent of 6 subband samples and performs a decimation of a decimation factor 2, performs a conversion of the QMF samples into polar coordinates and again performs an operation in the phase adjuster 124b, and the output is again extended by zeroes, however now for the first three subband samples and for the last three subband samples. This operation is equivalent to a (synthesis) windowing with a rectangular window of length 6.
The transposition outputs of each branch are then added to form the combined QMF output by the adder 128, and the combined QMF outputs are finally superimposed using overlap-add in   block 130, where the overlap-add advance or stride value is two times the stride value of the block extractors 120a, 120b, 120c as discussed before.
An example comprises a method for decoding an audio signal by using subband block based harmonic transposition, comprising the filtering of a core decoded signal through an M-band analysis filter bank to obtain a set of subband signals; synthesizing a subset of said subband signals by means of subsampled synthesis filter banks having a decreased number of subbands, to obtain subsampled source range signals.
An example relates to a method for aligning the spectral band borders of HFR generated signals to spectral borders utilized in a parametric process.
An example relates to a method for aligning the spectral borders of the HFR generated signals to the spectral borders of the envelope adjustment frequency table comprising: the search for the highest border in the envelope adjustment frequency table that does not exceed the fundamental bandwidth limits of the HFR generated signal of transposition factor T; and using the found highest border as the frequency limit of the HFR generated signal of transposition factor T.
An example relates to a method for aligning the spectral borders of the limiter tool to the spectral borders of the HFR generated signals comprising: adding the frequency borders of the HFR generated signals to the table of borders used when creating the frequency band borders used by the limiter tool; and forcing the limiter to use the added frequency borders as constant borders and to adjust the remaining borders accordingly.
An embodiment relates to combined transposition of an audio signal comprising several integer transposition orders in a low resolution filter bank domain where the transposition operation is performed on time blocks of subband signals.
A further embodiment relates to combined transposition, where transposition orders greater than 2 are embedded in an order 2 transposition environment.
A further example relates to combined transposition, where transposition orders greater than 3 are embedded in an order 3 transposition environment, whereas transposition orders lower than 4 are performed separately.
A further example relates to combined transposition, where transposition orders (e.g. transposition orders greater than 2) are created by replication of previously calculated   transposition orders (i.e. especially lower orders) including the core coded bandwidth. Every conceivable combination of available transposition orders and core bandwidth is possible without restrictions.
An embodiment relates to reduction of computational complexity due to the reduced number of analysis filter banks which are required for transposition.
An example relates to an apparatus for generating a bandwidth extended signal from an input audio signal, comprising: a patcher for patching an input audio signal to obtain a first patched signal and a second patched signal, the second patched signal having a different patch frequency compared to the first patched signal, wherein the first patched signal is generated using a first patching algorithm, and the second patched signal is generated using a second patching algorithm; and a combiner for combining the first patched signal and the second patched signal to obtain the bandwidth extended signal.
A further example relates to this apparatus according, in which the first patching algorithm is a harmonic patching algorithm, and the second patching algorithm is a non-harmonic patching algorithm.
A further example relates to a preceding apparatus, in which the first patching frequency is lower than the second patching frequency or vice versa.
A further example relates to a preceding apparatus, in which the input signal comprises a patching information; and in which the patcher is configured for being controlled by the patching information extracted from the input signal to vary the first patching algorithm or the second patching algorithm in accordance with the patching information.
A further example relates to a preceding apparatus, in which the patcher is operative to patch subsequent blocks of audio signal samples, and in which the patcher is configured to apply the first patching algorithm and the second patching algorithm to the same block of audio samples.
A further example relates to a preceding apparatus, in which a patcher comprises, in arbitrary orders, a decimator controlled by a bandwidth extension factor, a filter bank, and a stretcher for a filter bank subband signal.
A further example relates to a preceding apparatus, in which the stretcher comprises a block extractor for extracting a number of overlapping blocks in accordance with an extraction   advance value; a phase adjuster or windower for adjusting subband sampling values in each block based on a window function or a phase correction; and an overlap/adder for performing an overlap-add-processing of windowed and phase adjusted blocks using an overlap advance value greater than the extraction advance value.
A further embodiment relates to an apparatus for bandwidth extending an audio signal comprising: a filter bank for filtering the audio signal to obtain downsampled subband signals; a plurality of different subband processors for processing different subband signals in different manners, the subband processors performing different subband signal time stretching operations using different stretching factors; and a merger for merging processed subbands output by the plurality of different subband processors to obtain a bandwidth extended audio signal.
A further example relates to an apparatus for downsampling an audio signal, comprising: a modulator; an interpolator using an interpolation factor; a complex low-pass filter; and a decimator using a decimation factor, wherein the decimation factor is higher than the interpolation factor.
An example relates to an apparatus for downsampling an audio signal, comprising: a first filter bank for generating a plurality of subband signals from the audio signal, wherein a sampling rate of the subband signal is smaller than a sampling rate of the audio signal; at least one synthesis filter bank followed by an analysis filter bank for performing a sample rate conversion, the synthesis filter bank having a number of channels different from a number of channels of the analysis filter bank; a time stretch processor for processing the sample rate converted signal; and a combiner for combining the time stretched signal and a low-band signal or a different time stretched signal.
A further example relates to an apparatus for downsampling an audio signal by a non-integer downsampling factor, comprising: a digital filter; an interpolator having an interpolation factor; a poly-phase element having even and odd taps; and a decimator having a decimation factor being greater than the interpolation factor, the decimation factor and the interpolation factor being selected such that a ratio of the interpolation factor and the decimation factor is non-integer.
An embodiment relates to an apparatus for processing an audio signal, comprising: a core decoder having a synthesis transform size being smaller than a nominal transform size by a factor, so that an output signal is generated by the core decoder having a sampling rate smaller than a nominal sampling rate corresponding to the nominal transform size; and a post   processor having one or more filter banks, one or more time stretchers and a merger, wherein a number of filter bank channels of the one or more filter banks is reduced compared to a number as determined by the nominal transform size.
A further example relates to an apparatus for processing a low-band signal, comprising: a patch generator for generating multiple patches using the low-band audio signal; an envelope adjustor for adjusting an envelope of the signal using scale factors given for adjacent scale factor bands having scale factor band borders, wherein the patch generator is configured for performing the multiple patches, so that a border between the adjacent patches coincides with a border between adjacent scale factor bands in the frequency scale.
An example relates to an apparatus for processing a low-band audio signal, comprising: a patch generator for generating multiple patches using the low band audio signal; and an envelope adjustment limiter for limiting envelope adjustment values for a signal by limiting in adjacent limiter bands having limiter band borders, wherein the patch generator is configured for performing the multiple patches so that a border between adjacent patches coincides with a border between adjacent limiter bands in a frequency scale.
The inventive processing is useful for enhancing audio codecs that rely on a bandwidth extension scheme. Especially, if an optimal perceptual quality at a given bitrate is highly important and, at the same time, processing power is a limited resource.
Most prominent applications are audio decoders, which are often implemented on hand-held devices and thus operate on a battery power supply.
The encoded audio signal can be stored on a digital storage medium or can be transmitted on a transmission medium such as a wireless transmission medium or a wired transmission medium such as the Internet.
Depending on certain implementation requirements, embodiments of the invention can be implemented in hardware or in software. The implementation can be performed using a digital storage medium, for example a floppy disk, a DVD, a CD, a ROM, a PROM, an EPROM, an EEPROM or a FLASH memory, having electronically readable control signals stored thereon, which cooperate (or are capable of cooperating) with a programmable computer system such that the respective method is performed.
Some embodiments according to the invention comprise a data carrier having electronically readable control signals, which are capable of cooperating with a programmable computer system, such that one of the methods described herein is performed.
Generally, embodiments of the present invention can be implemented as a computer program product with a program code, the program code being operative for performing one of the methods when the computer program product runs on a computer. The program code may for example be stored on a machine readable carrier.
Other embodiments comprise the computer program for performing one of the methods described herein, stored on a machine readable carrier.
In other words, an embodiment of the inventive method is, therefore, a computer program having a program code for performing one of the methods described herein, when the computer program runs on a computer.
A further embodiment of the inventive methods is, therefore, a data carrier (or a digital storage medium, or a computer-readable medium) comprising, recorded thereon, the computer program for performing one of the methods described herein.
A further embodiment of the inventive method is, therefore, a data stream or a sequence of signals representing the computer program for performing one of the methods described herein. The data stream or the sequence of signals may for example be configured to be transferred via a data communication connection, for example via the Internet.
A further embodiment comprises a processing means, for example a computer, or a programmable logic device, configured to or adapted to perform one of the methods described herein.
A further embodiment comprises a computer having installed thereon the computer program for performing one of the methods described herein.
In some embodiments, a programmable logic device (for example a field programmable gate array) may be used to perform some or all of the functionalities of the methods described herein. In some embodiments, a field programmable gate array may cooperate with a microprocessor in order to perform one of the methods described herein. Generally, the methods are preferably performed by any hardware apparatus.
The above described embodiments are merely illustrative for the principles of the present invention. It is understood that modifications and variations of the arrangements and the details described herein will be apparent to others skilled in the art. It is the intent, therefore, to be limited only by the scope of the impending patent claims and not by the specific details presented by way of description and explanation of the embodiments herein.
Literature:- [1]M. Dietz, L. Liljeryd, K. Kjörling and O. Kunz, "Spectral Band Replication, a novel approach in audio coding," in 112th AES Convention, Munich, May 2002.
- [2]S. Meltzer, R. Böhm and F. Henn, "SBR enhanced audio codecs for digital broadcasting such as "Digital Radio Mondiale" (DRM)," in 112th AES Convention, Munich, May 2002.
- [3] T. Ziegler, A. Ehret, P. Ekstrand and M. Lutzky, "Enhancing mp3 with SBR: Features and Capabilities of the new mp3PRO Algorithm," in 112th AES Convention, Munich, May 2002.
- [4] International Standard ISO/IEC 14496-3:2001/FPDAM 1, "Bandwidth Extension," ISO/IEC, 2002. Speech bandwidth extension method and apparatus Vasu Iyengar et al
- [5] E. Larsen, R. M. Aarts, and M. Danessis. Efficient high-frequency bandwidth extension of music and speech. In AES 112th Convention, Munich, Germany, May 2002.
- [6]R. M. Aarts, E. Larsen, and O. Ouweltjes. A unified approach to low- and high frequency bandwidth extension. In AES 115th Convention, New York, USA, October 2003.
- [7] K. Käyhkö. A Robust Wideband Enhancement for Narrowband Speech Signal. Research Report, Helsinki University of Technology, Laboratory of Acoustics and Audio Signal Processing, 2001.
- [8]E. Larsen and R. M. Aarts. Audio Bandwidth Extension - Application to psychoacoustics, Signal Processing and Loudspeaker Design. John Wiley & Sons, Ltd, 2004.
- [9]E. Larsen, R. M. Aarts, and M. Danessis. Efficient high-frequency bandwidth extension of music and speech. In AES 112th Convention, Munich, Germany, May 2002.
- [10]J. Makhoul. Spectral Analysis of Speech by Linear Prediction. IEEE Transactions on Audio and Electroacoustics, AU-21(3), June 1973.
- [11]United States Patent Application 08/951,029, Ohmori , et al. Audio band width extending system and method
- [12]United States Patent 6895375, Malah, D & Cox, R. V.: System for bandwidth extension of Narrow-band speech
- [13] Frederik Nagel, Sascha Disch, "A harmonic bandwidth extension method for audio codecs," ICASSP International Conference on Acoustics, Speech and Signal Processing, IEEE CNF, Taipei, Taiwan, April 2009
- [14] Frederik Nagel, Sascha Disch, Nikolaus Rettelbach, "A phase vocoder driven bandwidth extension method with novel transient handling for audio codecs," 126th AES Convention , Munich, Germany, May 2009
- [15]M. Puckette. Phase-locked Vocoder. IEEE ASSP Conference on Applications of Signal Processing to Audio and Acoustics, Mohonk 1995.", Röbel, A.: Transient detection and preservation in the phase vocoder; citeseer.ist.psu.edu/679246.html
- [16]Laroche L., Dolson M.: "Improved phase vocoder timescale modification of audio", IEEE Trans. Speech and Audio Processing, vol. 7, no. 3, pp. 323--332,
- [17]United States Patent 6549884 Laroche, J. & Dolson, M.: Phase-vocoder pitch-shifting
- [18] Herre, J.; Faller, C.; Ertel, C.; Hilpert, J.; Hölzer, A.; Spenger, C, "MP3 Surround: Efficient and Compatible Coding of Multi-Channel Audio," 116th Conv. Aud. Eng. Soc., May 2004
- [19]Neuendorf, Max; Gournay, Philippe; Multrus, Markus; Lecomte, Jérémie; Bessette, Bruno; Geiger, Ralf; Bayer, Stefan; Fuchs, Guillaume; Hilpert, Johannes; Rettelbach, Nikolaus; Salami, Redwan; Schuller, Gerald; Lefebvre, Roch; Grill, Bernhard: Unified Speech and Audio Coding Scheme for High Quality at Low Bitrates, ICASSP 2009, April 19-24, 2009, Taipei, Taiwan
- [20]Bayer, Stefan; Bessette, Bruno; Fuchs, Guillaume; Geiger, Ralf; Goumay, Philippe; Grill, Bernhard; Hilpert, Johannes; Lecomte, Jérémie; Lefebvre, Roch; Multrus, Markus; Nagel, Frederik; Neuendorf, Max; Rettelbach, Nikolaus; Robilliard, Julien; Salami, Redwan; Schuller, Gerald: A Novel Scheme for Low Bitrate Unified Speech and Audio Coding, 126th AES Convention, May 7, 2009, München