The present invention pertains generally to processing digital signals and pertains more specifically to converting the sample rate of a digital signal.
An increasing number of devices including professional and consumer video and audio devices contain circuitry that processes digital signals. The signals that need to be passed between components of these types of systems are often digital rather than analog. Unfortunately, many of these components require signals that have different sample rates. Differences in sample rate can occur even between devices that use the same nominal rate if those devices operate with digital clocks or oscillators that differ in frequency. These differences may vary over time.
In situations where the output signal of one device is intended to be the input signal of another device, it is often necessary to convert the sample rate of the signal so that the two devices can work together. For ease of discussion in this disclosure, the signal whose sample rate must be converted is referred to as the “source signal” and its sample rate is referred to as the “source sample rate.” The desired signal to be obtained by sample-rate conversion is referred to as the “destination signal” and its sample rate is referred to as the “destination sample rate.”
Two ways that are known to convert the sample rate of a digital signal are known as “rational ratio sample-rate conversion” and “asynchronous sample-rate conversion.”
Rational ratio sample-rate conversion can be used when the source sample rate and the destination sample rate are related to one another by a ratio that can be expressed as a constant rational factor. For example, the ratio of the sample rates for signals sampled at 48 kHz and 44.1 kHz can be expressed as the rational factor F=48000/44100=160/147.
Asynchronous sample-rate conversion is a more complex process that can be used when the ratio between the source sample rate and the destination sample rate is not constant. This conversion process must continually assess the ratio between source and destination rates and adapt the conversion process accordingly. This process can be used in situations where the sample rate of either or both signals varies over time.
The remainder of this disclosure is directed primarily to asynchronous sample-rate conversion techniques but principles of the present invention may also be applied to rational ratio sample-rate conversion techniques.
A variety of integrated circuits are available that can convert the sample rate of a digital signal. One example that is suitable for use with audio signals is the SRC4193 chip that is available from Texas Instruments Incorporated, Dallas, Tex. This device is typical of other devices that are available from other manufacturers. It can receive one or two digital signals having sample rates within a wide allowable range and convert the sample rate up or down to provide one or two digital signals having sample rates within a wide allowable range. It has features that are intended to facilitate its use in many practical situations including source and destination sample rates that may vary continuously and may be independent of the chip clock frequency.
The sample rate converter that is implemented in the SRC4193 chip as well as in other known chips use finite impulse response (FIR) filters. In essence, each destination signal sample is generated by applying a low-pass filter to the source signal samples. The cutoff frequency (FC) of the low-pass filter is typically set equal to the lesser of one-half the source sample rate (½ FS,IN) and one-half the destination sample rate (½FS,OUT). This can be expressed as:
This type of conversion is often difficult to implement because the cutoff frequency of the low-pass filter is linked to the source sample rate when the sample rate is converted upwards but is linked to the destination sample rate when the sample rate is converted downwards. One implementation uses two low-pass filters. One low-pass filter with a cutoff frequency FC1=½ FS,IN is used to interpolate source signal samples up to a higher intermediate sample rate. The other low-pass filter with a cutoff frequency FC2=½ FS,OUT is used to decimate the intermediate samples down to the destination sample-rate. In the SRC4193 chip, for example, the first low-pass filter interpolates up to a rate that is sixteen times the source sample rate and the second low-pass filter decimates down to the destination sample rate.
In addition to the difficulties explained above, the FIR implementation is not attractive in many applications because it requires a large amount of memory to store filter coefficients. In typical implementations, the FIR filters are used to compute destination signal samples that are delayed by fractions of a sample interval. The amount of the delay must be precise and stable to provide an accurate sample rate conversion and to avoid jitter-related noise in the destination signal. The necessary high time-resolution of the filter can be achieved if a set of filter coefficients for each possible delay is available. A large amount of memory is needed to store all of these coefficients. Alternatively, interpolation can be used with a smaller number of coefficient sets but much memory is still required because FIR filter coefficients generally cannot be determined accurately by interpolation between two sets of coefficients that represent widely-spaced events.
It is an object of the present invention to provide high-quality sample rate conversion that can adapt to changes in source and destination sample rates and that requires much less memory than conventional techniques.
According to the present invention, sample-rate conversion may be implemented using a discrete-time digital simulation of a continuous-time analog filter. This approach allows sample-rate conversion filters to be implemented with a very high time resolution without need for large amounts of memory to store tables of coefficients.
The various features of the present invention and its preferred embodiments may be better understood by referring to the following discussion and the accompanying drawings in which like references refer to like elements in the several figures. The contents of the following discussion and the drawings are set forth as examples only and should not be understood to represent limitations upon the scope of the present invention.
Referring to the example shown in
It has been found that the time resolution should be accurate to about twenty-four bits if a sample-rate converter is required to give twenty-four bits of accuracy in the destination signal samples. For the example shown in
In practice, the coefficient tables are not this large. Various techniques such as interpolation are used to reduce the number of entries that must be stored; however, memory requirements are still impractical for many applications. In addition, these techniques require computational resources to calculate the desired coefficients and they can introduce errors into the coefficients.
The present invention works differently. A discrete-time digital system is used to simulate a continuous-time analog filter, which allows the time resolution of the filter to be set to essentially any desired amount. The system, which simulates the state of complex poles in the analog filter, can process source and destination signal samples at arbitrary times because the state of the filter can be advanced in arbitrarily small fractions of a sample interval. This process is illustrated schematically in
A sample-rate converter that is implemented according to teachings of the present invention is capable of providing a variety of features that include the ability to convert between source and destination sample rates that can vary continuously and are independent of the converter clock frequency. These features are not discussed further because they are not needed to understand the present invention.
Preferably the analog filter has a low amount of ripple in its pass-band and a large amount of attenuation in its stop-band with a roll off in the stop-band at a rate of at least 12 dB per octave so that the filter gain is zero at s=∞. The transfer function of a suitable filter is shown in
This composite tenth-order filter has five pairs of conjugate poles. Its transfer function can be expressed in the s domain as:
Because the gain of this filter is zero at s=∞, the coefficient K=0, which simplifies the transfer function as follows:
This transfer function may be implemented by a digital simulation using a sampling interval τs that ensures the sampling frequency Fs is much larger than the frequency of the largest pole Pi. For example, the sampling interval may be set to a very small value such as one nanosecond. This is an extremely high sample rate as compared to the rates encountered in typical audio applications, for example, but it is only of mathematical significance. Because the sampling frequency is very high, the approximation s=log(z)/τs is reasonably accurate and the z-domain poles p1, . . . p5 can be mapped to the s-domain poles P1, . . . P5 by the expression Pi=log(pi)/τs. Furthermore, for values of z and pi very close to unity, the approximation log(z)≈z−1 also holds.
Using these approximations and mappings, the term (s−Pi) can be rewritten as (log(z)/τs−log(pi)/τs), which can be approximated by ((z−1)/τs−(pi−1)/τs), and this can be simplified to be (z−pi)/τs. This allows the transfer function to be expressed as:
which can be rewritten as:
This filter can be implemented by a discrete-time digital system such as the one shown in
Each filter section can also be represented by two difference equations. The first difference equation represents the input/state portion of filter section operation that receives source signal samples and updates state variables. The second difference equation represents the output portion of filter section operation that computes destination signal samples. The first difference equations for all sections in the filter can be written as the matrix and vector operations shown in expression 5 and the second difference equations for all sections can be written as shown in expression 6:
Expression 5 can be rewritten in a more compact notation shown in expression 7:
State(n+1)=P×State(n)+2×R×x(n)×τs (7)
In principle, each section of the filter shown in
A simulation of filter operation for arbitrary arrival times of source signal samples and arbitrary output times of destination signal samples can be obtained by rewriting the input process as shown in expression 8, the state-update process as shown in expression 9 and the output process as shown in expression 10:
State(t)State(t)+R×x(t)×2τin (8)
State(t+Δt)PΔt/τ
where Δt=the interval of time between two consecutive events (input sample arrival or output sample generation events). These expressions allow both t and Δt to have arbitrary real values that are independent of the sampling interval τs.
A simulation of this analog filter for a source signal with a sample interval τin can be implemented by the following process in which operations 2, 3 and 4 are performed after initialization and independently of one another as needed:
The three basic parts of this process as shown in expressions 8 through 10 are illustrated schematically in
The steps of this process that perform the example shown in
In this example, the time interval between adjacent source signal samples is equal to τin. The time interval between adjacent destination signal samples is equal to τout, where τout=1.151τin. The two destination signal samples shown in
The need to operate the filter with a high time resolution requires the ability to compute the state-update factors PΔt with high accuracy. A simple implementation that stores all of the needed values in a look-up table would require an extensive amount of memory. The amount of memory can be reduced significantly by a slightly more complex process that takes advantage of the following identity:
P
a+b
=P
a
×P
b (11)
This identity allows a high-resolution system to be implemented using a few small tables. For example, the value for P0.527 can be computed by the following:
P
0.527
=P
0.5
×P
0.02
×P
0.007
The first two terms in this expression can be stored in look-up tables. One look-up can store values for a coarse resolution such as 0.1. This table would store the values for P0.0, P0.1, P0.2, . . . P0.9. Another look-up table can store values for a finer resolution such as 0.01. This table would store the values for P0.00, P0.01, P0.02, . . . P0.09.
The finest resolution could be stored in a third table in the same manner or it can be computed using the following approximation:
P
aΔn≈1+a(PΔn+1) (12)
By setting Δn=0.001, the constant Pi0.001 can be computed for each pole Pi of the filter and stored for later use. The value needed for the resolution 0.001 can be obtained from expression 12 using the values a=0, 1, 2, . . . 9. If desired, a can be allowed to take on a fractional value such as 3.1459 to obtain essentially any desired time resolution.
The examples discussed here are expressed with decimal numbers to aid in understanding. These principles can be extended to other base-number systems such as base-2 or binary systems used by many digital computers. Empirical tests with audio applications suggest the look-up table should have a time-resolution of about 512 steps per audio signal sample interval. This resolution can be achieved in a number of ways including one single look-up table with 512 entries, two look-up tables with thirty-two and sixteen entries (because 32×16=512), or some other combination of tables having a number of entries whose product equals or exceeds 512.
In a preferred implementation, the time for each signal sample is determined with a resolution of twenty-four bits, which is sufficient to allow filter processing to have a signal-to-noise ratio better than 120 dB. The nine most significant bits of the time measurement can be processed using one or more look-up tables to compute a partial product PΔt and the factor representing the remaining fifteen bits can be obtained by interpolation as explained above.
As explained above, the implementation shown in
A sample-rate converter that is implemented according to the present invention can improve the fidelity of the destination signal by including an additional correction filter to improve the overall transfer function so that it has a flatter frequency response and reduced phase shift in the pass-band. Empirical tests have shown that a sixty-four tap FIR filter can be used to reduce pass-band ripple to less than 0.1 dB.
Examples of sample-rate converters that are implemented according to teachings of the present invention are illustrated in
Referring to
The Phase Locked Loop receives word-clock timing extracted by the “WClk In” block from one of the “AES In” blocks or, alternatively obtained from an external word-clock input, and generates a high-speed clock that is nominally at 45.1584 MHz. Preferably, the Phase Locked Loop uses an external voltage controlled crystal oscillator (VCXO) to provide a low-jitter clock with high accuracy.
A digital phase locked loop (Digital PLL) takes the clock generated by the Phase Locked Loop and computes an accurate estimate of the arrival time of each input signal sample, which also corresponds to the precise output time for each output signal sample. The arrival/output time estimate for a sample is referred to here as “Precise Event Time.”
The “Coef ALU” block uses the Precise Event Time of each input/output sample to compute the filter coefficients required by the “Input SRC” and “Output SRC” blocks to perform sample-rate conversions.
The “Input SRC” block converts the sample rate of each input signal sample using the sample-rate conversion process illustrated in
The “Output SRC” block converts the intermediate signals having a sample rate of 96 kHz into output signals having a sample rate of 44.1 kHz, which are passed to respective “AES OUT” blocks. The “Output SRC” block implements the sample-rate conversion process illustrated in
The “AES OUT” blocks receive signal samples from the “Output SRC” block and produce two-channel audio output signals that conform to AES standard AES3-2003. This block uses the low-jitter 45.1584 MHz clock generated by the Phase Locked Loop.
The “Coef ALU” block is provided with the Precise Event Time of each input signal sample and this Precise Event Time is broken into an integer part and a fractional part. For example, referring to
InWeighti=2RiτinP(1−Δf)
For the “Output SRC” block, the coefficients needed by the sample-rate conversion filter are five complex values that are computed as follows:
OutWeighti=PΔf
Devices that incorporate various aspects of the present invention may be implemented in a variety of ways including software for execution by a computer or some other device that includes more specialized components such as digital signal processor (DSP) circuitry coupled to components similar to those found in a general-purpose computer.
In embodiments implemented by a general purpose computer system, additional components may be included for interfacing to devices such as a keyboard or mouse and a display, and for controlling a storage device 78 having a storage medium such as magnetic tape or disk, or an optical medium. The storage medium may be used to record programs of instructions for operating systems, utilities and applications, and may include programs that implement various aspects of the present invention.
The functions required to practice various aspects of the present invention can be performed by components that are implemented in a wide variety of ways including discrete logic components, integrated circuits, one or more ASICs and/or program-controlled processors. The manner in which these components are implemented is not important to the present invention.
Software implementations of the present invention may be conveyed by a variety of machine readable media such as baseband or modulated communication paths throughout the spectrum including from supersonic to ultraviolet frequencies, or storage media that convey information using essentially any recording technology including magnetic tape, cards or disk, optical cards or disc, and detectable markings on media including paper.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US07/01472 | 1/18/2007 | WO | 00 | 7/16/2008 |
Number | Date | Country | |
---|---|---|---|
60759897 | Jan 2006 | US |