Timing recovery system and method

Abstract
Tracking methods and systems for providing timing recovery of continuous signals is presented. According to one embodiment, the method includes: sampling a continuous signal; estimating a timing disturbance of the sampled continuous signal; generating a timing adjustment signal in accordance with the estimated timing disturbance; and adjusting a sampling signal associated with a sampling device based on the timing adjustment signal.
Description


DESCRIPTION OF THE BACKGROUND

[0001] In, for example, hard disk drive (HDD) data storage systems, a continuous readback signal needs to be sampled prior to data detection. Data storage systems, however, introduce time-varying timing disturbances into the continuous readback signal. These delays are due to many factors, including disk speed variation, frequency offset between the different clocks used in the writing and reading processes, and clock wander. As data storage densities are pushed toward one terabit per square inch (1 Tb/in2) and beyond, advanced signal detection algorithms such as iterative soft decoding are being suggested to cope with the lower signal-to-noise ratios (SNRs) and higher inter-symbol interference (ISI) inevitable at these densities.


[0002] In HDD systems, low SNR is a direct consequence of decreased track widths of the recording medium to accommodate increased track density. Unfortunately, at low SNRs, conventional phase-locked loop (PLL)-based decision-directed timing recovery schemes exhibit a large residual timing jitter. Residual timing jitter refers to the residual timing error introduced by the timing recovery system and is the difference between the estimated timing disturbance and the actual timing disturbance in a continuous readback signal as it is processed by the timing recovery system. Large residual timing jitter leads to frequent loss of lock, an event where the estimated timing disturbance differs considerably from the actual timing disturbance for a significantly long duration leading to misindexing of the detected bits and thus error bursts. Large residual timing jitter erodes SNR gains achieved by advanced signal detectors and ensures loss of lock. It is therefore desirable to develop timing recovery methods and systems that can perform well in low SNR environments. For conventional PLL-based decision-directed timing recovery schemes, the residual timing jitter can be decreased by employing reliable detection schemes within PLLs, such as a full Viterbi structure with a long decision window instead of a Viterbi detector having a short decision window. It is difficult, however, to maintain the stability of a PLL having a long delay. Another approach for reducing residual timing jitter is to use a soft timing error detector (TED), which uses soft information from a Soft Output Viterbi Algorithm (SOVA) with a forced short decision window. Test results show that the soft TED provides some improvement in terms of the residual timing jitter and the overall bit error rate (BER). Nevertheless, the soft TED method alone may not provide adequate performance at low SNRs, especially when a large PLL bandwidth is needed to track a relatively rapidly changing timing disturbance.


[0003] Accordingly, there exists a need for a new timing recovery system and method to perform timing recovery in low SNR partial response recording channels.



BRIEF SUMMARY OF THE INVENTION

[0004] In one general respect, the present invention is directed to a tracking method for providing timing recovery of continuous signals. According to one embodiment, the method includes sampling a continuous signal and estimating a timing disturbance of the sampled continuous signal. The method further includes generating a timing adjustment signal in accordance with the estimated timing disturbance, and adjusting a sampling signal associated with a sampling device based on the timing adjustment signal.


[0005] According to another embodiment, the method includes estimating a timing disturbance of a sampled continuous signal at a predetermined sampling instant. The sampled continuous signal comprises a plurality of sectors, wherein each sector comprises one or more segments of a predetermined number of bits (M). The method further includes estimating a timing offset signal at a corresponding channel bit of the sampled continuous signal, and generating a timing adjustment signal based on the timing offset signal.


[0006] In another general respect, the present invention is directed to a tracking system for providing timing recovery of continuous signals. According to one embodiment, the system includes a sampling device for sampling the continuous signal, and a filter in communication with the sampling device. The filter is for estimating a timing disturbance of the continuous signal and generating a timing adjustment signal in accordance with the estimated timing disturbance. The filter is further for adjusting a sampling signal associated with the sampling device to obtain a sampled version of the continuous signal based on with the timing adjustment signal.


[0007] According to another embodiment, the system includes a filter for receiving an estimated timing disturbance signal of a sampled version of the continuous signal at a predetermined sampling instant. The sampled version of the continuous signal comprises a plurality of sectors, each sector comprising one or more segments of a predetermined number (M) of bits. The filter is further for estimating a timing offset signal at a corresponding channel bit of a sampled continuous signal, and generating a timing adjustment signal based on the timing offset signal.


[0008] In another general respect, the present invention is directed to a filter for a timing recovery system. According to one embodiment, the filter includes means for receiving an estimated timing disturbance signal of a sampled version of the continuous signal at a predetermined sampling instant. The sampled version of the continuous signal comprises a plurality of sectors, each sector comprising one or more segments of a predetermined number (M) of bits. The filter further includes means for estimating a timing offset signal at a corresponding channel bit of a sampled continuous signal and means for generating a timing adjustment signal based on the timing offset signal.







DESCRIPTION OF THE DRAWINGS

[0009] Embodiments of the present invention are described herein in conjunction with the following figures, wherein:


[0010]
FIG. 1 is a block diagram of a conventional timing recovery scheme approach in magnetic recording systems;


[0011]
FIG. 2 is a graph illustrating hard and soft decisions of channel bits ak as a function of a log likelihood ratio (LLR);


[0012]
FIG. 3 is a block diagram illustrating the relationship between a Kalman filter and a PLL;


[0013]
FIG. 4 illustrates a relationship between timing disturbance estimations of two intertwined segmented-Kalman filters;


[0014]
FIG. 5 illustrates a DSK-STR architecture in accordance with one embodiment of the present invention;


[0015]
FIG. 6 is a diagram representing a loss of lock rate as a function of SNR for different timing recovery schemes; and


[0016]
FIG. 7 is a diagram of the RMS value of residual timing jitter versus SNR for different timing recovery schemes.







DETAILED DESCRIPTION OF THE INVENTION

[0017] For convenience, the following acronyms and abbreviations are used herein.
1AWGNAdditive White Gaussian NoiseBERBit Error RateBCJRBahl, Cocke, Jelenik, Raviv (algorithm)DSK-STRDual Segmented Kalman Filters Based Timing RecoveryEPR4Extended Partial Response 4 (1 + D − D2 − D3)FIRFinite Impulse Response (filter)FUGFrequency Update GainISIInter-symbol InterferenceITRInterpolation Timing RecoveryLDPCLow Density Parity CheckLLRLog Likelihood RatioLMSLeast Mean Squares (algorithm)M&M TEDMueller and Muller Timing Error DetectorMMSEMinimum Mean Squared ErrorPLLPhase Locked LoopPRPartial ResponsePR4Partial Response 4 (target 1-D2)PRMLPartial Response Maximum LikelihoodPUGPhase Update GainRMSRoot Mean SquareSDD-TEDSoft Decision Directed Timing Error DetectorSNRSignal-to-Noise RatioSOVASoft Output Viterbi AlgorithmTEDTiming Error DetectorVCOVoltage Controlled Oscillator


[0018] In one embodiment, the present invention is directed to tracking systems and methods used for performing timing recovery of continuous readback signals, and may be applicable in timing recovery schemes used in communication systems, data storage systems, and the like. For example, the tracking techniques of the present invention may be used for performing timing recovery in low-SNR partial response data storage channels. Throughout this description, the tracking/timing recovery scheme of the present invention is sometimes referred to generally as a “dual segmented Kalman filters based timing recovery (DSK-STR).” An underlying tracking/timing recovery scheme in accordance with embodiments of the present invention may include, for example, a phase-locked loop (PLL) based tracking/timing recovery scheme. The DSK-STR scheme of the present invention also may utilize two or more intertwined PLLs wherein update gains corresponding to each PLL may be updated according to modified Kalman filters at each symbol instant, for example, as described further herein.


[0019] In data storage systems that employ partial response (PR) data storage channels, an equalizer is generally utilized to control the amount of ISI while simultaneously minimizing the amplification of noise that may be present along with the continuous data signals. The PR data storage channels, such as the PR4 and the extended PR4 (EPR4) channels, are commonly used in conventional magnetic hard disk drives, whereas other PR data storage channels are used in optical recording systems. The present invention, however, should not be construed as being limited to conventional magnetic hard disk drives or optical recording systems, but may be applied to various other recording systems having perpendicular magnetic recording systems, for example, as well as digital communication systems including wireless, satellite, optical, and the like.


[0020] One embodiment of the tracking/timing recovery scheme of the present invention will now be described by way of an example with reference to a recording system model. As discussed hereinbefore, however, those skilled in the art will appreciate that the tracking/timing recovery scheme of the present invention is not limited thereto as it can be applied to communication systems as well.


[0021] Recording systems experience time-varying timing disturbances due to many factors including disk speed variations, frequency offset between different clocks used in the writing and reading processes, clock wander, and the like. Accordingly, a continuous-time readback signal y(t) of a recording system in may be modeled as follows:
1y(t)=k=-akh[t-kT-τ(t)]+n(t)(1)


[0022] where ak are channel bits that take on values of +1 and −1 in binary recording, h(t) is a time-varying channel pulse response, n(t) is additive noise (i.e., the total noise including the media noise and electronics noise), and T is a channel bit interval. A timing disturbance term τ(t) represents the timing variability of the timing recovery system. A timing recovery module may be utilized to estimate the timing disturbance τ(t) and to adjust the clock associated with the recording system for obtaining continuous readback signal samples that effectively correspond to zero timing disturbance (i.e., τ(t=0)).


[0023]
FIG. 1 is a block diagram of a timing recovery module (loop) 10 for recording channels taking the form of a discrete second-order PLL. Such a timing recovery module 10 is generally used in magnetic recording systems. A sampling device such as a voltage controlled oscillator (VCO) 12 controls a clock and generates a synchronized clock signal τout, which is used for sampling the continuous readback signal. The continuous readback signal samples are input into an equalizer 14 where the samples are equalized. The equalized readback samples yk are then input into a simple data detector 16 such as, for example, a slicer or a Viterbi detector having a short decision delay. The simple data detector 16 provides preliminary bit estimates corresponding to the equalized readback samples yk to a timing error detector (TED) 18. The TED 18 uses the equalized readback samples yk and the corresponding estimated bits from the simple data detector 16 to generate a phase adjustment signal Tinst representing the timing adjustment to be applied at each bit instant. A low pass loop filter 20, in order to reduce any noise present on the timing adjustment signal τinst, filters the timing adjustment output τinst of the TED 18. The low pass loop filter 20 output on line 22 drives the VCO 12, which generates the synchronized clock signal τout. The recovered version of the actual timing disturbance τ(t) is τinst(t) The difference between τinst(t) and τ(t) is the residual timing jitter.


[0024] When the timing recovery module 10 is enabled, the initial phase offset and frequency offset of the continuous readback signal may be relatively large. The timing recovery module 10 must, therefore, reduce the large initial phase offset and frequency offset in a relatively short time. In storage systems, a preamble comprising a known pattern of bits may be included in the continuous readback signal to reduce such large offsets. Timing recovery in data storage systems is generally performed in two stages referred to as acquisition mode and tracking mode. During the first stage (i.e., the acquisition mode), large phase and frequency corrections may be made using a known preamble pattern, for example. During the second stage (i.e., the tracking mode), small and slow timing disturbance corrections may be made using bits extracted from the readback samples. The present invention relates generally to performing timing recovery in the tracking mode.


[0025] As illustrated in FIG. 1, a component of a timing recovery system is the TED 18. One example of a decision directed TED 18 that may be incorporated in one embodiment of the present invention is the Mueller and Müller (M & M) TED. The output of a M & M type TED is given generally as follows:


τinst(k)=yk−1dk−dk−1yk  (2)


[0026] where yk are the equalized readback samples that reflect the noise and timing disturbances present in the continuous readback signal and dk are the ideal values that would have been obtained from a perfect equalization in the absence of any noise and timing disturbances. In PR channels, the dk ideal values may be the linear combinations of channel bits ak. For example, dk=ak−ak−2 for a PR4 target (i.e., 1−D2), and dk=ak+ak−1−ak−2−ak−3 for an EPR4 target (i.e., 1+D−D2−D3). Because ak assumes binary values (−1 and +1), dk may assume only a finite number of values, generally referred to as hard values. For example, dkε[−2, 0, 2] for PR4, and dkε[−4, −2, 0, 2, 4] for EPR4. In conventional recording channels, the simple data detector 16 may be used to estimate the ak values and a linear combination of estimated ak values may be used to estimate the desired dk ideal values. At low SNRs, however, the simple data detector 16 generally makes many decision errors resulting in an extremely noisy τinst signal and, consequentially, in an unacceptably large residual timing jitter.


[0027] Other data detection schemes such as LDPC codes or Turbo codes may be employed in various other embodiments of the present invention in order to achieve more accurate channel bit estimates at low SNRs without departing from the general scope of the present invention. Such advanced detection approaches, however, may introduce significant decision delays in the timing recovery loop 10 and thus may reduce the stability margin of the loop 10. Nevertheless, such advanced detection methods may be used for detecting data outside the timing recovery loop 10 in order to achieve acceptably low bit error rates.


[0028] Another TED 18 approach that may be utilized is a soft decision directed TED (SDD-TED). An SDD-TED uses soft information {overscore (d)}k ideal values in place of the dk ideal values used in the hard output M & M type TED. A soft output Viterbi algorithm (SOVA) detector can provide soft information in the form of a log-likelihood ratio (LLR) having a relatively short decision delay. Soft output SOVA detectors are generally used in iterative soft decoding applications. The LLR may be defined as:
2LLR(ak)=log(Pr(ak=1)Pr(ak=-1))(3)


[0029] The SOVA detector may be used with a forced short delay by outputting the soft information after a short delay, as illustrated in the simple data detector 16 of FIG. 1, for example. This leads to a formulation for an SDD-TED as follows:


τinst(k)=yk−1{overscore (d)}k−{overscore (d)}k−1yk  (4)


[0030] where the {overscore (d)}k soft decisions values are referred as the expected values of the desired bits that may be obtained by a linear combination of expected values of the channel bits {overscore (a)}k. For example, {overscore (d)}k={overscore (a)}k−{overscore (a)}k−2 for a PR4 target and {overscore (d)}k={overscore (a)}k+{overscore (a)}k−1−{overscore (a)}k−2−{overscore (a)}k−3 for an EPR4 target where {overscore (a)}k may be estimated from the LLR of {overscore (a)}k. The output from a SOVA detector may be expressed as follows:
3a_k=exp[LLR(ak)]-1exp[LLR(ak)+1(5)


[0031]
FIG. 2 is a graph showing the hard decision 100 and the soft decision 102 versions of the channel bits {overscore (a)}k as a function of the LLR. It is seen that by using the soft decision 102 information, the SDD-TED gives more weight to the more reliable bit estimates (|LLR(ak)|>>0) rather than to the less reliable estimates (|LLR(ak)|≅0).


[0032] Generally, the timing disturbance τ(t) in recording systems may be characterized as linear, sinusoidal timing disturbance or autoregressive (AR). The linear timing disturbance model corresponds to a constant frequency offset between an actual bit rate and a sampled bit rate. It is the model generally used for the kinds of timing disturbances observed in magnetic type hard disk drives. The sinusoidal timing disturbance model generally is used when a servo loop cannot damp out excessive vibration in the head/media interface. Tracking a sinusoidal timing disturbance requires a PLL with a relatively large bandwidth. A PLL with large bandwidth, however, permits large amounts of noise to pass through the PLL making it challenging to perform timing recovery when a sinusoidal type of timing disturbance is present in the continuous readback signal. The autoregressive timing disturbance model corresponds to the random nature of timing disturbance especially during the tracking mode when the frequency offset is relatively small and there is no initial phase offset.


[0033] In a conventional PLL-based timing recovery scheme, the bandwidth (Bn) of the PLL is designed to enable the PLL to track the timing disturbance while simultaneously suppressing noise to a sufficiently low level. Conventional timing recovery schemes are equivalent to a timing offset estimation-based feedforward timing recovery scheme where a sector is divided into small segments of N bits (typically N=1/2Bn) and the timing offsets are assumed to be constant over the N bits. Such a timing recovery scheme effectively uses a piecewise constant approximation of the timing disturbance. if the timing disturbance is changing slowly, N may be relatively large without significantly violating the piecewise constant approximation. Conversely, if the timing disturbance changes relatively rapidly, N may be relatively small in order to use piecewise constancy while the number of segments per fixed length sector may be relatively large. Thus, in a conventional timing recovery scheme the number of parameters to be estimated, such as the number of timing offsets of the segments, becomes large and the performance of the timing disturbance estimation degrades, especially at low SNRs.


[0034] One embodiment of the present invention provides an estimate of the timing disturbance using a piecewise linear approximation. In such an embodiment a sector is divided into longer segments of M bits and it is assumed that the slopes of the timing disturbance i.e., the frequency offsets, in each segment are constant. Furthermore, the initial phase offset present in a given segment is assumed to be the same as the final phase offset of a previous segment. Estimating the timing disturbance becomes the equivalent of estimating the initial phase offset of a first segment and the frequency offsets of all segments. Estimating the timing disturbance by piecewise linear approximation significantly reduces the number of parameters to be estimated because each segment is divided into a much longer number of bits than was previously required in conventional timing recovery schemes. Therefore, the performance of the timing recovery process based on the piecewise linear approximation model in accordance with one embodiment of the present invention provides an improvement over conventional timing recovery processes and methods.


[0035] Dual Segmented Kalman Filters Based Timing Recovery (DSK-STR)


[0036]
FIG. 5 is a diagram of a Dual Segmented Kalman Filters Based Timing Recovery (DSK-STR) system 500 according to one embodiment of the present invention. As illustrated in FIG. 5, the system 500 may include two branches 502, 504, although according to other embodiment, a greater number of similar branches may be utilized. Each branch may include a Kalman filter, as illustrated in FIG. 5, wherein the branch 502 includes Kalman filter 512 and the branch 504 includes the Kalman filter 514. Those skilled in the art will appreciate that the Kalman filters 512, 514 may be implemented in the form of one or more digital signal processors.


[0037] Details of the operation of the system 500 are provided hereinafter, but first a preliminary identification of the components of the system 500 is provided to facilitate understanding of the discussion to follow. A continuous readback signal is sampled by two sampling devices 548, 550, one for each branch 502, 504. The sampling devices 548, 550 may be, as illustrated in FIG. 5, voltage-controlled oscillators (VCOs). The output of the sampling devices 548, 550 is provided to equalizers 516, 518 respectively. The outputs of the equalizers 516, 518 are provided to TEDs 520, 522 respectively. In addition, the outputs of the equalizers 516, 518 may be provided to a multiplexer 517, the output from which may be provided to a simple data detector 546, which as explained further hereinafter, supplies decisions to the respective TEDs 520, 522.


[0038] The Kalman filter 512 of the branch 502 is used to control the sampling device 548 for the branch 502, and similarly the Kalman filter 514 of the branch 504 is used to control the sampling device 550 of that branch. For simplicity, an overview of the components only one Kalman filter 512 is now provided, recognizing that the other Kalman filter 514 may be similarly configured.


[0039] The Kalman filter 512 may comprise a loop filter 524. Input from the TED 520 is supplied to two braches of the loop filter 524: one branch is updated at mixing node 537 with a phase update gain (PUG), to be described further hereinafter, which may be stored in a memory look-up table 528, and the other branch is updated at mixing node 539 with the frequency update gain (FUG), also to be described further hereinafter, which may be similarly stored in a memory look-up table 530. The loop filter 524 may further include a first summer 545, a frequency register 544, a digital unit delay 547, and a second summer 549. The frequency update signal is supplied to the summer 545, where it is summed with the output of the digital unit delay 547. The frequency register 544 is connected between the summer 545 and the digital unit delay 547. Output from the digital detector 547 is also supplied to the summer 549, where it is summed with the phase update signal.


[0040] The output from the summer 549 is supplied to phase register 540, and the output of the phase register 540 is supplied to a digital unit delay 536. The output of the digital detector 536 controls the sampling device 548, and is also fed back to the summer 549.


[0041] The DSK-STR system 500 may be based on the piecewise linear model described hereinbelow. A piecewise linear timing disturbance model may be expressed using the state vector θk=[τkfk]T where τk is the phase offset at channel bit k and fk is the frequency offset as follows:
4θk+1=[τk+1fk+1]=[1101][τkfk]+[0wk]=Fθk+[0wk](6)


[0042] where wk, a nonstationary random process, is the driving noise and
5F=[1101].


[0043] In Eq. (6), it is assumed that the sampling interval is normalized by the channel clock to one, for example. For a piecewise linear timing disturbance model using a segment of size M, wk is zero except at integer multiples of M where wk may assume nonzero values. That is, wk is used to randomize the frequency offsets fk in various segments. In each segment, however, the frequency offset fk is assumed to be constant. In Eq. (6) it is also assumed that the timing disturbance in a segment is due to the frequency offset in that segment. The variance of the initial frequency offset in each segment is σf2 and the variance of the initial phase offset in each segment is στ2. In one embodiment of the present invention the TED 520, 522 may be used to extract the timing error information. Assuming a linear transfer function of the TED 520, 522, the linear timing error observation model may be described as follows:




y


k


=[KPD
0]θkk=Hθkk=KPD×τk+νk  (7)



[0044] where yk is the observed noisy timing offset which is the output of the TED 520, 522, H=[KPD 0], and KPD is the gain of the TED 520, 522. Noise νk represents the output jitter of the TED 520, 522 and is modeled as additive white Gaussian noise (AWGN) with variance σν2.


[0045] In one embodiment, Kalman filter 512, 514 may be used to provide an optimum estimation of τk, the timing disturbance at channel bit k, in the sense of a Minimum Mean Squared Error (MMSE) for the timing disturbance model described in Eq. (6) when the driving noise wk is stationary and the timing error observation model is linear as expressed in Eq. (7).


[0046]
FIG. 3 is a block diagram 300 of the relationship between a Kalman filter and a PLL. In one embodiment, a Kalman filter may be used to model a PLL. The closed form expressions for the phase update gain ak (PUGs) 310 and the frequency update gain βk (FUGs) 320 may be derived when the driving noise wk is zero. Throughout this description the phase update gain ak 310 and the frequency update gain βk 320 are sometimes referred to as the “Kalman gains.” In a piecewise linear model, the timing disturbance may be divided into segments of size M. Because wk is zero within a segment except at integer multiples of M, the driving noise is zero within the segment, and, therefore, the nonzero driving noise wk at integer multiples of M may be treated as the initial frequency offset f0 for the segment. Kalman gains of the piecewise linear timing disturbance model in accordance with one embodiment of the present invention may be written as:
6[αkβk]=1σv2cm[1KPD(m2σv2στ2+σv2σf2+m(m+1)(2m+1)6)1KPD(mσv2στ2+m(m+1)2)](8)cm=σv2στ2σf2+m(m+1)(2m+1)6σt2+m+1σf2+m(m+1)2(m+2)12σv2(9)
m=kmodM  (10)


[0047] where k is the bit index, M is the size, σν2 is the variance of the output jitter of the TED 18, στ2 is the variance of the initial phase error in each small segment, and σf2 is the variance of the initial frequency error in each small segment, i.e., σf2 the variance of the nonzero value of the nonstationary driving noise wk. m is the normalized bit index in each segment. In one embodiment, the phase update gain ak 310 and the frequency update gain βk 320 follow from each of the segmented Kalman filters 512, 514.


[0048] According to one embodiment, two intertwined segmented Kalman filters 512, 514 may be used to provide an estimate of the timing disturbance τk. This general scheme is referred throughout the description as the “dual segmented Kalman filters timing recovery (DSK-STR)” scheme. FIG. 4 illustrates the relationship between the timing disturbance estimates τk provided by the two intertwined segmented Kalman filters 512, 514. The solid line 410 in diagram 400 represents the timing disturbance estimate τk of one segment of the first segmented Kalman filter 512, for example. The dashed line 412 represents the timing disturbance estimate τk of one segment of the second segmented Kalman filter 514, which is shifted in time by M/2 with respect to the first segmented Kalman filter 514. The large dotted line 414 represents the portion contributed to the final version of the estimated timing disturbance τk. Because the two segmented Kalman filters 512, 514 are shifted in time by M/2 bit intervals relative to each other, Eq. (12) may be used to calculate Kalman gains ak and βk for the first Kalman filter 512, while for the other filter, Eq. (12) may be modified for the second Kalman filter 514 as follows:




M=
(m+M/2)modM  (11)



[0049] where Eq. (13) may be used to calculate Kalman gains ak and βk for the second Kalman filter 514. For each segment, each of the first and second Kalman filters 512, 514 may use the timing disturbance and the frequency offset states of the other filter as its initial states. Moreover, each of the first and second Kalman filters 512, 514 may alternatively contribute to the final version of the estimated timing disturbance τk when mε[M/4,3M/4].


[0050] As illustrated in the embodiment of FIG. 5, each branch of the DSK-STR system 500 may include its own equalizer 516, 518, TED 520, 522, loop filter 524, 526, pre-calculated PUG/FUG look-up tables 528, 530, 532, 534, digital integrator 536, 538, phase register 540, 542, frequency register 544, 546, and VCO 548, 550. According to other embodiments, more than two segmented branches may used.


[0051] The two branches 502, 504 may share one simple data detector 546. For the dual segmented Kalman filters 512, 514 the PUG and FUG values may be pre-calculated using Eq. (10) and then stored in memory in the form of a look-up table. Those skilled in the art will appreciate that Eqs. (12) and (13) may be used for the two different Kalman filters 512, 514, respectively. At each sampling clock instant, the PUG and FUG values provided to the Kalman filters 512, 514 may be updated according to the values stored in the look-up tables 528, 530, 532, 534. The two Kalman filters 512, 514 may control the digitally controlled VCOs 548, 550 respectively. The VCOs 548, 550 may sample the continuous readback signal. The equalizers 516, 518 subsequently may equalize the continuous readback signal samples. Control logic may be used to determine which Kalman filter 512, 514 outputs the estimated timing disturbance in accordance with the technique shown in FIG. 4 and may select as an output the corresponding equalized continuous readback signal samples to the advanced data detector via line 552. The selected equalized continuous readback signal samples may also be passed to the simple data detector 546 and may provide preliminary decisions for the TEDs 520, 522. In turn, the TEDs 520, 522 may generate the necessary timing error information for the dual segmented Kalman filters 512, 514, respectively.


[0052] For each segmented Kalman filter 512, 514, at the beginning of each segment the contents of the phase register 540, 542 and frequency register 544, 546 may be initialized using the contents of the corresponding registers of the other segmented Kalman filter 514, 512, respectively. For example, for the Kalman filter 512, at the beginning of each segment, the contents of the phase register 540 and frequency register 544 are initialized using the contents of the corresponding phase register 542 and frequency register 546 of the other segmented Kalman filter 514. Alternatively, for the Kalman filter 514, at the beginning of each segment, the contents of the phase register 542 and frequency register 546 are initialized using the contents of the corresponding phase register 540 and frequency register 544 of the other segmented Kalman filter 512.


[0053] The process associated with the DSK-STR system 500 illustrated in FIG. 5 will now be described in terms of the following example. Those skilled in the art will appreciate, however, that the scope of the present invention is not to be limited thereto. Assuming that at a time instant k the kth bit in the continuous readback signal is to be sampled by the VCOs 548, 550. First, the PUG and FUG values of the two Kalman filters 512, 514 are updated according to the values stored in the pre-calculated look-up tables 528, 530, 532, 534 associated with each Kalman filter 512, 514, respectively. The two VCOs 548, 550, then sample the continuous readback signal and the two equalizers 516, 518 equalize the samples. The m values for the two different branches 502, 504 of the DSK-STR system 500 are calculated using Eqs. (12) and (13) respectively. There may be one mε[M/4,3M/4] among the two m values. The outputs of each equalizer 516, 518 are provided to a multiplexer (e.g., 2 to 1 selector) 517. For example, the multiplexer 517 may select the output of the equalizer 516 of branch 502 (the active branch), as the synchronized output equalized samples to be supplied to the advanced data detector via line 552. If the m value of the other branch 504 (the inactive branch) happens to be zero, for example, the contents of the phase register 542 and frequency register 546 of the inactive branch 504 are refreshed using the contents of the corresponding phase register 540 and frequency register 544 of the active branch 502. The multiplexer 517 also passes the selected equalized samples of the continuous readback signal to the shared simple data detector 546. In one embodiment, the shared simple data detector 546 may be a Viterbi detector or, in another embodiment, a SOVA detector with short decision delay. The TEDs 520, 522 each receive two inputs. One is the preliminary decision made by the simple data detector 546. The other input is the equalized sample of the continuous readback signal in its own branch.


[0054] The following procedure may be the same for both branches 502, 504 of the DSK-STR system 500. The low pass loop filters 524, 526 filter the timing error information from the TEDs 520, 522, respectively. The instantaneous bandwidth of the low pass loop filters 524, 526 is controlled by the updated PUG/FUG values received by the look-up tables 528, 530, 532, 534. The timing error information is then integrated by the digital integrators 536, 538, and converted to a time signal by the digitally controlled VCOs 548, 550. The time instant k is then incremented by one and the whole process is repeated recursively until the end of the sector.


[0055] Although the previous example was described with reference to two offset segmented Kalman filters 512, 514 and using the central 50% portion of the timing disturbance estimates from each segmented Kalman filter 512, 514 as shown in FIG. 4, the present invention may be extended to using more than two segmented Kalman filters and using a central portion of timing disturbance estimates from each filter, as mentioned previously.


[0056] The scope of one embodiment of the present invention may be further illustrated with reference to the following example based on a Monte-Carlo simulation of one embodiment of the DSK-STR system 500. In the present example, the Monte-Carlo simulation utilizes a Lorentzian magnetic recording channel model at normalized channel density of 2.5 such that the channel pulse response may be given by:
7h(t)=11+(2tPW50)2-11+(2(t-T)PW50)2(12)


[0057] and the channel bit interval may be T=PW50/2.5. In the example, sinusoidal timing disturbances with a period of 5,000 bits and amplitude of one bit interval were introduced into the simulated readback waveform. Twenty times over sampling was used in the simulation to mimic a continuous-time waveform. In the current simulation example, an EPR4 target (i.e., 1+D−D2−D3) was chosen as the PR target. A floating point Finite Impulse Response (FIR) filter with eleven coefficients was used as the equalizer 516, 518 and they were trained using a least mean squares (LMS) algorithm. An LDPC code was used with a {fraction (16/17)} rate and a codeword size of 4352 (i.e., 4096×17/16) bits was assumed. A BCJR algorithm was used to perform the channel detection. There were five iterations between the turbo equalizer and the LDPC decoder, and 30 were used iterations within the sum-product algorithm used for LDPC decoding. The SNR may be defined as the ratio of the power of the pulse response to the noise power. The length of the preamble was chosen as 100 bits for the example. A Kalman filter based timing acquisition scheme in accordance with one embodiment of the present invention was used for the acquisition mode.


[0058] In order to separate the acquisition and tracking aspects of the timing recovery in the current simulation example a perfect initial frequency offset acquisition was presumed. In the simulation, this assumption may be achieved by always starting the sinusoidal timing disturbance with a zero instantaneous slope. For the case of conventional hard decision directed M&M type TEDs, a Viterbi detector with a detection window of eight bit intervals was used as the simple data detector 546 as shown in FIG. 5, while a SOVA detector with detection window of eight bit intervals was used for the SDD-TED embodiment. The segment size M for the DSK-STR system 500 was optimized to 200 bits by estimating the loss of lock rate for the various M values. In the simulations, a loss of lock of the sector was declared whenever more than 50% of the bytes in a sliding observation window of 50 bytes are in error. These parameters were chosen such that the loss of lock miss rate and the loss of lock false alarm rate are negligible compared to the actual loss lock rate due to the residual timing jitter. In other words, the fraction of loss of lock events that are not identified by the loss of lock detector and the fraction of events that are flagged by the loss of lock detector but are not actually loss of lock events, were chosen so as to be negligible as compared to the actual loss of lock rate due to the residual timing jitter.


[0059]
FIG. 6 is a diagram 600 representing the loss of lock rate as a function of SNR for different timing recovery schemes using the above described exemplary parameters. It is seen that the performance of the SDD-TED DSK-STR for the sinusoidal timing disturbance model 610 of an embodiment of the present invention is about 3.5 dB better than that of the conventional timing recovery scheme for a target loss of lock rate of 1×10−5 FIG. 6 also indicates that a 0.25 dB gain in performance may be achieved with the present invention when using the SDD-TED DSK-STR sinusoidal timing disturbance 610 as compared to the hard decision directed TED based DSK-STR 612. The loss of lock performance of the SDD-TED DSK-STR linear timing disturbance model 616 of the present invention provides an additional 0.6 dB improvement in performance over the sinusoidal model 610 when the phase drift is linear. This is an expected result given that the design of the DSK-STR system 500 is based on a piecewise linear assumption.


[0060]
FIG. 7 illustrates a diagram 800 showing the RMS value of the residual timing jitter as a function of SNR for different timing recovery schemes. It is seen that the residual timing jitter of the DSK-STR schemes 810 of the present invention is much smaller than that of the conventional scheme 812.


[0061] Those of ordinary skill in the art will recognize that many modifications and variations of the present invention may be implemented. The foregoing description and the following claims are intended to cover all such modifications and variations. Furthermore, the materials and processes disclosed are illustrative, but are not exhaustive. Other materials and processes may also be used to make devices embodying the present invention.


Claims
  • 1. A tracking method for providing timing recovery of continuous signals, comprising: sampling a continuous signal; estimating a timing disturbance of the sampled continuous signal; generating a timing adjustment signal in accordance with the estimated timing disturbance; and adjusting a sampling signal associated with a sampling device based on the timing adjustment signal.
  • 2. The method of claim 1, wherein estimating a timing disturbance of the continuous signal includes Kalman filtering the sampled version of the continuous signal by a first and second segmented Kalman filters.
  • 3. The method of claim 2, further comprising updating the first and second segmented Kalman filters at each sampling instant with a phase update gain and a frequency update gain.
  • 4. The method of claim 3, wherein updating the first and second segmented Kalman filters at each sampling instant includes updating the phase update gain and the frequency update gain from a look-up table.
  • 5. The method of claim 3, wherein the phase update gain and the frequency update gain for the first and second Kalman filters are calculated according to:
  • 6. The method of claim 3 wherein updating the first and second segmented Kalman filters at each sampling instant includes updating the phase update gain and the frequency update gain of the first Kalman filter according to m=k mod M and updating the phase update gain and the frequency update gain of the second Kalman filter according to M=(m+M/2) mod M, wherein the first and second segmented Kalman filters are shifted in time by M/2 bit intervals relative to each other.
  • 7. The method of claim 2, further comprising for each of the first and second segmented Kalman filters, at the beginning of a segment, initializing a first phase register and a first frequency register of the first segmented Kalman filter according to the contents of a corresponding second phase register and a corresponding second frequency register of the second segmented Kalman filter, respectively.
  • 8. The method of claim 2, wherein sampling the continuous signal includes sampling the continuous signal with a voltage controlled oscillator to thereby obtain the sampled version of the continuous signal, wherein the voltage controlled oscillator is controlled by the first and second Kalman filters.
  • 9. The method of claim 2, further comprising equalizing the sampled version of the continuous signal to thereby generate an equalized sampled version of the continuous signal.
  • 10. The method of claim 9, wherein equalizing the sampled version of the continuous signal includes equalizing the sampled version of the continuous signal according to a finite impulse response filter.
  • 11. The method of claim 9, further comprising: providing the equalized sampled version of the continuous signal to a data detector; and generating, with the data detector, preliminary bit estimates corresponding to the equalized sampled version of the continuous signal.
  • 12. The method of claim 11, further comprising providing the preliminary bit estimates to a timing error detector.
  • 13. The method of claim 12, wherein generating the timing adjustment signal includes generating the timing adjustment signal from the preliminary bit estimates and the equalized sampled version of the continuous signal.
  • 14. The method of claim 1, wherein estimating a timing disturbance of the continuous signal includes Kalman filtering the sampled version of the continuous signal by at least two segmented Kalman filters.
  • 15. A tracking method for providing timing recovery of continuous signals, comprising: estimating a timing disturbance of a sampled continuous signal at a predetermined sampling instant, the sampled continuous signal comprising a plurality of sectors, wherein each sector comprises one or more segments of a predetermined number of bits (M); estimating a timing offset signal at a corresponding channel bit of the sampled continuous signal; and generating a timing adjustment signal based on the timing offset signal.
  • 16. The method of claim 15, wherein estimating the timing offset signal includes filtering the sampled continuous signal with a first and second segmented Kalman filters.
  • 17. The method of claim 16, further comprising providing the phase update gain and the frequency update gain to each of the first and second Kalman filters at the sampling instant.
  • 18. The method of claim 17, further comprising determining the phase update gain and the frequency update gain provided to each of the first and second Kalman filters according to:
  • 19. The method of claim 17, wherein providing the first and second segmented Kalman filters with the phase update gain and the frequency update gain at the sampling instant includes updating the phase update gain and the frequency update gain of the first Kalman filter according to m=k mod M and updating the phase update gain and the frequency update gain of the second Kalman filter according to M=(n+M/2) mod M, wherein the first and second segmented Kalman filters are shifted in time by M/2 bit intervals relative to each other.
  • 20. The method of claim 17, further comprising, at a starting portion of each segment, initializing a first phase register and a first frequency register associated with the first Kalman filter with the contents of a second phase register and a second frequency register associated with the second Kalman filter.
  • 21. The method of claim 15, further comprising: sampling a continuous signal with a voltage controlled oscillator to thereby generate the sampled continuous signal; and controlling the voltage controlled oscillator based on the timing adjustment signal based on the timing offset signal.
  • 22. The method of claim 15, further comprising equalizing the sampled continuous signal.
  • 23. The method of claim 22, further comprising generating a timing error signal by providing the equalized samples of the continuous signal to a timing error detector for generating the liming error signal.
  • 24. The method of claim 23, wherein generating the timing error signal includes generating the timing error signal according to a linear model, wherein the linear model is expressed as:
  • 25. The method of claim 15, wherein estimating the timing offset signal includes filtering the sampled continuous signal with at least two segmented Kalman filters.
  • 26. A tracking system for providing timing recovery of continuous signals, comprising: a sampling device for sampling the continuous signal; and a filter in communication with the sampling device for: estimating a timing disturbance of the continuous signal; generating a timing adjustment signal in accordance with the estimated timing disturbance; and adjusting a sampling signal associated with the sampling device to obtain a sampled version of the continuous signal based on with the timing adjustment signal.
  • 27. The system of claim 26, wherein the filter includes first and second segmented Kalman filters.
  • 28 The system of claim 27, wherein the first and second Kalman filters are for estimating a timing offset at a predetermined channel bit of the sampled version of the continuous signal.
  • 29. The system of claim 28, wherein the first and second segmented Kalman filters are updated at each sampling instant with a phase update gain and a frequency update gain.
  • 30. The system of claim 29, wherein the first and second segmented Kalman filters are updated at each sampling instant with the phase update gain and the frequency update gain based on a look-up table.
  • 31. The system of claim 29, wherein the phase update gain and the frequency update gain for the first and second Kalman filters are calculated according to:
  • 32. The system of claim 31, wherein at each sampling instant the first segmented Kalman filter includes the phase update gain and the frequency update gain determined according to m=k mod M and the second segmented Kalman filter includes the phase update gain and the frequency update gain determined according to M=(m+M/2) mod M, wherein the first and second segmented Kalman filters are shifted in time by M/2 bit intervals relative to each other.
  • 33. The system of claim 28, further comprising: a first phase register in communication with the first Kalman filter; a first frequency register in communication with the first Kalman filter; a second phase register in communication with the second Kalman filter; and a second frequency register in communication with the second Kalman filter, wherein, at the beginning of a segment, the first phase register is initialized according to the contents of the second phase register and the first frequency register is initialized according to the contents of the second frequency register.
  • 34. The system of claim 28, wherein the sampling device is a voltage controlled oscillator controlled by the first and second Kalman filters.
  • 35. The system of claim 28, further comprising an equalizer in communication with the sampling device for generating an equalized sampled version of the continuous signal.
  • 36. The system of claim 35, wherein the equalizer is a finite impulse response filter.
  • 37. The system of claim 35, further comprising a data detector for generating preliminary bit estimates corresponding to the equalized sampled version of the continuous signal.
  • 38. The system of claim 37, further comprising a timing error detector in communication with the equalizer, wherein the preliminary bit estimates are provided to the timing error detector.
  • 39. The system of claim 38, wherein the timing error detector is for generating the timing adjustment signal from the preliminary bit estimates and the equalized sampled version of the continuous signal.
  • 40. The system of claim 26, wherein the filter includes at least two segmented Kalman filters.
  • 41. A tracking system for providing timing recovery of a continuous signal, comprising a filter for: receiving an estimated timing disturbance signal of a sampled version of the continuous signal at a predetermined sampling instant, the sampled version of the continuous signal comprising a plurality of sectors, each sector comprising one or more segments of a predetermined number (M) of bits; estimating a timing offset signal at a corresponding channel bit of a sampled continuous signal; and generating a timing adjustment signal based on the timing offset signal.
  • 42. The system of claim 41, wherein the filter comprises first and second segmented Kalman filters.
  • 43. The system of claim 42, wherein a phase update gain and a frequency update gain are provided to each of the first and second segmented Kalman filters at the predetermined sampling instant.
  • 44. The system of claim 42, wherein the phase update gain and the frequency update gain provided to each of the first and second segmented Kalman filters are determined according to:
  • 45. The system of claim 44, wherein the phase update gain and the frequency update gain of the first Kalman filter are updated according to m=k mod M and the phase update gain and the frequency update gain of the second Kalman filter are updated according to M (m+M/2) mod M; and wherein the first and second segmented Kalman filters are shifted in time by M/2 bit intervals relative to each other.
  • 46. The system of claim 43, wherein the filter further comprises: a first phase register in communication with the first Kalman filter; a first frequency register in communication with the first Kalman filter; a second phase register in communication with the second Kalman filter; and a second frequency register in communication with the second Kalman filter, wherein, at the beginning of a segment, the first phase register is initialized according to the contents of the second phase register and the first frequency register is initialized according to the contents of the second frequency register.
  • 47. The system of claim 41, further comprising a voltage controlled oscillator in communication with the filter for sampling the continuous signal, wherein the voltage controlled oscillator is controlled by the timing adjustment signal based on the timing offset signal.
  • 48. The system of claim 41, further comprising an equalizer in communication with the filter for equalizing the sampled continuous signal.
  • 49. The system of claim 48, further comprising a timing error detector in communication with the equalizer, wherein the timing error detector is for generating a timing error signal based on the equalized samples of the continuous signal
  • 50. The system of claim 48, wherein the timing error signal is generated according to a linear model, wherein the linear model is expressed as:
  • 51. The system of claim 41, wherein the filter comprises at least two segmented Kalman filters.
  • 52. A filter for a timing recovery system, comprising: means for receiving an estimated timing disturbance signal of a sampled version of the continuous signal at a predetermined sampling instant, the sampled version of the continuous signal comprising a plurality of sectors, each sector comprising one or more segments of a predetermined number (M) of bits; means for estimating a timing offset signal at a corresponding channel bit of a sampled continuous signal; and means for generating a timing adjustment signal based on the timing offset signal.
  • 53. The filter of claim 52, further comprising: means for providing a phase update gain to the filter; and means for providing a frequency update gain to the filter at the predetermined sampling instant.
  • 54. The filter of claim 52, wherein the phase update gain and the frequency update gain provided to the filter are determined according to:
  • 55. The filter of claim 54, wherein the filter further comprises: first means for filtering; and second means for filtering in communication with the first means for filtering; wherein the phase update gain and the frequency update gain of the first means for filtering are updated according to m=k mod M and the phase update gain and the frequency update gain of the second means for filtering are updated according to M=(m+M/2) mod M; and wherein the first and second means for filtering are shifted in time by M/2 bit intervals relative to each other.
  • 56. The filter of claim 55, wherein the filter comprises first and second segmented means for filtering.
  • 57. The filter of claim 56, wherein the first means for filtering includes a first Kalman filter, and the second means for filtering includes a second Kalman filter.
  • 58. The filter of claim 56, wherein a phase update gain and a frequency update gain are provided to each of the first and second segmented means for filtering at the predetermined sampling instant.
  • 59. The filter of claim 58, wherein the phase update gain and the frequency update gain provided to each of the first and second segmented means for filtering are determined according to:
  • 60. The filter of claim 59, wherein the phase update gain and the frequency update gain of the first segmented means for filtering are updated according to m=k mod M and the phase update gain and the frequency update gain of the second segmented means for filtering are updated according to M=(m+M/2) mod M; and wherein the first and second segmented means for filtering are shifted in time by M/2 bit intervals relative to each other.
  • 61. The filter of claim 59, wherein the filter further comprises: a first means for storing in communication with the first segmented means for filtering; a second means for storing in communication with the first segmented means for filtering; a third means for storing in communication with the second segmented means for filtering; and a fourth means for storing in communication with the second segmented means for filtering; wherein, at the beginning of a segment, the first means for storing is initialized according to the contents of the third means for storing and the second means for storing is initialized according to the contents of the fourth means for storing.
  • 62. The filter of claim 56, further comprising sampling means in communication with the filter for sampling the continuous signal, wherein the sampling means is controlled by the timing adjustment signal in based on with the timing offset signal.
  • 63. The filter of claim 56, further comprising means for equalizing in communication with the filter for equalizing the sampled continuous signal.
  • 64. The filter of claim 63, further comprising means for detecting timing errors in communication with the means for equalizing, wherein the means for detecting timing errors is for generating a timing error signal based on the equalized samples of the continuous signal.
  • 65. The filter of claim 64, wherein the timing error signal is generated according to a linear model, wherein the linear model is expressed as:
  • 66. A tracking system for providing timing recovery of a continuous signal, the system comprising: means for receiving an estimated timing disturbance signal of a sampled version of the continuous signal at a predetermined sampling instant, the sampled version of the continuous signal comprising a plurality of sectors, each sector comprising one or more segments of a predetermined number (M) of bits; means for estimating a timing offset signal at a corresponding channel bit of a sampled continuous signal; and means for generating a timing adjustment signal based on the timing offset signal.
  • 67. The system of claim 66, wherein the filter comprises first and second segmented means for filtering.
  • 68. The system of claim 67, wherein a phase update gain and a frequency update gain are provided to each of the first and second segmented means for filtering at the predetermined sampling instant.
  • 69. The system of claim 67, wherein the phase update gain and the frequency update gain provided to each of the first and second segmented means for filtering are determined according to:
  • 70. The system of claim 69, wherein the phase update gain and the frequency update gain of the first segmented means for filtering are updated according to m=k mod M and the phase update gain and the frequency update gain of the second segmented means for filtering are updated according to M=(m+M/2) mod M; and wherein the first and second segmented means for filtering are shifted in time by M/2 bit intervals relative to each other.
  • 71. The system of claim 68, wherein the filter further comprises: a first means for storing in communication with the first segmented means for filtering; a second means for storing in communication with the first segmented means for filtering; a third means for storing in communication with the second segmented means for filtering; and a fourth means for storing in communication with the second segmented means for filtering; wherein, at the beginning of a segment, the first means for storing is initialized according to the contents of the third means for storing and the second means for storing is initialized according to the contents of the fourth means for storing.
  • 72. The system of claim 66, further comprising a sampling means in communication with the means for filtering for sampling the continuous signal, wherein the means for sampling is controlled by the timing adjustment signal based on the timing offset signal.
  • 73. The system of claim 66, further comprising a means for equalizing in communication with the means for filtering for equalizing the sampled continuous signal.
  • 74. The system of claim 73, further comprising means for detecting timing errors in communication with the means for equalizing, wherein the means for detecting timing errors is for generating a timing error signal based on the equalized samples of the continuous signal
  • 75. The system of claim 73, wherein the timing error signal is generated according to a linear model, wherein the linear model is expressed as: