The read channel 10 includes an analog-to-digital converter (ADC) 12, a variable-gain amplifier (VGA) 14, an interpolated-timing-recovery circuit (ITR) 16, a finite-impulse-response filter (FIR) 18, a Viterbi detector 20, and a phase-error detector (PE) 22. The ITR 16, FIR 18, Viterbi detector 20, and PE 22 form a timing loop (TLP) 24 for phase acquisition and tracking. The read channel 10 may also include other components that are omitted from
The ADC 12 generates raw digital samples S of the read signal in response to a sample clock that is unsynchronized to the read signal, and the VGA 14 adjusts the amplitudes of the raw samples S such that these amplitudes are within a predetermined range that is suitable for the ITR 16, FIR 18, and Viterbi detector 20. Furthermore, although the sample clock is unsynchronized to the read signal, it typically has the same or approximately the same frequency as the data carried by the read signal.
The ITR 16 interpolates the gain-adjusted samples according to a target polynomial (e.g., PR4, EPR4 and E2PR4) that corresponds to the characteristics of the read signal and according to a phase-interpolation value Tau that is related to the phase error between the read signal and the sample clock. Generally, the ITR 16 interpolates each gain-adjusted raw sample by causing the amplitude of the interpolated sample to equal (or approximately equal) the amplitude that the gain-adjusted raw sample would have had if the sample clock were in-phase (phase error=0) with the read signal. That is, the ITR 16 effectively shifts the phase of the interpolated sample by Tau relative to the phase of the gain-adjusted raw sample.
The FIR 18 equalizes the interpolated samples according to the target polynomial. The topology and filter coefficient(s) of the FIR 18 provide the FIR with a transfer function that corresponds to the target polynomial. That is, the transfer function causes the FIR to “fit” the interpolated samples to the target polynomial.
The Viterbi detector 20 recovers data from the read signal according to the target polynomial.
The PE 22 acquires and tracks the phase error between the sample clock and the data carried by the read signal, generates the phase-interpolation value Tau in response to the phase error, and provides the phase-interpolation value Tau to the ITR 16. For example, the PE 22 may generate Tau equal (or approximately equal) to the phase error, although in most instances, Tau does not equal the instantaneous phase error due to the latency of the TLP 24.
Still referring to
An embodiment of a read channel includes a filter, an interpolator, a recovery circuit, an error detector, a reverse interpolator, and a filter calibrator. The filter is operable to receive a raw sample of a signal and a coefficient-correction value, generate a filtered sample from the raw sample and a pre-established coefficient, and change the coefficient in response to the coefficient-correction value. The interpolator is operable to interpolate the filtered sample, and the recovery circuit is operable to generate a data symbol from the interpolated sample. The error detector is operable to generate an ideal sample from the data symbol and to generate a difference between the ideal sample and the interpolated sample, and the reverse interpolator is operable to reverse interpolate the difference. The filter calibrator is operable to receive the raw sample and to generate the coefficient-correction value from the raw sample and the reverse-interpolated difference.
Because in such a read channel the filter is located before the interpolator, and thus is outside of the timing loop, the latency of the loop is reduced, and thus the bandwidth of the loop is increased, as compared to the timing loop of the read channel 10 (
Furthermore, the reverse interpolator and calibrator allow calibration of the filter coefficient(s) even though the filter is located before the interpolator—techniques for calibrating the coefficient(s) of a filter that is located after the interpolator are typically unsuitable for calibrating the coefficient(s) of a filter that is located before the interpolator.
In addition to the ADC 12, VGA 14, ITR 16, Viterbi detector 20, phase-error detector 22, FIR 32, and TLP 34, the read channel 30 includes a sample-error detector 36, a reverse interpolator (RITR) 38, and an FIR calibrator 40 for calibrating the coefficients of the FIR 32 according to an embodiment of the invention.
The FIR 32 may be similar to the FIR 18 of
The TLP 34 includes the ITR 16, Viterbi detector 20, and the phase-error detector 22. Like the TLP 24 of
The sample-error detector 36 calculates respective differences, i.e., error values, between the interpolated samples from the ITR 16 and the corresponding ideal samples. The target polynomial for which the read channel 30 is designed relates a data symbol (e.g., a data bit) generated by the Viterbi detector 20 to the sequence of ideal read-signal samples that represent the data symbol as discussed in U.S. Pat. Nos. 6,492,918, 6,587,059, 6,662,338, and 6,604,204, which are incorporated by reference. The sample-error detector 36 may obtain the ideal samples by solving the target polynomial for each data symbol generated by the Viterbi detector 20, or by storing the ideal samples in a look-up table (LUT). Furthermore, the sample-error circuit 36 conventionally accounts for the latency between the output of the ITR 16 and the output of the Viterbi detector 20 so as to associate the ideal sample generated for the current data symbol with the interpolated sample corresponding to the current data symbol.
The RITR 38 generates reverse-interpolated error values E by reverse interpolating the error values from the sample-error detector 36. The RITR 38 performs this reverse interpolation by effectively removing the phase correction that the ITR 16 imparts to the interpolated samples. Because the FIR 32 is on the input side of the ITR 16, the FIR 32 filters samples that have not yet been phase corrected by the ITR 16. Therefore, to accurately calibrate the coefficients of the FIR 32, the calibrator 40 uses the reverse-interpolated error values E from which the ITR phase correction has been removed. Depending on the accuracy of the RITR 38, this removal of the phase correction may be complete or partial. The operation of the reverse interpolator 36 is further discussed below in conjunction with
The FIR calibrator 40 includes a sample memory 42, an error memory 44, and a calculator 46. The sample memory 42 stores n raw samples S1-Sn of the read signal from the ADC 12. For example, the sample memory 42 may store raw samples S1-Sn from an entire data sector of a storage disk (not shown in
Still referring to
The ADC 12 generates raw digital samples S1-Sn of the read signal, which typically carries data that is divided into one or more blocks each having a predetermined size. For example, if the read channel 30 is part of a disk drive system (not shown in
The VGA 14 amplifies the samples S1-Sn, and the FIR 32 equalizes the amplified samples to the target polynomial.
The ITR 16 corrects the phase of the equalized samples in response to the phase-interpolation value Tau (this phase correction may be full or partial), and the Viterbi detector 20 recovers the data symbols from the phase-corrected samples.
The phase-error detector 22 tracks the phase error between the data carried by the read signal and the sample clock, and updates the phase-interpolation value Tau as appropriate to maintain the phase error at a suitably low value, e.g., less than 5% of the period of the sample clock.
While the VGA 14, FIR 32, ITR 16, Viterbi detector 20, and phase-error detector 22 are operating as described above, the sample-error detector 36 is generating respective differences between the phase-corrected samples from the ITR 16 and the corresponding ideal sample values. Furthermore, the RITR 38 is generating the reverse-interpolated error values E1-En from the respective differences generated by the sample-error detector 36, and the FIR calibrator 40 is storing the samples S1-Sn in the sample memory 42 and the reverse-interpolated error values E1-En in the error memory 44. The operation of the RITR 38 is further described below in conjunction with
While or after the FIR calibrator 40 stores S1-Sn in the memory 42 and E1-En in the memory 44, the calibrator calculates the coefficient-correction values F1-Fm, which the FIR 32 uses to update its coefficients C1-Cm so as to reduce the mismatch between the read channel 30 and the read signal. The ITR 16 would generate the interpolated samples equal to the ideal samples if the following ideal conditions existed: 1) there were no noise on the read signal, 2) the TLP 34 were perfectly tracking the phase error between the sample clock and the data carried by the read signal, and 3) the ITR and the FIR 32 were perfectly matched to the read signal. But because these ideal conditions typically do not exist, the interpolated samples that the ITR 16 generates typically differ from the corresponding ideal samples. The respective differences between the interpolated samples and the ideal samples (the sample-error detector 36 generates these differences as discussed above) are related to the mismatch between the read channel 30 and the characteristics of the read signal. By calibrating the coefficients of the FIR 32 to reduce or eliminate the respective error differences between the interpolated and ideal samples, the calibrator 40 reduces or eliminates the mismatch between the read channel 30 and the read signal. This calibration, however, need not take place in real time; therefore, the FIR calibrator 40 may generate F1-Fm at any time, such as while the ADC 12, VGA 14, FIR 32, ITR 16, Viterbi detector 20, and phase-error detector 22 are idle.
The FIR calibrator 40 may periodically recalculate the coefficient-correction values F1-Fm so as to track the read channel 30 to the read signal over time—the characteristics of both the read signal and the read channel may change over time in response to, e.g., environmental changes (e.g., temperature), aging of the components that form the read channel 30, and aging of the data-storage disk (in a disk drive). For example, if the read channel 30 is part of a disk drive, the FIR calibrator 40 may recalculate F1-Fm, e.g., every data sector or every ten data sectors. The operation of the FIR calibrator 40 is further described below in conjunction with
Still referring to
Ek=Einterpolated
where Einterpolated
Referring to
Referring to
The FIR calibrator 40 calculates the coefficient-correction values F1-Fm according to the following modified Weiner equation:
F=Rx, fx-y·Rxx−1 (2)
where F is a vector having the elements F1, F2, . . . , Fm, m is the number of coefficients C in the FIR filter 32, Rx,fx-y is the cross correlation of the sample vector S (having the elements S1, S2, . . . , Sn) and the reverse-interpolated-error vector E (having the elements E1, E2, . . . , En), and Rxx is a matrix derived from the auto-correlation of the vector S.
Referring to
Ri=S1Si+S2Si+1+S3Si+2+S4Si+3+S5Si+4+ . . .+Sn-m+1Sn-m+i (3)
where S1, S2, S3, . . . , Sn are the elements of the sample vector S.
Referring to
Rxx=Toeplitz(R) (4)
where the Toeplitz function is a well-known function for converting a 1×y vector to a y×y matrix.
Referring to
Rx, fx-y−1=SISTEi+SIST+1Ei+1+SIST+2Ei+2+SIST+3Ei+3+SIST+4Ei+4+ . . .+Sn-IST+2En-m+i (5)
where IST=m/2+1 (IST is the position of the center-tap coefficient of the FIR filter 32 of
Referring again to
Ci
where Ci
Still referring to
Referring to
If the RITR 38 uses linear reverse interpolation to calculate E has described above in conjunction with
Referring to
First, the FIR calibrator 40 calculates the vector F according to equation (2) and as otherwise discussed above in conjunction with
Next, the FIR calibrator 40 calculates a first intermediate 2×m matrix D according to the following equation:
D=(┌φT·Rxx−1·┌φ)−1 (7)
where Rxx is calculated according to equation (4) and as otherwise discussed above in conjunction with
Then, the FIR calibrator 40 calculates a second intermediate 1×m matrix ΔD according to the following equation:
ΔD=−D·┌φT·FT (8)
Next, the FIR calibrator 40 calculates a modified 1×m coefficient-correction vector F′ according to the following equation:
F′=F+round[(Rxx−1┌φ·ΔD)T] (9)
where the round function respectively rounds off each of the elements of the resulting vector within the brackets to the nearest integer.
Then, after the FIR calibrator 40 calculates the modified coefficient-correction vector F′, the calibrator provides F′ to the FIR 32, which updates the FIR coefficients C1-Cm according to the following equation:
Ci
where equation (10) is derived by replacing Fi in equation (6) with Fi′ from equation (9). Consequently, the updated coefficients Ci
Still referring to
The disk drive 52 also includes write and read interface adapters 74 and 76 for respectively interfacing the write and read controllers 58 and 60 to a system bus 78, which is specific to the system used. Examples of system busses include, e.g., ISA, PCI, S-Bus, Nu-Bus.
The computer system 50 also typically includes other devices, such as a random access memory (RAM) 80 and a central processing unit (CPU) 82 coupled to the bus 78.
Still referring to
From the foregoing it will be appreciated that, although specific embodiments have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the invention. Furthermore, where an alternative is disclosed for a particular embodiment, this alternative may also apply to other embodiments even if not specifically stated.
This application claims priority to U.S. Provisional Application Ser. No. 60/776,256, filed on Feb. 24, 2006, which is incorporated by reference.
Number | Date | Country | |
---|---|---|---|
60776256 | Feb 2006 | US |