The present invention is related to systems and methods for processing information, and more particularly to systems and methods for processing information received in a data transfer operation.
Data transfer systems typically include a receiver that converts an analog input into a stream of digital samples representing the analog input. For example, in a hard disk drive system, digital information is converted to an analog signal that is stored as a magnetic signal on a storage medium. The magnetic information is later sensed and converted back to an analog signal using a read circuit. The received analog signal is converted back to digital information representing the digital information originally provided to the storage medium. As another example, a wireless communication system involves a transmitter that receives digital information, and converts it to an analog signal that is transmitted. The analog signal is received and converted back to the original digital information that was originally prepared for transmission.
In such systems, the receiver typically utilizes a Viterbi algorithm data detector that is able to receive information including one or more errors, and to perform some level of error correction to reduce or eliminate any errors. Many approaches have been introduced to increase the achievable detector performance. For example, limited length pattern prediction filters looking only at previous bits on the media have been utilized. Such prediction filters have been tightly coupled to the final Viterbi detector target values, and operate as co-optimized filters that affect both the noise and expected portions of the received samples. Such approaches exhibit a variety of deficiencies including, but not limited to, an inability to consider the effect on a bit where a variety of different transitions may be involved, only a limited ability to de-correlate pattern dependent noise, and a length of data dependent detection that is fixed to the length of a final Viterbi target. Other approaches involve pattern dependent noise prediction to increase the bit error rate performance, but such implementations are typically highly complex. Further, the complexity of such approaches often causes a variety of difficulties in timing closure. To assure timing closure, such implementations are non-optimal and result in little if any increase in performance.
Hence, for at least the aforementioned reasons, there exists a need in the art for advanced systems and methods for processing received information.
The present invention is related to systems and methods for processing information, and more particularly to systems and methods for processing information received in a data transfer operation.
Various embodiments of the present invention provide data decoding circuits. Such circuits include a digital input signal that is provided to a pre-detector that detects an estimated pattern in the digital input signal. In addition, the digital input signal is provided to a summation element that subtracts the estimated pattern from the digital input signal to yield a noise estimate. The noise estimate is provided to a data dependent noise prediction filter that is statically tuned to detect a highly correlated noise pattern, and provides a filtered noise estimate. In some instances of the aforementioned embodiments, the circuits further include a post-detector that performs a data detection process on the digital input signal reduced by the filtered noise estimate. In some instances of the aforementioned embodiments, both the pre-detector and the post-detector are Viterbi algorithm detectors. In one case, the length of the pre-detector is less than the length of the post detector. Further, in some cases, the length of the post detector is different from the length of the data dependent noise prediction filter. In some cases, the data dependent noise prediction filter is a finite impulse response filter. In various instances of the aforementioned embodiments, another summation element is used along with a noise whitening filter. The noise whitening filter receives the digital input signal and provides a filtered digital input signal, and the other summation element is operable to subtract the filtered noise estimate from the filtered digital input signal to provide a noise reduced input signal. In some cases, the circuits further include an analog to digital converter that receives an analog input and provides the digital input signal.
Other embodiments of the present invention provide methods for data decoding that include receiving a series of digital samples, and pre-detecting an estimated pattern in the series of digital samples. The estimated pattern is subtracted from the series of digital samples to yield a noise estimate which is filtered using a data dependent noise prediction filter. The data dependent noise prediction filter is statically tuned to detect a highly correlated noise pattern and provides a filtered noise estimate. The filtered noise estimate is subtracted from a derivative of the series of digital samples, and the resulting noiseless data input is put through a post detection process. In some instances of the aforementioned embodiments, a simulation operation is performed that includes using a pre-defined pattern as the series of digital samples, and based on the results of the simulation process, the highly correlated noise pattern is determined.
In various instances of the aforementioned embodiments, pre-detecting the estimated pattern is done using a first Viterbi algorithm detector of a first length, and post-detecting the noiseless data input is done using a second Viterbi algorithm detector of a second length. In some cases, the second length is greater than the first length, and the second length is not equal to the length of the data dependent noise prediction filter. In some cases, the derivative of the series of digital samples is identical to the series of digital samples, while in other cases the derivative of the series of digital samples is a filtered version of the series of digital samples.
Yet other embodiments of the present invention provide communication systems that include a receiver with an analog to digital converter operable to receive an analog input and to provide a series of digital samples; a pre-detector that detects an estimated pattern in the series of digital samples; a summation element that subtracts the estimated pattern from the series of digital samples to yield a noise estimate; and a data dependent noise prediction filter that is statically tuned to detect a highly correlated noise pattern, and that filters the noise estimate and provides a filtered noise estimate. In some cases, the analog input is transmitted by a transmitter to the receiver via a transfer medium. In some such cases, the system is a hard disk drive system where the transfer medium is a magnetic storage medium, and in other such cases, the system is a wireless communication system where the transfer medium is an atmosphere through witch a radio frequency signal is transmitted.
This summary provides only a general outline of some embodiments of the invention. Many other objects, features, advantages and other embodiments of the invention will become more fully apparent from the following detailed description, the appended claims and the accompanying drawings.
A further understanding of the various embodiments of the present invention may be realized by reference to the figures which are described in remaining portions of the specification. In the figures, like reference numerals are used throughout several drawings to refer to similar components. In some instances, a sub-label consisting of a lower case letter is associated with a reference numeral to denote one of multiple similar components. When reference is made to a reference numeral without specification to an existing sub-label, it is intended to refer to all such multiple similar components.
The present invention is related to systems and methods for processing information, and more particularly to systems and methods for processing information received in a data transfer operation.
Various embodiments of the present invention utilize a simplified data detector as a pre-detector designed to refine an input to a later, more complex data detector. The “pre-detector” utilizes a simplified subset of an overall target to perform an early estimation of a given data sequence. This early estimation of the data sequence is used to generate estimates of the ideal target values which are then subtracted from the incoming sample to get the estimated noise component of the received signal. These estimated noise samples are then used to de-correlate the current noise sample using filters for specific data patterns with filter coefficients based on statistical analysis. A data dependent noise prediction filter provides de-correlation that uses the feed-forward information from the pre-detector so the length of the filter and transition effect on the current bit (i.e., how the adjacent transitions in both directions affect the current bit) do not affect a final detector target. This allows a shorter final target for the later data detector, but still allows longer data dependent noise predictive filters. Since only the noise is extracted for de-correlation, the precision of the filters can also be higher with the same bit length.
Turning to
In addition, filtered output 152 is provided to a simple detector 120 that performs a data detection using a simplified subset of an overall target (i.e., a simplified subset of the target of an extended detector 180) to perform an early estimation (i.e., determination of a most likely data pattern) of a given data sequence. In one particular embodiment of the present invention, simple detector 120 is a two bit Viterbi algorithm detector, and extended detector 180 is a Viterbi algorithm detector with a length greater than two bits. It should be noted that extended detector 180 is also referred to herein as a post-detector. Based on the disclosure provided herein, one of ordinary skill in the art will recognize a variety of detector lengths for simple detector 120 that may be used in accordance with various embodiments of the present invention. The output of simple detector 120 corresponds to the determined most likely pattern and is provided to a convolution filter 122 that in turn provides an estimated term 124 for the current sample. In some cases, the target used for convolution filter 122 is the final target of extended detector 180. In such cases, samples of filtered output 152 are statistically altered by the combination or simple detector 120 and convolution filter 122. The resulting output of convolution filter 122 is a noiseless estimate for the current received sample.
The result from convolution filter 122 is subtracted from filtered output 152 using a summation circuit 160. As the result from convolution filter 122 is a noiseless estimate for the current received sample, the output of summation circuit 160 is an estimate of noise 162 associated with the received sample. The result from convolution filter 122 is also provided to a sample timing control circuit 190 that is used to adjust sample clock 112. Sample timing control circuit 190 may be any circuit known in the art for adjusting the phase and/or frequency of an output clock based upon an input signal. As an example, sample timing control circuit 190 may be a phase lock loop or a delay lock loop circuit as are known in the art.
Noise estimate 162 is processed using a bank of data dependent noise prediction filters 172 that includes a number of data dependent noise prediction filters 174, 176, 178 each tuned to a respective, defined data pattern. In some embodiments of the present invention, data dependent noise prediction filters 174, 176, 178 are finite impulse response filters each tuned for a particular pattern. Of note, the length of data dependent noise prediction filters 174, 176, 178 is not governed by the length of extended detector 180. This allows for modification of data dependent noise prediction filters 174, 176, 178 without requiring a modification to extended detector 180. Each of data dependent noise prediction filters 174, 176, 178 operates as a de-correlation filter that de-correlates the noise component of the received signal. Noise prediction filters 174, 176, 178 each provide a respective noise estimate output 175, 177, 179. Of note, because only noise estimate 162 (a relatively small amplitude signal compared with the overall sample) is provided to data dependent noise prediction filters 174, 176, 178, the precision of the filters is greater than the same filter operating on the entire sample signal.
Data dependent noise prediction filters 174, 176, 178 estimate the noise correlation for specific data patterns included in filtered output 152. Minimum Euclidean distance calculations vary depending on the data pattern. The transition noise distribution is correlated to the data pattern since adjacent bits affect the transition noise of the current transition, and the amount of correlation may be determined through simulation processes using each different data pattern as an input. The information derived from the simulation can be used to determine which specific data patterns have the most correlation and will offer the best return for data dependent noise prediction. Based on this determination, data dependent noise prediction filters 174, 176, 178 may be hard wired for only those patterns that offer the greatest correlation, and therefore the best return for data dependent noise prediction. The number of noise prediction filters included filter bank 172 is selected based on the number of patterns to be tested. For example where a two bit pattern is to be tested, four noise prediction filters may be included to test all possible two bit patterns. Alternatively, where a three bit pattern is to be tested, eight noise prediction filters may be included to test all possible three bit patterns. As yet another alternative, where a longer pattern is to be tested it may not be practical to include a filter to test each and every possible pattern. In such situations, only a subset of the patterns may be tested. Based on the disclosure provided herein, one of ordinary skill in the art will appreciate that different numbers of noise prediction filters may be used depending upon the particular requirements of the implementation.
The Probability Density Function of the data dependent noise is described by a Gaussian distribution. The following equations summarize the aforementioned probability:
where rk=sk(b)+nk(b) and μp represent the optimal linear prediction. Use of the noise predicted outputs results in the following change to the branch metric of extended detector 180 (i.e., the branch metric of a Viterbi algorithm detector where extended detector 180 is implemented as a Viterbi algorithm detector):
For noise that is uncorrelated to the data, the term μp(b)=sk(b)+{circumflex over (n)}k(b) is sk (ideal target) and σp2(b) becomes a constant and can be removed. In this case the equation will reduce down to the following normal Viterbi branch metric equation:
(rk=sk)2.
Filtered output 152 is additionally provided to a noise whitening filter 170 that in this case is a generalized partial response filter that equalizes filtered output 152 to a given polynomial. Each of the aforementioned noise estimates 175, 177, 179 is subtracted from the output of noise whitening filter 170 using respective summation circuits 182, 184, 186. The outputs from each of summation circuits 182, 184, 186 represent digital samples 103 having been subjected to a noise reduction process and are provided to appropriate Branch Metric Units of extended detector 180. Extended detector 180 uses these improved samples in its branch metric difference calculations and also accounts for the correlated noise mean in those calculations. This will improve the bit error rate by de-correlating the noise of the received sample and allows a separate target for the Main FIR used for timing and bit sequence estimation. Of note, the taps provided to data dependent noise prediction filters 174, 176, 178 are hard coded. Other implementations discussed below in more detail allow for variable taps.
By separating estimated term 124 from filtered output 152 through use of an early detector or pre-detector (i.e., simple detector 120) to generate an estimate of the received data sequence, the noise term (i.e., the nk(b) term of the preceding equations) can then be used in the de-correlation filters to generate the final noise estimate for that sample. The actual filter coefficients can be computed using statistical analysis for each targeted data pattern. The estimated de-correlated noise (i.e., noise estimates 175, 177, 179) can then be subtracted from the current sample (i.e., filtered output 152) that has been equalized to an initial GPR target by whitening filter 170. Where extended detector 180 is a Viterbi algorithm detector, the final Viterbi detector target can be more elaborate than that of simple detector 120. Thus, filtered output 152 may be aided by the equalization of whitening filter 170 to translate the levels to those of extended detector 180. However, in some embodiments of the present invention, whitening filter 170 may be eliminated. Of note, the noise estimate in this case does not require any feedback from extended detector 180 since it only uses noise estimate 124 from the prediction process and feeds this information forward to extended detector 180.
As just some of many advantages, data decoding system 100 provides for increased error rate performance by providing data dependent noise prediction. Further, the architecture allows for longer noise prediction filters as the filter length is not tied to the length of any final target of the extended detector. Of note, the aforementioned noise prediction filters are capable of considering the effect that following bit transitions have on a current bit sample by inserting a delay in the feed forward path. This can be done without modifying the length of the final target of the extended detector, which avoids any unnecessary increase in design and operational complexity. Further, the use of the output from the simple detector to govern timing loop recovery allows for reduced latency in timing loop recovery compared to implementations where the output of an full length Viterbi detector is used as feedback.
Turning to
In contrast to the embodiments of the present invention discussed in relation to
Turning to
In addition, filtered output 252 is provided to a simple detector 220 that performs a data detection using a simplified subset of an overall target (i.e., a simplified subset of the target of an extended detector 280) to perform an early estimation (i.e., determination of a most likely data pattern) of a given data sequence. In one particular embodiment of the present invention, simple detector 220 is a two bit Viterbi algorithm detector, and extended detector 280 is a Viterbi algorithm detector with a length greater than two bits. It should be noted that extended detector 280 is also referred to herein as a post-detector. The output of simple detector 220 corresponds to the determined most likely pattern and is provided to a convolution filter 222 that in turn provides an estimated term 224 for the current sample. In some cases, the target used for convolution filter 222 is the final target of extended detector 280. In such cases, samples of filtered output 252 are statistically altered by the combination of simple detector 220 and convolution filter 222. The resulting output of convolution filter 222 is a noiseless estimate for the current received sample (i.e., estimated term 224).
The result from convolution filter 222 is subtracted from filtered output 252 using a summation circuit 260. As the result from convolution filter 222 is a noiseless estimate for the current received sample, the output of summation circuit 260 is an estimate of noise 262 associated with the received sample. The result from convolution filter 222 is also provided to a sample timing control circuit 290 that is used to adjust sample clock 212. Sample timing control circuit 290 may be any circuit known in the art for adjusting the phase and/or frequency of an output clock based upon an input signal. As an example, sample timing control circuit 290 may be a phase lock loop or a delay lock loop circuit as are known in the art.
Noise estimate 262 is processed using a bank of data dependent noise prediction filters 272 that includes a number of data dependent noise prediction filters 274, 276, 278 each adaptively tuned to a particular pattern based on variable taps 269 received from an adaptable tap source 271. In some embodiments of the present invention, data dependent noise prediction filters 274, 276, 278 are finite impulse response filters tuned based upon variable taps 269 to detect various highly correlated noise patterns. Of note, the length of data dependent noise prediction filters 274, 276, 278 is not governed by the length of extended detector 280. This allows for modification of data dependent noise prediction filters 274, 276, 278 without requiring a modification to extended detector 280.
Where the noise predictive filters are implemented as finite impulse response filters, an adaptation approach applicable to finite impulse response filters may be used. Finite impulse response adaptation uses an input sequence and an ideal output sequence. Gradient information based on the difference between the actual finite impulse response output and an ideal output from the extended detector is used to update variable taps that are used to drive the finite impulse response filters. Two common methods for doing this are the Least Mean Squares (LMS) algorithm and the Zero-Forcing (ZF) algorithm. Thus, adaptable tap source 271 may be implemented, for example, using zero forcing equalization or least means squared equalization. For the sake of an example, assume that the data dependent noise predictive finite impulse response filters P taps, namely h1, h2, . . . hp. The input to each of these finite impulse response filters is the noise sequence . . . ñ[k−2], ñ[k−1], ñ[k], ñ[k+1], . . . based on the bit decisions from simple detector 220. The output of a given filter (e.g., any of data dependent noise prediction filters 274, 276, 278) is the noise estimate given by the following equation:
Here, Δ is an integer that is greater than or equal to zero. When Δ is greater than zero, the finite impulse response predictor is using non-causal bit information for the noise prediction. To provide variable taps 269, ideal target values are needed. In this case, the ideal target values are the actual noise values seen for a specific pattern (i.e., noise estimates 275, 277, 279). These ideal noise values may be obtained by keeping the original received samples from filter 250 and subtracting off the ideal trellis target that the equalized sample should have been. The ideal trellis targets may be found by convolving the final bit decisions from, for example, extended detector 280 or a post processor (not shown) with the generalized partial response (GPR) target. For each received sample, only one of the trellis targets will be the correct target, so only one data dependent noise prediction finite impulse response filter is updated for every input sample.
Let ni[k] be the actual noise value that the i-th data dependent noise predictor filter should have predicted. The aforementioned actual notice may be determined by subtracting the received sample r[k] from the convolution of the filter output 252 with the GPR target, which results in the ideal Viterbi target s[k]. Let be the vector of ideal noise samples. Let be the vector of input samples to each of the N data dependent noise prediction filters, and let ñ[k]=[ñ[k]. . . ñ[k−P]]T be the vector of output samples from the i-th data dependent noise prediction filter. Also, let hki=[hi[1] . . . hi[P]]T be the current filter coefficients for the i-th data dependent noise prediction filter, and let hk+1i be the new filter coefficients of the i-th data dependent noise prediction filter after one update. Finally, let the error vector be defined as e[k]=n[k]−{circumflex over (n)}[k] and let μ be the learning rate of the adaptation. In such a case, the zero-forcing update will be:
h
k+1
i
=h
k
i
+μe[k]*n[k],
where “*” operator is an element-by-element multiply. In the same case, the least means squared update will be:
h
k+1
i
=h
k
i
+μe[k]. *ñ[k].
The only difference in implementation is whether the error vector is multiplied by the ideal output for zero forcing or the actual input in the data dependent noise prediction filters for least means squared. While the updates look similar, they have very different theoretical interpretations. The selection of the i-th data dependent noise prediction filter is based on the ideal output (i.e., bit decision pattern) provided by extended detector 280.
Filtered output 252 is additionally provided to a noise whitening filter 270 that in this case is a generalized partial response filter that equalizes filtered output 252 to a given polynomial. Each of the aforementioned noise estimates 275, 277, 279 is subtracted from the output of noise whitening filter 270 using respective summation circuits 282, 284, 286. The outputs from each of summation circuits 282, 284, 286 represent digital samples 203 having been subjected to a noise reduction process and are provided to appropriate Branch Metric Units of extended detector 280. Extended detector 280 uses these improved samples in its branch metric difference calculations and also accounts for the correlated noise mean in those calculations. This will improve the bit error rate by de-correlating the noise of the received sample and allows a separate target for the Main FIR used for timing and bit sequence estimation. Of note, the taps provided to data dependent noise prediction filters 274, 276, 278 are hard coded. Other implementations discussed below in more detail allow for variable taps.
The overall branch metric unit for the i-th branch in extended detector 280 may be defined by the following equation:
The method discussed to this point has focused on predicting the {circumflex over (n)}i[k] terms (i.e., noise estimates 275, 277, 279). Theoretically, the pattern dependent variances are:
where ni2[m]=(r[m]−si)2 is the squared noise term for a specific data pattern. This sum requires an infinite number of realizations, which is impractical. However, it is possible to track this sum using the following formula:
(σi2)new=α(σi2)odd+(1−α)ni2[m],
where 0<α<1 is the forgetting factor. When a is close to one, the algorithm weights the current estimate of the variance more than the current squared input noise sample. The value α can be a function of time. It is often the case that a will increase with time as the variance settles on the correct values. In fact, the variance is known to converge (asymptotically) to the correct value if α approaches one in the limit.
Turning to
The taps for the aforementioned data dependent noise prediction filters are adapted based on the output from the noise whitening filter (i.e., the input sequence) and the output from the later data detection process (i.e., the ideal output). The adaptation may be accomplished using a least means square processing algorithm or a zero-forcing algorithm (block 440). The variable taps that are provided are updated to the data dependent noise prediction filters (block 445).
Turning to
In conclusion, the invention provides novel systems, devices, methods and arrangements for processing information. While detailed descriptions of one or more embodiments of the invention have been given above, various alternatives, modifications, and equivalents will be apparent to those skilled in the art without varying from the spirit of the invention. Therefore, the above description should not be taken as limiting the scope of the invention, which is defined by the appended claims.