This invention relates generally to apparatus and methods for detecting communication signals, and, more particularly, to detecting communication signals containing signal-dependent noise.
With the continuing evolution of computer systems, there is an increasing demand for greater storage density. For example, due to advances in technology, the areal densities of magnetic recording media have increased steadily over the past several years. To increase areal densities using longitudinal recording, as well as increase overall storage capacity of the media, the data bits are typically made smaller and put closer together on the magnetic media (e.g., the hard disc). However, there are limits to how small the data bits can be made. If a bit becomes too small, the magnetic energy holding the bit in place may also become so small that thermal energy can cause it to demagnetize. This phenomenon is known as superparamagnetism. To avoid superparamagnetic effects, magnetic media manufacturers have been increasing the coercivity (the “field” required to write a bit) of the media. However, the coercivity of the media is limited by the magnetic materials from which the write head is made.
In order to increase the areal densities of magnetic media even further, many media manufacturers are using perpendicular recording. Unlike traditional longitudinal recording, where the magnetization is lying in the plane of the magnetic medium, with perpendicular recording the media grains are oriented in the depth of the medium with their magnetization pointing either up or down, perpendicular to the plane of the disc. Using perpendicular recording, manufacturers have exceeded magnetic recording densities of 100 Gbits per square inch, and densities of 1 Terabit per square inch are feasible.
However, as storage densities increase, the signal processing and detection of recording channels becomes more difficult. Sources of distortion, including media noise, electronics and head noise, signal transition noise (e.g., transition jitter), inter-track interference, thermal asperity, partial erasure, and dropouts, are becoming more and more pronounced. Particularly troublesome are signal-dependent types of noise, such as transition jitter, because these types of noise are quickly becoming the dominant sources of detection errors. Signal-dependent noise may overwhelm white noise and severely degrade the performance of detectors designed for a white noise channel.
The most common type of detector is the linear Viterbi detector. This detector assumes the span of inter-symbol interference is limited and the channel noise is additive white Gaussian noise. Accordingly, linear Viterbi detectors perform poorly when the channel includes a high signal-dependent noise component. There have been attempts to design detectors to mitigate signal-dependent noise. However, current detectors designed to combat signal-dependent noise have problems. One problem with these types of detectors is their complexity. In order to detect data in the presence of signal-dependent noise, the detectors must employ complicated correction schemes, such as modifying the Euclidean branch metric to compensate for the noise. For example, some currently available detection techniques use either a non-linear Viterbi detector assuming the noise is Markov, or a non-linear post-processor with a similar Markov noise model. For a description of a non-linear post-processor with a Markov noise model, see U.S. Pat. No. 6,931,585, to Burd et al., which is hereby incorporated by reference herein in its entirety.
Another problem with current detection techniques is that they only perform well when the variance of the signal-dependent noise is small. This is because the first-order Taylor approximation of the noise process is only valid for small values of variance. Thus, when the signal-dependent noise variance is large, these detection techniques are far from optimal.
Thus, it would be desirable to provide a more reliable detector architecture for detecting signals containing signal-dependent sources of noise, such as transition jitter and pulse width noise. It would be further desirable to provide a detector that does not assume the channel noise is auto-regressive, and, therefore, the detector may be an optimal detector for channels with signal-dependent noise.
These and other objects of the invention are accomplished in accordance with principles of the present invention by providing a nonlinear detector for channels with signal-dependent noise. The detector may choose a channel data sequence that maximizes the conditional probability of the detector's input signal given the channel data sequence. As such, the detector may be considered a maximum likelihood (ML) detector that does not assume the channel noise is Markov or auto-regressive.
In some embodiments, to simplify the branch metric calculation, the nonlinear detector assumes the conditional probability takes some form, such as a Gaussian distribution. In some of these embodiments, the detector may further assume that the mean and variance of the conditional probability also take some form. For example, the mean may be a function of the detector's input and the branch trellis whereas the variance may be only a function of the branch trellis.
Since the channel may be time-varying and the channel characteristics may not be exactly known, in some embodiments the detector may include an adaptation block. The adaptation block may receive the detector's input and output and adapt at least one of the parameters in the branch metric computation.
In some embodiments, the detector may also include a loading block. The loading block may receive the output of the adaptation block and perform some normalization or simplification of the branch metric parameters before passing them to the detector. This may reduce the logic (and complexity) required in the detector.
In one embodiment of the invention, adaptation means may receive the detector input and adapt at least one branch metric parameter until the steady-state value (or a user-programmable acceptable value) is reached. Loading means may normalize the one or more parameters received from the adaptation means and send the parameters to data detection means. The data detection means may then choose a data sequence that maximizes the conditional probability, and output means may output the data sequence.
In one embodiment of the invention, a computer program running on a processor is provided for detecting a channel signal containing signal-dependent noise. The program may include program logic to adapt one or more branch parameters. The program logic may then normalize the branch metric parameters and maximize the conditional probability of the channel signal given the channel data.
Further features of the invention, its nature and various advantages, will become more apparent from the accompanying drawings and the following detailed description.
Embodiments of the present invention relate to apparatus and methods for detecting data signals, particularly magnetic recording channel data signals. However, the present invention may be used to detect a signal from any communication channel in which there is signal-dependent noise, such as optical and magneto-optical channels.
s(t−kTs−Δk)≈s(t−kTs)−Δks′(t)|t=kT
Similar to
This product may be approximated (assuming finite memory) by focusing on the local area as:
where L is the memory factor and the previous state sk-1 and the current state sk represent a branch in the trellis. In EQ 4, J is some number that determines the complexity of the system. For example, in some embodiments, the larger the value of J, the greater the complexity.
In some embodiments, instead of calculating P(y|u) directly, the detector may calculate −log(P(y|u)), if desired. Accordingly, in these embodiments, the branch metric that the detector calculates may corresponds to:
−log(P(yk|sk-1,sk,yk-Lk-1) (EQ 5)
The remainder of the detection process may be similar to a standard Viterbi detection process (e.g., the detector may employ the Viterbi algorithm).
The branch metric of EQ 5 may be calculated by the detector in many ways. In one embodiment, a look-up table is used. Using a look-up table may be the most straightforward way to calculate the branch metric. The branch metric may be looked up in the table using the signal y and the index of the trellis branch. However, the table size may be prohibitively large, especially if there is a large range of y. Therefore, in some embodiments, a hybrid approach may be used, whereby certain branch metrics are computed using a look-up table, while other branch metrics are computed using EQ 6, described below. In some embodiments, assumptions may be made about the form of the conditional probability. For example, to simplify the branch metric calculation, the conditional probability may be assumed to take the form of a Gaussian distribution. In other embodiments, the probability may be assumed to take different forms, such as a Rayleigh, chi-square, Cauchy, or log-normal distribution.
Assuming the probability takes a Gaussian distribution, for example, the probability may be described by its mean m and variance σ2. After removing some constant factors, the branch metric may then be calculated as:
To further simplify the calculation, the mean m and variance σ2 can also be assumed to take certain forms. For example, the detector can assume the mean and variance are linear or quadratic. In one embodiment, the detector assumes the mean m can take the form:
where the parameters b and fi are functions of the particular trellis branch. Similarly, in some embodiments the variance σ2 may be assumed to be a function of the trellis branch only (and not a function of y).
Although the components of
In some embodiments, adaptation block 404 may provide one or more of these adapted parameters directly to detector 402. In other embodiments, adaptation block 404 may provide one or more of these adapted parameters to loading block 406. Loading block 406 may perform various simplification, normalization, or pre-calculations on the adapted parameters received from adaptation block 404 in order to simplify the detector's branch metric calculation. For example, as shown in EQ 6, the branch metric calculation may require logarithm and division by the variance. These steps may be complex for the detector to compute and may require additional logic in the detector. Moreover, the detector may receive a wide-range of signal values (e.g., equalizer targets), and some parameters of the branch metric calculation may exceed the range specified by the precision setting. Therefore, in order for the detector to accept a wide-range of signal values and to simplify the branch metric computation in the detector, one or more of the branch metric parameters may be normalized and/or pre-computed as shown in more detail below in
where ck is the linear branch value corresponding to yk, z is a constant, and L is the memory factor. In EQ 8, the mean m is assumed to take a slightly different, but equivalent, form than that of EQ 7 for ease of illustration. The branch metric parameters to be adapted may include, for example, fi, σ2, and z. In some embodiments, these parameters may be adapted as:
where sgn is the sign of the difference value and the μ parameters determine the adaptation speed. The parameters to be adapted (e.g., fi, σ2, and z) may initially be set to the values corresponding to the linear Viterbi detector. In addition, initially the p parameters may be set to larger values and then reduced to smaller values close to or at steady-state, if desired. In some embodiments, the adaptation may be run until steady-state values of the parameters of EQ 9 are reached. In other embodiments, for faster performance the adaptation may stop before steady-state values are reached.
Since the parameters fi, σ2, and z depend on the trellis branch, there may be one adaptation block for each trellis branch. However, in some embodiments, adaptation blocks may be shared among more than one trellis branch. Since the parameters fi, σ2, and z may take similar values between more than one trellis branch, similar branches may be grouped together in order to reduce the number of adaptation blocks and, hence, the complexity of the system. The adaptation block groupings may vary depending on one or more of the parameter values.
In the example of
One or more of these parameters may be adapted at any convenient time. For example, the parameters may be adapted for every new sector of input data. As another example, the parameters may be adapted after a user-programmable amount of time or when the received samples have changed their values by some user-programmable threshold value (e.g., a moving average or mean calculation has deviated greater than some threshold value), or any other convenient time.
Once the branch metric parameters have been adapted, the parameter b may be computed as:
In some embodiments, the detector may now calculate the branch metric using EQS 6 and 7. However, from these equations, it is clear that the branch metric calculation requires some complex computation, such as logarithm and division by the variance. Moreover, the detector ideally should be able to handle a wide range of equalizer targets. Therefore, in some embodiments the branch metric parameters may be further processed by loading block 406 (
Instead of passing the branch metric parameters b, fi, and σ2 directly to the detector, in some embodiments these parameters may be normalized first. For example, in one embodiment, the loading stage may pass 1/σ, fi/σ, b/σ, and an offset value to the detector as the branch metric parameters. Since scaling and adding a constant to the branch metric will not change the detector's decision, a new branch metric that is simpler to compute may be calculated. For example, this new branch metric may take the form of:
BMnew=σmin2BMold−σmin2 log(σmin2) (EQ 11)
where BMold is the branch metric defined by EQS 6 and 7 and σ2min is the minimum variance among all the branches.
In the example of
The computation of the normalized branch metric parameters and the offset value are shown in illustrative
Referring now to
Referring now to
The HDD 900 may communicate with a host device (not shown) such as a computer, mobile computing devices such as personal digital assistants, cellular phones, media or MP3 players and the like, and/or other devices via one or more wired or wireless communication links 908. The HDD 900 may be connected to memory 909 such as random access memory (RAM), low latency nonvolatile memory such as flash memory, read only memory (ROM) and/or other suitable electronic data storage.
Referring now to
The DVD drive 910 may communicate with an output device (not shown) such as a computer, television or other device via one or more wired or wireless communication links 917. The DVD 910 may communicate with mass data storage 918 that stores data in a nonvolatile manner. The mass data storage 918 may include a hard disk drive (HDD). The HDD may have the configuration shown in
Referring now to
The HDTV 920 may communicate with mass data storage 927 that stores data in a nonvolatile manner such as optical and/or magnetic storage devices. At least one HDD may have the configuration shown in
Referring now to
The cellular phone 930 may communicate with mass data storage 944 that stores data in a nonvolatile manner such as optical and/or magnetic storage devices for example hard disk drives HDD and/or DVDs. At least one HDD may have the configuration shown in
Referring now to
The set top box 950 may communicate with mass data storage 960 that stores data in a nonvolatile manner. The mass data storage 960 may include optical and/or magnetic storage devices for example hard disk drives HDD and/or DVDs. At least one HDD may have the configuration shown in
Referring now to
The media player 970 may communicate with mass data storage 980 that stores data such as compressed audio and/or video content in a nonvolatile manner. In some implementations, the compressed audio files include files that are compliant with MP3 format or other suitable compressed audio and/or video formats. The mass data storage may include optical and/or magnetic storage devices for example hard disk drives HDD and/or DVDs. At least one HDD may have the configuration shown in
It will be understood that the foregoing is only illustrative of the principles of the invention, and that various modifications can be made by those skilled in the art without departing from the scope and spirit of the invention.
This application is a continuation of commonly assigned, U.S. patent application Ser. No. 13/415,465, filed Mar. 8, 2012, which is a continuation of, commonly assigned, U.S. patent application Ser. No. 11/493,269, filed Jul. 25, 2006 (now U.S. Pat. No. 8,160,181), claiming the benefit of U.S. Provisional Patent Application Nos. 60/729,699, filed Oct. 24, 2005, 60/742,692, filed Dec. 6, 2005, and 60/798,879, filed May 8, 2006, each of which is hereby incorporated by reference herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6201839 | Kavcic et al. | Mar 2001 | B1 |
6931585 | Burd et al. | Aug 2005 | B1 |
7173783 | McEwen et al. | Feb 2007 | B1 |
8462897 | Song et al. | Jun 2013 | B1 |
20050169412 | Yang et al. | Aug 2005 | A1 |
20060093075 | Radich | May 2006 | A1 |
Entry |
---|
Bahl, L. R., Cocke, J., Jelinek, F., and Raviv, J., “Optimal Decoding of Linear Codes for Minimizing Symbol Error Rate,” IEEE Transactions on Information Theory, Mar. 1974. |
Kavcic, A. and Moura, J., “The Viterbi Algorithm and Markov Noise Memory,” IEEE Transactions on Information Theory, vol. 46, Jan. 2000. |
Zayed, N. M. and Carley, L. R., “Equalization and Detection in Nonlinear Storage Channels with Signal-Dependent Noise,” Digital Signal Processing Proceedings, 1997, DSP 1997, 1997 13th International Conference, vol. 2, Jul. 2-4, 1997, pp. 1027-1030. |
Number | Date | Country | |
---|---|---|---|
60729699 | Oct 2005 | US | |
60742692 | Dec 2005 | US | |
60798879 | May 2006 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13415465 | Mar 2012 | US |
Child | 13901315 | US | |
Parent | 11493269 | Jul 2006 | US |
Child | 13415465 | US |