1. Field of the Invention
The present invention relates to coding and decoding of audio signals to reduce transmission bandwidth without unacceptably degrading the quality of the reconstructed signal.
2. Description of Related Art
Many techniques exist in the field of audio compression for encoding a signal that can later be decoded without significant loss of quality. A common scheme is to sample a signal and use these samples to produce a discrete frequency transform. Varieties of transforms exist such as Discrete Fourier Transform (DFT), Odd-frequency Discrete Fourier Transform (ODFT), and Modified Discrete Cosine Transform (MDCT).
Also, transmission bandwidth can be conserved by sending only lower frequency (base band) spectral components. To restore the higher frequency components on the decoding side, various bandwidth extension techniques have been proposed. A simple technique is to take the base band components and scale them up in frequency.
Also, certain frequency components are difficult to perceive by the human ear when they are close in frequency to a dominant, high energy component. Accordingly, such dominant components can have associated with them a masking function to attenuate nearby frequency components, the attenuation being greater the closer a component is to the dominant masking component. Techniques of this type are part of the field of perceptual coding.
The field of perceptual coding for audio coding has been an active one over the past two decades. Typical configuration for the perceptual model used in audio codecs such as PAC, AAC, MPEG-LayerIII etc. may be found in [1-5]. The centerpiece of perceptual modeling is the concept of auditory masking [11-15, 27]. The goal is to quantize the audio signal in such a way that the quantization noise is either fully masked or rendered less annoying due to masking by the audio signal. Building of a perception model in audio codec typically involves the utilization of following four key concepts: simultaneous masking, temporal masking, frequency spread of masking, and, tone vs. noise like nature of the masker. Simultaneous masking is a phenomenon whereby a masker is found to mask the perception of a maskee occurring at the same time. Temporal masking refers to a phenomenon in which a masker masks a maskee occuring either prior to or after its occurrence. Frequency spread of masking refers to the phenomenon that a masker at a certain frequency has a masking potential not only at that frequency but also at neighboring frequencies. Finally, the masking potential of a narrow band masker is strongly dependent on the tone vs. noise like nature of the masker. These factors are utilized to estimate desired quantization accuracy, or Signal to Mask Ratio (SMR) for each band of frequency.
In many audio codecs the masking model for wideband audio signals is constructed using a two step procedure. First the (short-term) signal spectrum is analyzed in multiple partitions (which are narrower than a critical band). The masking potential of each narrow-band masker is estimated by convolving it with a spreading function which models the frequency spread of masking. The masked threshold of the wide band audio signal is then estimated by considering it to be the superposition of multiple narrow band maskers. Recent studies suggest that this assumption of superposition may not always be a valid one. In particular a phenomenon called Comodulation Release of Masking (CMR) has implication towards the extension of narrow band model to a wide band model. B. C. J. Moore, An Introduction to the Psychology of Hearing, 5th Ed., Academic Press, San Diego (2003). See Hall J W, Grose J H, Mendoza L (1995) Across-channel processes in masking. In: Hearing (Moore B C J, ed), pp 243-266. San Diego: Academic.
In accordance with the illustrative embodiments demonstrating features and advantages of the present invention, there is provided a method for encoding an audio signal. The method includes the step of transforming the audio signal into a discrete plurality of (a) basic transform coefficients corresponding to basic spectral components located in a base band and (b) extended transform coefficients corresponding to components located beyond the base band. Another step is correlating that is (i) based on at least some of the basic transform coefficients and at least some of the extended transform components and (ii) performed by programmatically determining and applying a primary frequency scaling parameter and a primary frequency translation parameter to form a revised relation between the basic transform coefficients and extended transform coefficients that increases their correlation. The method also includes the step of forming an encoded signal based on the basic transform coefficients, the primary frequency scaling parameter and the primary frequency translation parameter.
In accordance with another aspect of the present invention, there is provided an encoder for encoding an audio signal that includes a processor, which has a transform, a correlator and a former. The transform can transform the audio signal into a discrete plurality of (a) basic transform coefficients corresponding to basic spectral components located in a base band and (b) extended transform coefficients corresponding to components located beyond the base band. The correlator can provide a correlation that is (i) based on at least some of the basic transform coefficients and at least some of the extended transform components and (ii) performed by programmatically determining and applying a primary frequency scaling parameter and a primary frequency translation parameter to form a revised relation between the basic transform coefficients and extended transform coefficients that increases their correlation. The former can form an encoded signal based on the basic transform coefficients, the primary frequency scaling parameter and the primary frequency translation parameter.
In accordance with yet another aspect of the present invention, a method is provided for decoding a compressed audio signal signifying (a) basic transform coefficients of basic spectral components derived from a base band, (b) one or more frequency scaling parameters, and (c) one or more frequency translation parameters. The method includes the step of applying the one or more frequency scaling parameters and the one or more frequency translation parameters to the basic transform coefficients to provide a plurality of altered primary coefficients having altered spectral significance. Another step is inverting the basic transform coefficients and the altered primary coefficients to form a time-domain signal.
In accordance with still yet another aspect of the present invention, there is provided a decoder for decoding a compressed audio signal signifying (a) basic transform coefficients of basic spectral components derived from a base band, (b) one or more frequency scaling parameters, and (c) one or more frequency translation parameters. The decoder has a relocator for applying the one or more frequency scaling parameters and the one or more frequency translation parameters to the basic transform coefficients to provide a plurality of altered primary coefficients having altered spectral significance. The decoder also has an inverter for inverting the basic transform coefficients and the altered primary coefficients to form a time-domain signal.
In accordance with a further aspect of the present invention, a method is provided for encoding an audio signal. The method includes the step of transforming the audio signal into a discrete plurality of primary transform coefficients corresponding to spectral components located in a designated band. Another step is correlating based on a correspondence between at least some of the primary transform coefficients and programmatically synthesized data corresponding to a synthetic harmonic or individual sinusoids spectrum comprising any combination of one or more harmonic patterns and one or more individual sinusoids. The method also includes the step of forming an encoded signal based on at least some of the primary transform coefficients, and one or more harmonic parameters signifying one or more characteristics of the synthetic harmonic or individual sinusoids spectrum.
In accordance with another further aspect of the present invention, there is provided an encoder for encoding an audio signal. The encoder has a transform for transforming the audio signal into a discrete plurality of primary transform coefficients corresponding to spectral components located in a designated band. Also included is a correlation device for correlating based on a correspondence between at least some of the primary transform coefficients and programmatically synthesized data corresponding to a synthetic harmonic spectrum. The encoder also has a former for forming an encoded signal based on at least some of the primary transform coefficients, and one or more harmonic parameters signifying one or more characteristics of the synthetic harmonic spectrum.
In accordance with yet another further aspect of the present invention, a method is provided for decoding a compressed audio signal signifying (a) a plurality of basic transform coefficients corresponding to basic spectral components located in a base band, and (b) one or more harmonic parameters signifying one or more characteristics of a synthetic harmonic or individual sinusoids spectrum comprising any combination of one or more harmonic patterns and one or more individual sinusoids. The method includes the step of synthesizing one or more harmonically related transform coefficients based on the one or more harmonic parameters. Another step is inverting the basic transform coefficients and the one or more harmonically related transform coefficients into a time-domain signal.
In accordance with still yet another further aspect of the present invention, there is provided a decoder for decoding a compressed audio signal signifying (a) a plurality of basic transform coefficients corresponding to basic spectral components located in a base band, and (b) one or more harmonic parameters signifying one or more characteristics of a synthetic harmonic or individual sinusoids spectrum comprising any combination of one or more harmonic patterns and one or more individual sinusoids. The decoder has a synthesizer for synthesizing one or more harmonically related transform coefficients based on the one or more harmonic parameters. Also included is an inverter for inverting the basic transform coefficients and the one or more harmonically related transform coefficients into a time-domain signal.
In accordance with still yet another aspect of the present invention, a method is provided for encoding an audio signal. The method includes the step of transforming the audio signal into a discrete plurality of transform coefficients corresponding to spectral components located in a designated band, some of the transform coefficients corresponding to one or more standard time intervals and others individually corresponding to one of a plurality of subintervals within the one or more standard time intervals.
Another step is forming an encoded signal based on (a) the plurality of transform coefficients associated with the one or more standard time intervals, and (b) magnitude information based on the plurality of transform coefficients associated with the plurality of subintervals.
In accordance with yet another aspect of the present invention, there is provided an encoder for encoding an audio signal. The encoder has a transform for transforming the audio signal into a discrete plurality of transform coefficients corresponding to spectral components located in a designated band, some of the transform coefficients corresponding to one or more standard time intervals and others individually corresponding to one of a plurality of subintervals within the one or more standard time intervals.
The encoder also has a former for forming an encoded signal based on (a) the plurality of transform coefficients associated with the one or more standard time intervals, and (b) magnitude information based on the plurality of transform coefficients associated with the plurality of subintervals.
In accordance with yet another aspect of the present invention, a method is provided for processing a decompressed audio signal obtained from a discrete plurality of transform coefficients corresponding to one or more standard time intervals, using magnitude information based on a plurality of transform coefficients corresponding to one of a plurality of subintervals of the one or more standard time intervals. The method includes the step of inverting the discrete plurality of transform coefficients associated with the one or more standard time intervals into a first time-domain signal. Another step is successively transforming the first time-domain signal into a frequency domain to obtain a discrete plurality of local coefficients individually assigned to a plurality of successive time slots corresponding in duration to the plurality of subintervals. The method also includes the step of resealing the plurality of local coefficients using from the compressed audio signal the transform coefficients associated with the plurality of subintervals. Another step is inverting the discrete plurality of local coefficients into a corrected time-domain signal.
In accordance with yet another aspect of the present invention, there is provided a decoding accessory for processing a decompressed audio signal obtained from a discrete plurality of transform coefficients corresponding to one or more standard time intervals, using magnitude information based on a plurality of transform coefficients corresponding to one of a plurality of subintervals of the one or more standard time intervals. The accessory has a first inverter for inverting the discrete plurality of transform coefficients associated with the one or more standard time intervals into a first time-domain signal. Also included is a transform for successively transforming the first time-domain signal into a frequency domain to obtain a discrete plurality of local coefficients individually assigned to a plurality of successive time slots corresponding in duration to the plurality of subintervals. The accessory also has a rescaler for resealing the plurality of local coefficients using from the compressed audio signal the transform coefficients associated with the plurality of subintervals. Also included is a second inverter for inverting the discrete plurality of local coefficients into a corrected time-domain signal.
In accordance with another aspect of the present invention, a method is provided for encoding an audio signal. The method includes the step of transforming the audio signal into at least a discrete plurality of transform coefficients corresponding to spectral components located in a designated band, the transform coefficients including a standard grouping and a substandard grouping, the standard grouping being associated with one or more standard time intervals, the substandard grouping being dividable into a plurality of isofrequency sequences, each of the plurality of isofrequency sequences encompassing the one or more standard time intervals and being associated with a corresponding one of the transform coefficients in the standard grouping, the transform coefficients of the standard grouping each being assigned a masking characteristic for perceptually attenuating spectrally nearby ones of the standard grouping according to a predefined masking function having a predefined domain. Also included is the step of weakening the masking characteristic of each of the transform coefficients in the standard grouping based on the extent its corresponding one of the isofrequency sequences varies and correlates with spectrally nearby ones of the isofrequency sequences.
In accordance with another aspect of the present invention, there is provided an encoder for encoding an audio signal. The encoder has a transform for transforming the audio signal into at least a discrete plurality of transform coefficients corresponding to spectral components located in a designated band, the transform coefficients including a standard grouping and a substandard grouping, the standard grouping being associated with one or more standard time intervals, the substandard grouping being dividable into a plurality of isofrequency sequences, each of the plurality of isofrequency sequences encompassing the one or more standard time intervals and being associated with a corresponding one of the transform coefficients in the standard grouping, the transform coefficients of the standard grouping each being assigned a masking characteristic for perceptually attenuating spectrally nearby ones of the standard grouping according to a predefined masking function having a predefined domain. Also included is a weakener for weakening the masking characteristic of each of the transform coefficients in the standard grouping based on the extent its corresponding one of the isofrequency sequences varies and correlates with spectrally nearby ones of the isofrequency sequences..
The present audio bandwidth extension (BWE) technique is based upon two algorithms, namely Accurate Spectral Replacement (ASR) and Fractal Self-Similarity Model (FSSM). The ASR technique is described in a paper by Anibal J. S. Ferreira and Deepen Sinha, “Accurate Spectral Replacement,” 118th Convention of the Audio Engineering Society, May 2005, Paper 6383, which paper is incorporated herein by reference. The FSSM and ASR technique are described in a paper by Deepen Sinha, Anibal Ferreira, and, Deep Sen “A Fractal Self-Similarity Model for the Spectral Representation of Audio Signals,” 118th Convention of the Audio Engineering Society, May 2005, Paper 6467; and Deepen Sinha, and Anibal Ferreira, “A New Broadcast Quality Low Bit Rate Audio Coding Scheme Utilizing Novel Bandwidth Extension Tools,” 119th Convention of the Audio Engineering Society, October 2005, Paper 6588 of the which papers are incorporated herein by reference.
The ASR and FSSM techniques work directly in the frequency domain with a high frequency resolution representation of the signal. These representations are supplemented by a third tool “Multi Band Temporal Amplitude Coding” (MBTAC), which ensures accurate reconstruction of the time-varying envelope of the signal representation in the frequency domain. The MBTAC tool utilizes a Utility Filterbank (UFB) that generates a frequency representation of the signal that varies in time with a relatively high time resolution to provide a time-frequency representation of the signal.
With the ASR technique the spectrum is segmented into sinusoids and residual (or noise), this residual results by removing (i.e., by subtracting) sinusoids directly from the complex discrete frequency representation of the audio signals from block 10. Coefficients for the sinusoids are coded and transmitted to the decoder.
The FSSM technique implements a bandwidth extension model employing the basic principle of creating a high frequency bandwidth from a low frequency spectrum. The model involves identifying dilation (frequency scaling) and frequency translation parameters which when applied on a low frequency band, efficiently represents the high frequency signal. Maximizing intra spectral-cross correlation is the basic criterion in choosing dilation and translation parameters. A brief functional description of FSSM's operation is as follows:
In parallel to the above sequence of processes (which emanate from a high resolution frequency analysis), a second time-frequency analysis may be optionally performed and used to encode the time frequency envelope of the signal as well as the inter-aural phase cues. This sequence of parallel functional blocks is as follows:
A Utility Filterbank (UFB) is a complex modulated filterbank with several-times oversampling. It allows for a time resolution as high as 16/Fs (where Fs is the sampling frequency) and frequency resolution as high Fs/256. It also optionally supports a non-uniform time-frequency resolution.
Multi Band Temporal Amplitude Coding (MBTAC) involves efficient coding of two channel (stereo) time-frequency envelopes in multiple frequency bands. The resolution of MBTAC frequency bands is user selectable. The envelope information is grouped in time and frequency and jointly coded (across two channels) for coding efficiency. Various noiseless coding tools are used to reduce bit demand.
The present disclosure also has a perceptual model employing psychometric data and results related to comodulation release of masking.
The above brief description as well as other objects, features and advantages of the present invention will be more fully appreciated by reference to the following detailed description of illustrative embodiments in accordance with the present invention when taken in conjunction with the accompanying drawings, wherein:
Referring to
Block 10 is herein referred to as a transform for producing a plurality of transform coefficients (sometimes referred to as primary transform coefficients located in a designated band) indicating the magnitude or entity all discrete spectral components. These transform coefficients may be may be segregated into basic transform coefficients corresponding to basic spectral components located in a base band and extended transform coefficients that may not be directly encoded but many be simulated by the herein disclosed bandwidth extension method. The basic transform coefficients may be encoded and individually transmitted.
A window type detector 12 is applied to decide the window structure (Long/Short window) to be used to establish an input frame appropriate to avoid pre-echo condition; in other words, a trade off on time-frequency resolution is done based on the stationarity of the input frame. Specifically, detector 12 selects an increased time resolution (short window) for a non-stationary frame and an increased frequency resolution (long window) for a stationary frame. In case of a window state transition a well-known Start or Stop window is suitably inserted.
The present codec utilizes an algorithm for the detection and accurate parameter estimation of sinusoidal components in the signal. The algorithm may be based on the work by Anibal J. S. Ferreira and Deepen Sinha, “Accurate and Robust Frequency Estimation in ODFT Domain,” in 2005 IEEE Workshop on Applications of Signal Processing to Audio and Acoustics, Oct. 16-19, 2005; and Anibal J. S. Ferreira, “Accurate Estimation in the ODFT Domain of the Frequency, Phase and Magnitude of Stationary Sinusoids,” in 2001 IEEE Workshop on Applications of Signal Processing to Audio and Acoustics, Oct. 21-24 2001, pp. 47-50.
The detected sinusoids may be further analyzed for the presence of harmonic patterns using techniques similar to that described by Anibal J. S. Ferreira, “Combined Spectral Envelope Normalization and Subtraction of Sinusoidal Components in the ODFT and MDCT Frequency Domains,” in 2001 IEEE Workshop on Applications of Signal Processing to Audio and Acoustics, Oct. 21-24 2001, pp. 51-54.
Depending on the chosen window (Long window=1024/Short window=128) MDCT and ODFT coefficients are calculated as graphically indicated in
where XM(K) is MDCT of the input sequence x(n) and h(n) the windowing function and n0=½+N/4.
Taking 0≦K≦N/2−1 it can be shown that,
XM(K)=(X0(k))cos Θ(K)+ℑ(X0(K)) sin θ(K)
Where, X0(K) is ODFT of x(n) and
ODFT of a sequence x(n) is defined as:
ODFT of two channels is computed using an efficient algorithm described in. the TechOnline Paper “A Fast Algorithm for Computing Two Channel Odd Frequency Transforms with Application to Audio Coding” Sinha, N. and Ferreira J. S. TechOnline October 2005. The default window shape used in ODFT analysis is the sine window. Higher order smooth windows as described in the Sinha Ferreira Paper in AES 120th convention, NY may also be used for this analysis. In case of a Long to Short (Short to Long) transition the Long window immediately preceding (following) the Short window has a special non-symmetrical shape characterized as a Start (Stop) window. In such a case the ODFT/MDCT analysis is recomputed using the appropriate transition window shape.
The MDCT components thus produced are processed using a conventional stereo dynamic range control in block 26 before being bandwidth limited in block 28 for purposes to be described presently.
Thereafter, the magnitudes associated with the bandwidth limited components of the baseband are quantized in block 22. The quantizing steps can be adjusted dynamically in a manner to be described hereinafter.
Thereafter, entropy coding can be performed in block 24, which implements the well-known Huffman coding technique. Since the entropy coding can produce a time varying bit rate, a buffer is used in block 42, which is controlled by a rate control mechanism in block 40 in a conventional manner.
The final results of the processing in this main channel are forwarded to bitstream formatting block 48, which combines data from this channel with other data to form a bitstream having an appropriate transport protocol.
Pyschoacoustic Model
The present codec includes a perceptual coding scheme whereby a sophisticated psychoacoustic model is employed to quantize the output of an analysis filter bank.
Two key aspects of the present psychoacoustic model pertains respectively to the extension of a narrow band masking model to wide band audio signals and to the accurate detection of tonal components in the signal.
In block 34 a conventional tonal analysis is performed and its results are forwarded to the quantizing control block 36, which connects to the quantizer 22 in the main channel.
Unlike conventional perceptual models, analysis is performed in block 32 taking into account comodulation release (CMR). Comodulation release is a phenomenon that suggests reducing conventional masking in the presence of a wide band (bandwidth greater than a critical band) noise-like signal which is coherently amplitude modulated (comodulated) over the entire spectrum range covered by a masking function. The reduction in masking has been variously reported to be between 4.0 dB to as high as 18 dB. See Jesko L. Verhey, Torsten Dau, and Birger Kollmeier “Within-channel cues in comodulation masking release (CMR): Experiments and model predictions using a modulation filter bank model” Journal of the Acoustical Society of America, 106(5), p. 2733-2745.
The exact physiological phenomenon responsible for CMR is still being investigated by various researchers. However, there is some evidence that CMR occurs due to a combination of multiple factors. It has been hypothesized that the masking release results from cues available within a critical band and from cues generated by comparisons across critical bands.
In audio codecs this implies that superposition of masking does not hold in the presence of strong temporal envelope and masking of wide band signals can be significantly lower than the sum of masking due to individual narrow (sub-critical) band components depending upon the coherence of their temporal envelopes. It is tempting to think that CMR can be accounted for through adequate temporal shaping of the quantization noise (since the masking threshold during the dips in envelope is very likely to be lower), but experiments indicate that (the lack of) temporal shaping of maskee does not explain all (or most) of the CMR phenomenon. In particular masking release of about 4-8 dB should be accounted for directly in the psychoacoustic model.
The present psychoacoustic model works with the short windows (substandard grouping) produced by block 10 so that some finer time variation is obtained about the temporal envelope for the frequency components of the critical bands (one or more isofrequency sequences formed from the substandard grouping). In this specification, the long windows are considered part of a standard grouping and are associated with one or more standard time intervals, where the isofrequency sequences encompass one or more standard time intervals.
A CMR model is incorporated which takes into account: (i) the effective bandwidth of the ith critical band masker (masking value), EBM defined as
where φi and φj are respectively the normalized temporal envelopes of ith and h critical band maskers (a suitable value for N is about 5); and, (ii) dip in the temporal envelope of the masker, P (having an individual value defined for each critical band as the peak to valley ratio between the minimum and maximum of the temporal envelope of the masker in a 20-30 msec window). Estimation for the reduced masking potential of the narrowband masker, i, (CMRCOMP) is then made as below
CMRCOMPi=−10 log10[ρ/N(EBMi)] (2)
where N(α) is a non-linearity and the CMRCOMPI value in (2) is saturated to a minimum of 0 dB (a piecewise linear function with a linear rise for a below 0.7 and above 0.8 and rapid rise angle of over 80° for a between 0.7 and 0.8 was found suitable in our experiments). Therefore, each narrowband masker is reduced in accordance with CMRCOMPi. Partial support for this model is based on data in Verhey et al., supra, and is supported by listening data based on expert listeners. The estimated CMR compensation is utilized when combining the masking effect of multiple bands.
Basically, the masking characteristic (a predefined masking function with a predefined domain) ordinarily assigned to transform coefficients of the standard grouping are weakened (with a weakener in block 32) based on the comodulation value, CMRCOMPi.
Bandwidth Extension
The transform coefficients from block 10 are to be segregated into basic transform coefficients in a low-frequency base band and extended transform coefficients located above the base band. The basic transform coefficients will be processed in a main channel as MDCT coefficients capable of representing a signal with relatively high fidelity (these are directly coded using either a conventional perceptual coding technique or its extensions described herein). Other parameters indicating qualities of the extended transform coefficients located beyond the base band.
Harmonic analysis block 14 (shown in
ASR/FSSM Model Configuration block 18 has an input coupled to block 14. Block 18 can be configured (either permanently or based on user selected parameters) to issue control signal for specifying processing issues, such as processing order (ASR or FSSM first), components to be handled by ASR and FSSM, allowed number of harmonic patterns to be coded, bandwidth extension range, etc. See Table 1, which is discussed further hereinafter. Accordingly, FSSM block 16 and ASR block 20 will respond to this control signal and code accordingly the specified frequency structures (harmonics and tones).
While the present embodiment employs both an FSSM block 16 and ASR block 20, other embodiments may employ only one of them.
In ASR block 20 the spectrum is segmented into sinusoids and residual (or noise-like frequency components). This residual is created by removing (i.e., by subtracting) sinusoids directly from the complex discrete frequency representation of the audio signals from block 10. Coefficients for the sinusoids are coded with sub-bin accuracy and transmitted to the decoder.
Referring again to accurate harmonic analysis block 14, this block identifies sinusoidal components from the input spectrum by identifying peaks in the fine structure of the spectral-envelope, harmonic structures present, if any, and strong high frequency (HF) tonals from the input spectrum produced by block 10. Identifying peaks in the fine structure of the spectral-envelope and strong HF tonals is a simple peak picking process. Detecting harmonic structure is a more complex process involving identification of relevant structures of sinusoids harmonically related in a way that is tolerant to local harmonic discontinuities,. A condition for a harmonic structure to be recognized as such is that it contains at least four sinusoids. Alternatively, strong sinusoids not harmonically related may also be coded individually in case their spectral power exceeds a fraction of the total power of the audio signal. The results of detecting and separating harmonics and strong tonals is graphically illustrated in
Harmonic analysis block 14 models the input spectrum as a sum of harmonics plus noise-like components. The analysis involves identifying the harmonics to be removed from the spectrum. The analysis can be understood by considering the underlying signal as a spectrally spaced plurality of time-domain signals x(n) that can be viewed as sharply distinct harmonics among other components that fit within a smoother, almost noise-like spectrum, as follows:
where fk is the fundamental frequency and φk is the phase of the kth harmonic; and n1 are the partial corresponding to a harmonic sequence (for a non-harmonic tone only one partial will be present). Harmonic analysis results in identification of values of An,k, fk and φk. The spectrum remaining after removing the harmonics (and in some cases the tonal peaks) may be relatively flat and can be adequately represented by a flat (white noise) spectrum represented by a limited number of noise parameters indicating the envelope of a flattened noise spectrum. In other cases, the flattened spectrum will be subjected to analysis with the FSSM model.
While the harmonic components found among the coefficients produced by block 10 will normally be most efficiently handled by the ASR model of block 20, the ultimate choice of coding the harmonic structures using either ASR or FSSM is left to the user as a configuration parameter. If the user configures a flag in block 18 indicating a predominant FSSM mode, the strongest of existing harmonics structures is modeled by FSSM in a manner to be described presently. In the absence of this flag both harmonics are modeled by the ASR algorithm of block 20.
Block 18 also assigns harmonics to the ASR block 20 and FSSM block 16 based on maximum allowable number of harmonics to be coded through ASR block 20, which is established either as a hard coded limit or as one modified by a user-defined parameter. Block 18 also resolves any overlap of frequencies between the tonals and harmonics for both the channels (Left/Right) and also resolves any overlap of frequencies between the channels' HF and harmonic structures.
ASR Parameter Estimation
ASR parameter estimation is performed in block 20, which generates parameters indicating the structure for certain harmonic and tonal values that are assigned to ASR processing by the model configuration block 18. These synthetically generated sinusoids are removed (subtracted) from the input spectrum of from block 10 to give a flattened spectrum that is graphically illustrated in
The foregoing assumed long windows. For short windows the tonal removal is done using a different approach. Until the transition frame, for a short window, tonals are removed using the parameters computed from the previous long window frame and after the transition frame, the tonal parameters from the from the future long window frame are used for synthesis.
For the purpose of ASR parameter estimation. the time-domain representation may be modeled as:
where x(n) is the time-domain representation of the original signal that was analyzed during harmonic analysis; fk is the one or more fundamental frequencies and φk is the phase of the kth harmonic; and n1 are the partials corresponding to a harmonic sequence. Also, continuing with the time-domain representation yields
where x1(n) is the proposed combination of synthetically generated harmonics which uses parameters identified by the harmonic analysis block 14.
Depending upon the bit rate and configuration of the codec, the phase parameter φk may either not be used or used only at the “birth” of a harmonic sequence and then computed for the subsequent frames (e.g. long windows) using a “harmonic continuation algorithm”. In addition,
y(n)=x(n)−x1(n)=Σnoisy_sin usoids
where, y(n) is the residual after the ASR parameter estimation block removes harmonics to yield a noise-like spectrum (note, for missing partials no removal is necessary and therefore the indicated subtraction will not actually occur). Removal of such harmonics or strong tonals is herein referred to as elimination of dominant ones of the basic transform coefficients in the base band. The coefficients to be removed are selected by determining whether their magnitude exceeds to give an extent the magnitudes in predefined neighborhoods (e.g., a predetermined number of dB greater than the average in a predefined guard band, such as ±4 kHz).
Accordingly, the ASR technique results in an abbreviated list of parameters signifying one or more characteristics of a synthetic harmonic spectrum. In order to allow later reconstruction, each harmonic structure will be represented by (a) a fundamental frequency existing in the base band, the other harmonics being assumed to be integer multiples of that fundamental frequency, (b) an optional phase. parameter related to either the fundamental or one of the harmonics in either the base band or the extended band, and (c) optional magnitude information. The magnitude information can be explicitly sent as a shape parameter indicating the declination of the harmonics from one harmonic to the next. Such shape is efficiently coded using signal normalization using a smooth spectral envelope model that can be estimated using conventional (Linear Predictive Coding) LPC-based techniques, cepstrum-based techniques or other appropriate modeling techniques; and is described by a compact set of parameters,. In some embodiments no explicit magnitude information will be sent as part of the ASR process, but some magnitude tailoring will be accomplished as part of the MBTAC process described below.
FSSM Parameter Estimation:
The FSSM algorithm executed in block 16 includes a correlator categorizer and developer and is used for extension of bandwidth for higher frequencies based on low frequency spectrum values using the following programmatically determined and applied estimates of dilation and translation parameters. An introduction to the concept of FSSM is given followed by the functional implementation of FSSM in a BWE decoder.
The working of FSSM, described in detail, can be mathematically represented as a summation of terms with each having an iterative form, as indicated below:
Where each expansion operator EO, is assumed to have the form:
EOi·
Where, αi is a dilation parameter (αi≦1) and fi is a frequency translation parameter (although in some embodiments dilation parameters greater than one may be employed). Hi is a high pass filter with a cut-off frequency
fc1=αi*fc(i−1)+fi
with fc0=fc. This sequence of nested expansion is graphically illustrated in
Using the correlator in block 16, the values of αi and fi are chosen to maximize the cross correlation between FSSM-representative spectrum and the original spectrum. Mathematically, αi and fi are chosen such that,
φ(αi,fi)=<X(f).X(αif−fi)>
with these two discrete spectra being correlated through, for example, a dot product. The correlation is maximized by programmatically adjusting the dilation and translation parameters:
φ(
Where, A is a set of possible values for dilation parameter αi and F is the set of possible values for the translation frequency fi. For the model to be meaningful for bandwidth extension, the range of A and F should be restricted such that aifc+fi>fc+C, ∀αi∈& fi∈F for some suitably chosen minimum extension band C.
The foregoing self similarity model coherence maximization criterion works well in many cases. However, in certain instances special considerations need to be taken into account as listed below:
After performing FSSM on the spectrum, the cross-correlation between spectral frequencies of the original spectrum from block 10 and the FSSM coded spectrum from block 10 is expected to be over a pre-defined threshold; if not, the FSSM parameters/results for the particular frames are discarded and the decoder generates instead synthetic noise with its envelopes following the RMS of the coded values. For a valid structure having valid dilation and translation parameters, the RMS values of the spectrum may be quantized and coded; or the magnitude shaping task may be left for the MBTAC processor-described below.
Accordingly, the output of block 16 is a sequence of ordered, adjusted pairs of frequency scaling parameters αi and frequency translation parameters fi (the members 1, f1 of the first pair being referred to herein as a primary frequency scaling parameter and a primary frequency translation parameter). In most cases no magnitude information is included with this FSSM data because magnitude adjustment can be accomplished through the MBTAC process described below. However, in some instances the MBTAC process is disabled in which case limited magnitude information may be sent with the FSSM data, although this magnitude information may be a coarse grouping of the relocated upper frequency bands created by the pairs αi,fi.
These FSSM parameters are processed through selection block 30 together with the parameters produced by the ASR block 20 before being forwarded to block 48 (herein referred to as a former 48) where they are formatted into an appropriate transport protocol. It will be noted that the selection block 30 transmits the size of the extended band with two low pass filter block 28, which eliminates any high frequency components that are to be modeled by FSSM or ASR.
UFB and MBTA
To perform the task of shaping the temporal envelope of the reconstructed higher frequency components (in those cases when it is needed) we need to examine time trajectories of the spectral energy in multiple frequency bands. Furthermore, these time trajectories need to be examined at a time resolution that is substantially higher than that afforded by the high frequency resolution MDCT filterbank. For accurate temporal shaping for voiced speech and dynamic musical instruments a time resolution of 4-5 msec (or lower) is desirable. The desired temporal shaping can be computed by utilizing a separate higher time resolution “Utility Filter Bank” (UFB). It is desirable for the UFB to be a complex, over-sampled modulated filterbank because of several desirable characteristics of such filterbanks such as very low aliasing distortion. The magnitude of the complex output of the filterbank provides an estimate of the instantaneous spectral magnitude in the corresponding frequency band. Since UFB is not the primary coding filterbank its output may be suitably oversampled at the desired time resolution. Several options exist for the choice of the UFB. These include:
(a) Discrete Fourier Transform (DFT) with a higher time resolution (compared to MDCT): A DFT with 64-256 size power complementary window may be used in a sequence of overlapping blocks (with a 50% overlap between 2 consecutive windows)
(b) A complex modulated filterbank with sub-band filters of the form
where h0 is a suitably optimized prototype filter. The DFT is a sub-class of this type of filterbanks. The more general framework allows for selection of longer windows (compared to the down-sampling factor).
(c) A complex non-Uniform filterbank; e.g., one with two or more uniform sections and transition filters to link the 2 adjacent uniform sections.
The exact choice of the UFB is application dependent. The complex-modulated filterbanks with a higher over-sampling ratio offer superior performance when compared to the DFT but at a cost of higher computational complexity. The non-uniform filterbank with higher frequency resolution at lower frequencies is useful if envelope shaping at very low frequencies (1.2 kHz and lower) is desirable.
MBTAC
The functional requirement of MBTAC is to extract and code the temporal envelope (or time-frequency envelope) of the signal. Specifically, the signal envelope is analyzed in multiple frequency bands using a complex filterbank called a UFB. In a particular implementation of UFB shown herein as block 44, the signal is filtered in 128 uniform frequency sub-bands and each sub-band analysis is down sampled by a factor of 16.
In block 46 (which contains a categorizer and developer, as described further hereinafter) the over sampled signal, corresponding to a frame of input data (1024 samples) is arranged in a 2-D matrix of size 128×64 (128 frequency bands vs. 64 time samples). These 64 times samples are subintervals of the standard time interval for an MBCT frame (i.e., the MDCT timeframe is 64 times greater). Additional details regarding UFB may be obtained from the above noted reference, Deepen Sinha, Anibal Ferreira, and, Deep Sen “A Fractal Self-Similarity Model for the Spectral Representation of Audio Signals,” 118th Convention of the Audio Engineering Society, May 2005, Paper 6467. It may also be noticed that due to the complex nature of the UFB output only the first 64 of the 128 frequency bands need to be analyzed.
The detailed time-frequency envelope generated by this process is grouped using a combination of one or more of the techniques described below, which constitute the categorizer of block 46. The bit rate requirement for coding and transmitting the (grouped) time-frequency envelope is further reduced using the techniques described immediately thereafter.
First Level Time-Frequency Envelope Grouping
The initial, finely partitioned, time-frequency envelope is first grouped by assigning UFB sub-bands to N critical ordered frequencies so-bands (each critical band may be a partition using the well-known concept of Bark bands, each containing one or more of the UFB bands). Furthermore, several adjacent time samples are grouped into a single time slot. For the purpose of this time grouping, the system uses either 8 or 16 adjacent UFB time samples. Therefore, the 64 time samples in a frame get arranged into M ordered time slots, here either 8 or 4 time slots. As an illustrative example, assuming there are 17 critical bands between 0 and Fs/2 (Fs being the sampling frequency) after this level of frequency/time grouping, the result is a still relatively fine N×M matrix of 17×8 or 17×4 RMS envelope values (instead of a 128×64 finely detailed envelope). This N×M matrix has a corresponding frequency index and subinterval index and forms an N×M group index. A “base band” envelope is also computed by averaging across the critical bands between 1kHz and 3.5kHz. This base band envelope may be used in a subsequent, optional grouping technique described below (third level frequency grouping).
If no higher level of grouping is performed (i.e. Second Level or Third Level Grouping as described below) coefficients having the same index (from the N×M group index) will be merged using the developer of block 46 to form indexed proxies signifying, for example, the average magnitude of members of the group (an effective recoding with a recoder).
Second Level Time-Frequency Envelope Grouping
The RMS coded time-frequency envelope after the first level of grouping may optionally be grouped through a second level into consolidated collections that combine adjacent envelopes (adjacent in both time and frequency).
Time grouping is first done on each of the M time indices, with successive time slots being grouped if the difference between maximum-minimum RMS values in each frequency sub-band are within a predetermined limitation on magnitude variation (although sub-band to sub-band differences may be rather large). This grouping is performed over the time slots iteratively until reaching that index where, the latest RMS values cause the calculated difference between the maximum and minimum RMS values in the growing collection of time-grouped values to exceed a threshold in at least one frequency sub-band, in which case this latest time slot is not added to the growing collection. Once closed, all the time-grouped values within this collection are replaced with a single RMS averaged value, one for each frequency sub-band.
As the time grouping above and below transition bands might differ in the first level of grouping, based on the preset values, the second level of grouping is done separately above and below the transition band.
The above mentioned time grouping technique is followed with frequency grouping. In particular all of the time groups are evaluated to determine if all time groups can be partitioned with the same frequency breaks to form, two or more common frequency groups where in each frequency group (and in all time groups) the difference between the greatest and the smallest RMS value falls within a pre-specified frequency grouping limit. As before, the averaged RMS value of frequency groups is calculated to replace the grouped values, which then become indexed proxies replacing those of the first grouping.
This grouping is performed so that each of the consolidated collections do not exclude any one of the indexed proxies that intervene by aligning on a. common row or common column (of the N×M group index) contained in the collection. For each of the consolidated collections the encoded signal will include information based on the gross characteristics of the consolidated collection.
Third level Frequency Grouping
Unlike the other two grouping techniques this is done only on frequency envelope. The technique exploits the correlation between the frequency grouped values. The second level of grouping encompasses only those waveforms which are closer in RMS value to their neighbors; this grouping is done depending on the correlation of grouped frequency values. In this technique the time envelopes in each of the higher frequency bands (critical bands or grouped critical bands constituting higher temporal sequences) is analyzed for closeness to the baseband envelope (a pilot sequence having M temporally sequential values developed from one or more of the lower ones of the N ordered frequency sub-bands) computed in the first grouping. If the “shape” of the envelope is close to the shape in the baseband envelope, only a scaling factor is transmitted (instead of the detailed envelope shape).
The following gives an algorithmic description of this grouping technique and computation of the scaling factor.
To find a value ‘a’ such that the “distance” between ‘aX’ and Y is as small as possible, following procedure is used. With distance as the criterion consider X and Y monochromatic vectors as shown in
D=(y1−ax1)+(Y2−ax2)2+ . . . +(yn−axn)2
To minimize the value of distance (D) with respect to ‘a’, begin by differentiating D with respect to ‘a’ and equate it to zero.
Realigning the above equation,
From the above calculated value of ‘a’ maximum dB difference between the original (Y) waveform and the reconstructed waveform (Z=aX, that is, programmatic changing of scale) is compared with a predetermined threshold and a decision either to code and transmit as part of encoder bitstream X and Y individually or to code only X and the distance parameter ‘a’ is made. Coding of grouped values:
The above Time-Frequency grouped values are efficiently coded based on a comparative analysis based on bit demand. There are four different ways of differential coding (recoding) the above grouped Time-Frequency envelope, based on the adjacency along the ordered frequency sub-bands and ordered time slots, defined as follows:
(a) Time-Frequency Differential Coding
In this method, every element of the two dimensional matrix say, Ni,j is time, frequency and time-frequency differentially coded (i.e)
Ni,j=Ni,j−(Ni−1,j+Ni,j−1−Ni−1,j−1)
where Ni,j represents the value in the Time-Frequency matrix at ith frequency and jth time instant.
(b) Time Differential Coding
In this method, every element of the two dimensional matrix say, Ni,j is only time differentially coded (i.e)
Ni,j=Ni,j−Ni,j−1
(c) Frequency Differential Coding
In this method, every element of the two dimensional matrix say, Ni,j is only time differentially coded (i.e)
Ni,j=Ni,j−Ni−1,j
(d) No Differential Coding
As the name suggests, no differential coding is done and the individual values are quantized and Huffman coded.
All the above schemes are compared based on their bit demand and the one with the least bit demand is chosen to code the Time-Frequency envelope. This coding produces at plurality of utility coefficients signifying the magnitude for a specific time-frequency coordinate.
The above coding scheme applies equally both for a stereo and a mono file, the above coding schemes are applied to individual images on a stereo file. In addition to the above coding method stereo files are R-L diff coded, to lower the bit demand. In a stereo file R-L diff coding is performed first followed by any of the above coding schemes.
R-L differential coding exploits the temporal similarity of the left and right image of a stereo waveform. In this coding technique Left and Right images are differenced and halved and is stored as the new Left image of the stereo audio and the Left and Right images (from the original audio) are averaged and stored onto the Right image. See
Table 1 shows five default configurations (modes) controlling the assignment of tasks between the FSSM and ASR model as well as a corresponding adjustment in the role of the MBTAC process. It will be noted that the modes are listed in descending transmission bit rate (second column). Also, the top three modes (ST1 through ST3) use a bandwidth expansion range that is 50% of the overall bandwidth (half the sampling frequency fs) produced by the analysis block 10 (
In mode ST1 the ASR model handles secondary harmonics and isolated tones. In mode ST2 the ASR model handles tonal components. In modes ST3 and ST4, the ASR model handles isolated tones. In mode M1 there is no ASR model functioning. In each of these modes, components that are not handled by the ASR model are handled by the FSSM model.
In modes, ST1, ST3, and ST4 full MBTAC compensation is provided down to the indicated frequency and will handle both the right and left channel (full stereo). In modes ST3 and ST4 MBTAC compensation will be provided to even lower frequencies but this compensation will only correct the ratio (dB difference) between the right and left channels (or equivalently the sum and difference channels often used to represent two stereo channels). In mode ST2 essentially MBTAC compensation is absent and instead some magnitude information is sent along with the ASR and FSSM data indicating magnitudes at least for certain frequency bands. Finally, in monaural mode M1 the MBTAC operates down to 2 kHz. It will be noted that bit rate options are provided to blocks 16, 20, 44 and 46 by a user-controlled options block 50.
BWE Decoder
Referring to
FSSM reconstruction in block 62 is applied on a spectrum that was flattened at the encoder (
ASR reconstruction at the decoder in block 64 involves synthesizing (with a synthesizer in block 64) the harmonic structure and high frequency tonals contained in the encoded information from block 54. The synthesized sinusoids are processed in block 68 (being converted from ODFT to MDCT) and combined in harmonization block 70 with the FSSM full band spectrum from block 62 before being sent to summation node 58. Also, information from decoder block 54 indicating the desired shape of a synthetic noise spectrum is also combined in node 58 with the FSSM and ASR components from block 70 to reconstruct the original spectrum. In block 60 the MDCT coefficients are inverted into a time-domain signal.
In addition, MBTAC parameters passed from block 54 to compensation blocks 72 and 74 (having a inserter and restorer) ensure that the temporal envelope of the original signal is maintained after the reconstruction from the bandwidth extension technique. Adjustment of this temporal envelope is performed in blocks 72, 74, and 76.
MDCT to ODFT Transformation
Returning again to block 54, an MDCT to ODFT transformation proceeds as follows:
The coefficients of an MDCT filter bank can be decomposed as complex ODFT filter bank. The ODFT representation provides magnitude and phase information. MDCT to ODFT and ODFT to MDCT transformation is as given below:
where XM(K) is MDCT of the input sequence x(n) and h(n) the windowing function and n0=½+N/4.
Taking 0 <K <NI2-1 it can be shown that, XM (K)=9(X0 (k))cos E(K) +3(XO(K))sin 0(K) where, XO(K) is ODFT of x(n) and
ODFT of a sequence x(n) is defined as,
Similarly, a transformation of the MDCT domain to the aliased ODFT domain can be obtained by computing:
XO (k)=2 [XM (K) * cos O(K) +j XM (K) sin 0(K)] where j=V-- and
Aliasing iss cancelled in the overlap-add operation following inverse ODFT computation:
with 0<n<N-1 and XO(K)=X*(N-1-K) with O<K<N/2-1. ASR Analysis:
The purpose of this ASR analysis at the decoder is to create a cleaner baseband from which FSSM synthesis described below can proceed. This aids in avoiding interference between FSSM synthesized components and ASR synthesized components when both the models are in use. Referring to
The content of the ODFT spectrum lock 78 may be thought of as a signal, which if converted to the time-domain, would be represented as follows:
where, Xlo,pss is the lowpass, time-domain signal of interest and nIK1/2<fo Vn.,K,. ASR processing in block 80 involves identifying the values of An K,, ni and K,. Also, ft in the above inequality is the cut-off frequency of the spectrum. Upon identifying the harmonics, node 82 eliminates the harmonics in order to smooth the spectrum to one suitable for FSSM processing. In the time-domain, this smoothing process can be considered
After this smoothing process, the ODFT components are converted back to MDCT components in block 84. FSSM Reconstruction:
The flattened low pass spectrum is now extended using FSSM's adjusted pairs of dilation and translation parameters, 1, fi, which were extracted from the bitstream in decoder block 54 and sent to FSSM synthesizer block 86, which includes a relocator. The concept of reconstruction of FSSM from a low band signal is illustrated in
Specifically, the spectral components in the MDCT base band are multiplied by a first dilation (frequency scaling) parameter 1 and then shifted by a first frequency translation parameter f1. All relocated components (such relocated components being referred to as altered coefficients were altered primary coefficients) that fall beyond the base band are used to create a first FSSM reconstructed sub-band, which is added to the base band to form a first composite band. This first composite band is then subjected to a second dilation parameter 2 before being shifted by a second frequency translation parameter f2. All components relocated thereby (by the relocator) that fall beyond the first composite band are used to create a second FSSM reconstructed sub-band; which is added to the first composite band to form a second composite band. This process is repeated iteratively for all remaining adjusted pairs of dilation parameter and frequency translation parameters to create the FSSM extended band through a growing sequence of composite bands.
After FSSM reconstruction, high band frequencies are normalized coded to maintain the temporal envelope of the original flattened spectrum.
ASR Synthesis:
To reconstruct the original spectrum, the flattened full band signal from block 86 must be supplemented with harmonics and HF tonals, which were ASR coded at the encoder. ASR synthesis proceeds by using the information in the incoming encoded signal that signifies one or more fundamental frequencies and, where applicable, a phase signal. Specifically, fundamentals are identified by ASR information that is sent from block 54 to block 88, with the actual ODFT representation of that fundamental being sent from block 78 to block 88.
Each such fundamental frequency is multiplied in frequency by all the integers between a start and a stop integer to construct harmonics in the extended band (that is, synthesize harmonically related transform coefficients based on the harmonic parameters relayed from block 54). Since ASR works with ODFT components, phasing information is included to maintain proper phasing from harmonic to harmonic. In some cases the incoming encoded signal also includes information about a single tonal (essentially a single sinusoid without harmonics).
In some embodiments the incoming encoded signal includes magnitude information that is used to adjust the magnitude of the synthesized harmonics. In other embodiments, however, no magnitude adjustment is performed except for such adjustment that may be performed in the MBTAC process described hereinafter.
The phase continuity of the tonals/partials is ensured by maintaining the phase of the tonal in co-ordination with previous frame's phase, if any were present, else, a null value is assigned to that particular phase value of the tonal. Using a time-domain representation, the signal may be deemed:
(in case of non-harmonic tonals only the first partial corresponding to n1=1 will be synthesized where, φprev.n
All the ODFT components produced by block 88 are converted in that block to MDCT components which are then combined with the FSSM model components from block 86 before being forwarded to block 60 where they are converted from MDCT components to the time domain.
MBTAC Decoder:
Essentially, the MDCT components from block 88 may be considered to have high frequency resolution but its frequencies correspond to a relatively long standard time interval. For the application of MBTAC a higher time resolution is necessary. Therefore, the time domain signal from block 60 is processed by the UFB of block 72 into a number of local coefficients in the time-frequency plane to create a time-frequency matrix that is as fine as the matrix that was created by the encoder UFB analysis.
Desired RMS values of the time-frequency grouped UFB output samples are calculated from the log quantized MBTAC RMS parameters in the incoming encoded signal. Inverse differential coding based on the method chosen at the encoder is done. Inverse R-L differential coding is applied for a stereo signal to recover the R and L RMS values.
Inverse correlation coding is then performed at the decoder to reverse the third level of frequency grouping (in case this was done at the encoder). This is performed by first computing the pilot sequence envelope information from the UFB sub-bands which correspond to the baseband and then determining the corresponding higher frequency envelope by scaling the pilot sequence envelop with the transmitted distance parameters as described above (employing the above noted inserter and restorer). After this is done an inversion of the second level of Time-Frequency grouping, described above is done to fill all Time-Frequency bands. The purpose of this inversion is generate a set of N×M target RMS values for the UFB samples. The partitioning N×M is identical to the partitioning used by the encoder MBATC processor after first level of grouping. Since due to the second-level of grouping only a reduced number of RMS values were coded and transmitted to the decoder (and made available to block 74 by block 54), these values are then mapped to the original N×M grid to determine the desired RMS value at each of these grid point.
The ratio of the desired block RMS computed above and that of the reconstructed spectrum for every time-frequency block (i.e. each point of the N×M grid) is then computed in block 74 and used to scale the complex reconstructed time-frequency UFB samples for that time-frequency block. This ensures, that the envelope of the original spectrum is restored (using the above mentioned restorer) to desired accuracy. The above spectrum is then UFB synthesized in block 76 to regain the time domain signals.
After these components are adjusted by the MBTAC process, the components of the base band and the extended band are now inverted in block 76 to produce the final corrected time-domain signal.
Obviously, many modifications and variations of the present invention are possible in light of the above teachings. It is therefore to be understood that within the scope of the appended claims, the invention may be practiced otherwise than as specifically described.
This application claims the benefit of U.S. Provisional Patent Application, Ser. No. 60/724,856, filed 7 Oct. 2005, the contents of which are hereby incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
60724856 | Oct 2005 | US |