This invention relates to electronic devices, in particular to circuitry and methods for the conversion of digitally sampled data. The invention can be used in all fields in which the sample rate of a stream of data has to be changed, and particularly in audio systems and video systems. Another application is the adaptation of the sampling rate of the base band signal to the high sampling rate of a digital modulator in a telecommunication system, e.g. ADSL.
Digitally sampling analog signals such as audio signals or video signals is generally known. When processing the sampled signals it is often desirable to mix sampled data having different sample rates. For that purpose a sample rate conversion is necessary in which the sampled signal is converted from a first sample rate to a second sample rate. As an example, audio signals are often sampled at rates of 11.025, 22.05 or 44.1 KHz, or at rates of 8, 16, 32, or 48 KHz. Converting a signal from 8 KHz to 11.025 KHz means applying a sampling factor of 441/320, which needs complex converters in order to avoid a degradation of the signal quality.
Sample rate converters can be categorized in synchronous sample rate converters and asynchronous sample rate converters. In the first case the sampling factor, which is the ratio of the output sampling rate and the input sampling rate, is a rational number such as 441/320. In the latter case the ratio cannot be expressed by a rational number.
U.S. Pat. No. 5,907,295 discloses a synchronous sample rate converter (SSRC). The SSRC being used is a two-stage converter. A first stage is an L-tap low-pass FIR, and the second stage is a linear interpolator. The first stage adjusts the sampling rate by a factor of Q0/P0 and the second stage by a factor of Q1/P1, such that the overall sampling factor is Q/P=Q0/P0*Q1/P1. Splitting the SSRC into two stages results in a decreased coefficient storage within the L-tap FIR. This SSRC is not suitable for sampling factors smaller than ⅛, or sampling factors larger than 8. Its performance in terms of signal to noise ratio (SNR) is also limited.
U.S. Pat. No. 5,666,299 discloses an asynchronous sample rate converter (ASRC). The number of filter coefficients stored in a ROM are reduced by the design of the ASRC. This ASRC is not suitable for sampling factors smaller than ⅛, or sampling factors larger than 8. Its SNR is also limited.
U.S. Pat. No. 5,638,010 discloses a digitally controlled oscillator (DCO) in a digital phase lock loop, for the synchronization of ASRCs with a high sampling factor. For this purpose, the DCO generates a suited clock signal. It also generates a residue signal, usable for the precise interpolation of data samples. This residue signal is related to the instantaneous phase of the DCO.
In “A Stereo Asynchronous Digital Sample-Rate Converter for Digital Audio”, IEICE Transactions on Electronics, Institute of Electronics Information And Comm. Eng. Tokyo, JP, vol. E77-C (1994), no. 5, pp. 811-818, Adams et al. disclose an asynchronous sample rate converter including an n-tap polyphase filter (2), with n being an integer, and a computational entity (5,9) for calculating the filter coefficients.
It is an object of the invention to provide a high-performance ASRC and a corresponding method for converting a sample rate from a first value to a second value. The ASRC and the method should be usable for oversampled input signals and for very high or very low sampling factors of the converter.
According to the present invention the above-mentioned objects are achieved by providing the features defined in the independent claims. Preferred embodiments according to the invention additionally comprise the features defined in the sub-claims. It should be emphasized that any reference signs in the claims shall not be construed as limiting the scope of the invention.
According to the present invention the above-mentioned objects are achieved by an asynchronous sample rate converter which comprises an n-tap polyphase filter with n being an integer, and a computational entity for calculating the filter coefficients, whereby the computational entity is adapted to use a Parzen window or to use a quadratic window for calculating the filter coefficients.
The corresponding method is a method for converting the sample rate of digitally sampled data from a first sample rate to a second sample rate by using a conventional n-tap filter, whereby the filter coefficients are computed by using a Parzen window or by using a quadratic window.
These and other aspects of the invention will be apparent from and elucidated with reference to the embodiments described thereafter.
The clock signal asrc_clk_in is in general a jittered clock because it is phase synchronous with asrc_clk_out and frequency synchronous with data_in. Typically this clock is generated by means of the DCO of a digital PLL. This DCO uses the same clock signal asrc_clk_out, which synchronizes all registers 6.
The ASRC 1 can be conveniently used when the input data data_in are represented by an oversampled signal. For the purposes of this disclosure an oversampled signal shall be understood to be a signal having a sample rate significantly higher than the minimum sampling rate FMIN. Taking the Nyquist theorem into account the minimum sampling rate FMIN is twice the bandwidth.
Filtering is performed by averaging the sample points from the data registers 6. The sample points are multiplied by the DSP 4 with their corresponding weighing/filter coefficients. The sum of all weighted sample points is outputted by the DSP 4 at an output port 8.
In
There are two ways of generating the filter coefficients.
The first possibility is the generation of the filter coefficients by a computational entity, whereby the computational entity is at a location external to the n-tap polyphase filter 2. This computational entity might be hardware such as a DSP or an application-specific integrated circuit (ASIC), or may be a computer program running on a remote computer.
The second possibility is the generation of the filter coefficients by a computational entity, whereby the computational entity is at a location inside the n-tap polyphase filter 2. In other words the computational entity is part of the n-tap polyphase filter 2. In this case the computational entity is the coefficient generator 5 of
When the first possibility is chosen the n-tap polyphase filter has to provide memory space for the filter coefficients which are generated externally (outside the n-tap polyphase filter). In this case the phase signal is used as the reading address of four independent memory units 7, whereby each memory unit 7 of block 5 holds all the 2P possible values of a specific coefficient, with P=number of bits of the phase signal. For a precise interpolation, for instance with P=9, the required memory in block 5 is 29*4 words. As can be derived from the above explanations, block 5 is a pure memory block in this (first) operation mode. Block 9 can be regarded as the external computational entity.
When the second possibility is chosen, the phase signal is used for the polynomial computation of the filter coefficients by means of a computational entity 5. Typically the phase signal is generated by the DCO of a digital PLL. The four coefficients are Cl=Al*I+Bl*I2+Cl*I3+Dl*I3, whereby l is an index ranging from 1 to 4, and whereby I is the input phase signal.
The coefficients are either calculated on the fly (online calculation), or have been preloaded (offline calculation).
When the second possibility for generating the filter coefficients is chosen the calculation of the filter coefficients is performed in block 5. In this (second) operation mode block 5 is a coefficient generator or computational entity. Details of block 5 serving as a computational entity is visualized by means of block 9. It should be emphasized however that block 9 is merely a representation of block 5, and is not a separate physical entity. Block 9 thus zooms into block 5. The constants Al, Bl, Cl, Dl etc. are retrieved from a small memory unit (not shown). In this example a third order polynomial is chosen, such that a total of 16 coefficients are stored, whereby each coefficient needs a memory space of only 4 words. This solution for the coefficient generator reduces the required memory at the expenses of additional polynomial computations and it is generally better when a very precise interpolation is needed.
The invention uses the Parzen window or the quadratic window as the polynomial smart window. The Parzen window, also referred to as the de la Valle Poussin window, is a third order polynomial and is defined as
whereby n is the index of the time samples, and N+1 is the total length of the window. In the alternative, a quadratic window is chosen. This is a second order polynomial which is defined as
Both windows are shown in the time domain in
Both windows show a better performance (as far as the attenuation at the repetitive notches is concerned) when compared to a triangular window or to a rectangular window. As far as the above mentioned attenuation is concerned the Parzen window is even better than the quadratic window. The performance of the quadratic window is between the Parzen window and the triangular window.
The quadratic window is a smart window because it shows a double symmetry: an even symmetry around y=0, and an odd symmetry around (−N/4, 0.5) and (N/4, 0.5). The latter symmetry is useful when a multiple of four samples are used, because in this case half of the samples can be computed without other multiplications, applying a simple subtraction.
Another advantage of the quadratic window is that it creates secondary notches at middle frequencies. This means that the over-sampling stage enjoys an additional stop-band attenuation.
Still another advantage of the Parzen window and the quadratic window is that their dips in the frequency domain are particularly wide, such that bandwidth requirements at notch frequencies can be easily satisfied. This can be seen with the help of
The above formulae of the Parzen window and the quadratic window cannot be used directly to compute the filter coefficients by using the phase signals, whereby the phase signal might be provided by a DCO. In the case of the quadratic window, the coefficients C1, C2, C3 and C4 are computed as follows:
k is a constant which determines the filter gain, φ is the phase signal from the DCO,
whereby P is the number of bits of the phase signal from the accumulator of the DCO.
In the case of the Parzen window, the coefficients are computed as follows:
Circuit 11 has an input port 7 for input signals having a first sample rate, and an output port 8 for signals having a second sample rate. In this case the input data at port 7 are not oversampled like data_in of
Circuit 11 consists of an interpolation stage 12 with an integer sampling factor and an ASRC 1 as explained above. The interpolation stage 12 may be chosen to be composed of interpolation units 13, whereby each interpolation unit interpolates by a factor of 2. Splitting the interpolation stage 12 into a couple of interpolation units, whereby each interpolation unit interpolates by a factor of 2, has the advantage that the overall design of the circuit 11 becomes simpler. All interpolation units 13 are connected in series. The first interpolation unit 14 is connected to the input port 7, and the last interpolation unit 15 is connected to the ASRC 1. As can be derived from this explanation, the circuit 11 represents an ASRC, being composed of an interpolation stage 12 and a residual ASRC 1.
In the second case the interpolation stage 12 is replaced by a decimation stage 16 with an integer decimation factor (=1/sampling_factor) of at least 4. The decimation stage 16 may be chosen to be composed of decimation units 17, whereby each decimation unit decimates by a factor of 2. All decimation units 13 are connected in series. Furthermore, the residual ASRC 1 is the first stage into which the input signal is fed, and the decimation stage is the second stage outputting the output signal with the second sample rate. In other words port 8 becomes the input port, and port 7 the output port. For reasons of convenience, the following description will not discuss this second case in detail, as the advantages are identical.
The idea of the circuit 11 is to split the ASRC into an interpolation stage 12 with an integer interpolation factor of at least 4 and a residual ASRC. Further advantage is obtained by the split of the stage 12 into multiple interpolation units 13, each one interpolating the sample rate by a factor of 2. The particular advantage of the circuit 11 is that the residual ASRC 1 has to handle a sampling factor which is smaller than without the preceding interpolation stage 12. Therefore the computational burden for the ASRC 1 is decreased. This allows a simpler design for the ASRC 1.
As mentioned above, the ASRC 1 of the present invention is particularly well suited for input signals having a high sampling rate F/FMIN (or low sampling rate in the dual case). A signal with a high sampling rate is provided by the interpolation stage 12 of the circuit 11. The absolute value of F/FMIN which can be chosen mainly depends on two aspects.
One aspect is the design of the circuit 11. On the one hand the design of the ASRC 1 is simplified, and on the other hand the complexity of the circuit 11 is increased by the additional interpolation stage 12. From a practical point of view splitting the total ASRC into an interpolation stage 12 and a residual ASRC 1 may be acceptable if the sampling factor of the interpolation stage 12 is at least 8, such that a separated interpolation by 4 is needed.
A second aspect is the SNR of the ASRC 1 which is acceptable to the user. FIN may denote the input sampling rate of the ASRC 1, FOUT the corresponding output sampling rate, and B may denote the signal bandwidth. The question then is: what is the sampling rate F which must by provided for by the interpolation stage 12 in order to have a desired SNR of the output signal of the ASRC 1, and which window (quadratic or Parzen) should be chosen? Two cases can be distinguished:
Number | Date | Country | Kind |
---|---|---|---|
05000549.5 | Jan 2005 | EP | regional |