Decision Feedback Equalization (DFE) equalizes signal loss and interference on a signal. This signal loss and interference is often caused by a channel between the source of the signal and the receiver of that signal.
Not only may a channel cause signal loss and interference, this loss and interference may be different for different channels, change for a particular channel, and depend on the transmission rate of the signal. In part because of this, a particular equalization cannot accurately be set without taking into account the particular channel or, even for a particular channel, without an ability to change in response to changes in the loss or interference caused by that channel. DFE addresses this by making decisions about how to equalize loss and interference based on the signals received from the source and through the channel (this is a type of feedback). In effect, DFE continues to adapt based on the signals received to take into account the particular channel and changes to that channel.
A DFE's ability to accurately equalize for loss or interference depends on the signal's randomness. A random signal, also called a white signal, is one that has or can be closely approximated to have a random distribution of frequencies within a frequency band at which the signal is transmitted. Conversely, a non-random signal is typically referred to as a colored signal. A DFE is less accurate for a colored signal in part because the color of the signal may be confused with loss or interference caused by the channel.
Many signals transmitted today—especially those transmitted at comparatively high data-transmission rates—are not simply white signals. They are colored signals. As noted above, the more colored a signal, the less accurate current DFEs may equalize that signal.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
In some embodiments a method, computer-readable media, and/or system is described that acts or is capable of receiving signals each of which represents one of multiple possible bit patterns, the signals being received through a channel that causes amplitude loss or interference when passing through the channel. It may also determine, for each of the signals, which bit pattern of the multiple possible bit patterns each of the signals represents, the bit patterns of the signals being unequally distributed among the multiple possible bit patterns, after which it may retain a record of one or more of the received signals based on their respective bit patterns. It may also adapt equalizing coefficients using the record and based on a more-equal distribution of the multiple possible bit patterns than the unequally distributed bit patterns of the signals, the adapted equalizing coefficients capable of correcting, at least in part, the amplitude loss or the interference of the signals or new signals.
In other embodiments, a method, computer-readable media, system, and/or DFE engine is described that acts or is capable of receiving a signal having a bit pattern when received via a channel, the signal having amplitude loss across frequencies of a frequency band of the signal or interference caused when the signal passed through the channel. It may also determine, for the signal, the bit pattern that the signal represents and determine that the bit pattern for the signal has or has not been used to adjust one or more equalizing coefficients a predetermined number of times. It may then disregard the signal responsive to determining that the bit pattern has been used, or adjust the one or more equalizing coefficients responsive to determining that the bit pattern has not been used to adjust the one or more equalizing coefficients the predetermined number of times.
The detailed description is described with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different instances in the description and the figures may indicate similar or identical items.
Overview
As noted in the Background above, many signals transmitted today are colored signals. One example of this color is an unequal distribution of signals, the signals representing various bit patterns, and thus the color of the signals represents an unequal distribution of bit patterns. As noted above, the more colored a signal, the less accurately current DFEs may equalize that signal.
Various coding protocols are currently used that contribute to this unequal distribution of bit patterns. Some of these protocols limit the run length of bit patterns, sometimes called run-length-limited codes, which can make signals colored by limiting the type of bit patterns. Some of these run-length-limited codes do not permit a signal to be sent that represents a bit pattern having six or more zeros or ones in a row. Some of these protocols send idle bit patterns, which contribute to unequal bit pattern distribution because the idle bit pattern is often sent much more often than any of the other bit patterns. And some of these protocols send special code-word bit patterns that are more or less common than other bit patterns. Some coding protocols currently used for high-data-transmission rates (e.g., the 8b/10b line code) use all three of these contributors to unequal bit pattern distribution.
The following document describes tools capable of improving the accuracy of decision feedback equalization (DFE). The tools may adapt a DFE using a more-equal distribution of signals than those actually received. The tools may do so by disregarding, averaging, or weighting certain signals when adapting the DFE when those signals represent an unequal distribution of bit patterns. In one example, the tools detect and disregard some of the signals representing idle bit patterns that are received more often than other bit patterns. The tools may also or instead compensate for a bit pattern that is never or rarely received.
In the discussion that follows, an example operating environment is described that may incorporate, represent, or be used by the tools. Example procedures are also described that may be employed in the example operating environment as well as other environments. In the discussion below, reference will be made to the environment by way of example only. Therefore, implementation of the tools is not limited to the example environment. The term tools as used herein may refer to system(s), method(s), integrated circuit(s), various other hardware, computer-readable and/or executable instructions, and/or technique(s) as permitted by the context above and throughout the document.
This loss may be an unequal amplitude loss, such as high amplitude loss at particular frequencies (e.g., at or near the maximum frequency of the signal, also called the Nyquist frequency). The interference may include inter-symbol interference common to high data-transmission rates or other interference. The loss or interference is caused at least in part by the channel and may change over time as well. Temperature changes to the channel, data-transmission rate changes, and other protocol or environmental factors may affect the loss or interference between the source and receiver.
Signals 110 are received by receiver 106, either directly, or indirectly from DFE engine 112. DFE engine 112 may be integral with or separate from receiver 106. The DFE engine is capable of using a more-equal distribution of signals to equalize current or future signals than those actually received (i.e., signals 110).
The DFE engine may be implemented in hardware, firmware, and/or computer-readable media and may be digital, analog, or a combination of these. As shown in
The DFE engine may include or have access to a record 118. The DFE engine may use this record to track bit patterns so that the engine may adapt its equalizing coefficients 120 based on a more-equal distribution of signals than those actually received. The record may retain bit pattern occurrences (here bit patterns from 1 to N) and signals or information about the signals representing those bit patterns. The record may record that a particular bit pattern has two signals received for it and information about those two signals sufficient to adapt the equalizing coefficients to correct loss and/or interference in those signals, future signals, and other signals.
Equalizing coefficients 120 include one or more parameters, numbers, or equations with which the DFE engine may correct for loss and/or interference of signals 110.
As shown in
The following discussion describes decision feedback equalization techniques for signals having unequally distributed patterns. These techniques may be implemented utilizing the previously described environment or in other manners. Aspects of the procedure may be implemented in hardware, firmware, or software, or a combination thereof. The procedures are shown as a set of blocks that specify operations performed by one or more entities and are not necessarily limited to the orders shown for performing the operations by the respective blocks.
Block 202 receives signals each of which represents one of multiple possible bit patterns. As noted in part above, the received signals can be received from a source and through a channel and have loss, interference, or both from the channel. This loss may include an unequal amplitude loss across frequencies of a frequency band of the received signals. This interference may include inter-symbol or other types of interference.
By way of example, consider a case where these multiple possible bit patterns are restricted to 16 bit patterns by a run-length-limited code having a maximum length of 5 bits where the first bit set to 1:
Each of these received signals should represent one of these 16 possible bit patterns. Block 204 determines, for each of the received signals, which bit pattern of the multiple possible bit patterns each of the received signals represents. As noted above, the received signals are those that have been passed through a channel and therefore have experienced loss and/or interference. These signals, however, are similar to the pre-loss signals of
Block 206 retains a record of one or more of the received signals based on their respective bit patterns. The tools may act to determine which signals represent which bit patterns and record this in record 118. Assume, for the ongoing example, that 38 signals have been received and determined to represent the following unequal distribution of bit patterns:
The tools may act in various ways at this juncture. The tools may make the unequal distribution more-equal but not necessarily perfectly equal by adapting the DFE coefficients to an average of multiple received signals or the first or last of the signals that occurred for each of the bit patterns but without using a signal for a bit pattern that has not yet been received. Or the tools may wait until at least one signal for each bit pattern is received for an equal distribution. Or the tools may use a previously stored signal for a bit pattern for which a newer signal has not been received.
By way of example, consider a case where the tools record the signal for each of multiple occurrences of a particular bit pattern and weight those signals. In this case the tools may average the signals of 10001 so that the four occurrences of this bit pattern are weighted the same as the single occurrence of 11001 and 10110. In another example of the tools set forth in
The tools may also have a waiting period or maximum number of received signals before the tools proceed to adapt the DFE coefficients even if one or some of the possible bit patterns have not been received. Thus, the tools may determine or be pre-set to weigh the negative consequences of not adapting the DFE coefficients quickly with the possible inaccuracies of weighting the DFE coefficients with a more-equal but not entirely equal distribution of bit patterns. The tools may also record the prior signal or signals for a bit pattern and use that signal to adapt the DFE coefficients if the pre-set waiting period or number of signals received are met before another signal representing that bit pattern is received.
In the ongoing example the tools record all of the signals for each occurrence of the bit pattern and average each new signal for a particular bit pattern with the prior signals received for that bit pattern. The tools may also weigh the newest signal for a bit pattern heavier than older signals. Thus, if three signals are received, the first would start with a full weight of 1. The second would be averaged with the first so that both would have a half weight. The third would be averaged with the first two so that the first and second would have quarter weight and the third would have a half weight. Many other weighting techniques are contemplated herein, including those apparent to one skilled in the art of averaging, statistics, or weightings.
In the ongoing example, the tools continue to receive signals until at least one signal for each possible bit pattern is received. Continuing with the 38 signals received and noted above, assume that the tools continue to receive signals until 47 total signals are received before there is at least one signal for each bit pattern. Thus, the record may look like this:
At this point the tools proceed to block 208. Block 208 adapts, based on the record, equalizing coefficients capable of equalizing at least in part loss or interference in the received signals or new signals. These coefficients may be used to correct, at least in part, the above-noted unequal amplitude loss of received signals, inter-symbol interference, and/or other losses or interferences caused by the channel or otherwise. Block 208 adapts the DFE coefficients using a more-equal distribution of bit patterns than those received. As noted, this can be done by ignoring some bit patterns, using older bit patterns, decreasing the weight of repetitive bit patterns, or the like. This may effectively de-colorize or randomize the signals by reducing or removing unequal distribution of bit patterns represented in the signals received.
In another particular example, the tools receive a predetermined or determine the set of bit patterns that may be received, and retain in the record an equal number of signals for each bit pattern of the set. If predetermined or even determined by the tools, the set of bit patterns may be dictated by a protocol as mentioned above. This protocol may limit the set of bit patterns possible with run-length-limits, idle bit patterns, special code-word bit patterns, or in other manners. The protocols may exclude bit patterns, such as the 8b/10b line code excluding AKR idle bit patterns. The tools may determine the possible bit patterns based on the protocol being used, such as if the signals indicate this protocol through their structure or special code-word bit patterns.
Block 210 corrects the received signals or new signals based on the equalizing coefficients. In so doing the tools may correct for loss and/or interference of a channel even if the signals received are colored, whether by run length limits (noted in the example above), idle bit patterns, special code-word bit patterns, or otherwise. This equalizing may be effective to correct, at least in part, an unequal amplitude loss and/or inter-symbol interference caused by a channel through which the received signals passed.
Optionally, the tools may provide these equalizing coefficients to another entity for that entity to perform the equalizing. In the ongoing example however, DFE engine 112 may perform one, all, or any combination of blocks 202 to 210.
Block 302 receives a signal, the signal representing a bit pattern, the received signal received from a source and through a channel. The received signal may have amplitude loss and interference, such as unequal amplitude loss across frequencies of a frequency band of the received signal and inter-symbol interference, the loss or interference caused when the signal passed through the channel.
Block 304 determines, for the received signal, the bit pattern that the received signal represents after which block 306 determines that the bit pattern for the received signal has or has not been used to adjust one or more equalizing coefficients a predetermined number of times. The predetermined number of times applies to multiple other bit patterns, the bit pattern and the multiple other bit patterns comprised by a discrete set of multiple possible bit patterns capable of being received from the source and through the channel.
This predetermined number may be as little as one and reset to zero responsive to received signals representing all of the multiple possible bit patterns being used once to adjust the one or more equalizing coefficients.
If block 306 determines that the bit pattern for the received signal has not been used the predetermined number of times, the tools proceed to block 308. Otherwise, the tools disregard the signal at block 310 and proceed back to block 302. Alternatively, the tools may first proceed to block 312 after block 310 and before 302 (shown with the dashed arrow).
Block 308 adjusts, responsive to determining that the bit pattern for the received signal has not been used to adjust one or more equalizing coefficients more that a predetermined number of times, the one or more equalizing coefficients based on the received signal for the bit pattern. The tools may proceed to block 312 or back to block 302.
Note that the DFE engine and adaptation of the DFE coefficients may be performed in some cases more quickly and cheaply with a hardware-based and analog DFE engine. In this case the tools, through the DFE engine, may forgo retaining the signal or information about the signal other than to immediately use it to adapt the DFE coefficients. Thus, if the predetermined number is one, the tools may toggle a 1 or 0 in a hardware record for each bit pattern and, once a signal for a particular bit pattern is used to adapt the DFE coefficients, toggle the record to 1. Once all of the bit patterns have been used once the tools can toggle all of the 1s to 0s and start over again. Consider
Block 312 corrects the received signals or new signals based on the equalizing coefficients. Block 312 may be performed after block 308, after block 310, or at any point in the procedure or even outside of the procedure, such as by some external entity. In the ongoing example, however, the DFE engine continuously adapts the DFE coefficients and continuously equalizes received signals using those coefficients.
Through these and other procedures and techniques contemplated herein, the tools are effective, directly or indirectly, to correct at least in part the loss and/or interference caused by a channel.
Performance Improvement
The following discussion and accompanying
The setup for these simulations includes a backplane channel (pre-emphasized with a high-pass feed forward equalization). The simulations simulate a DFE implemented using the procedure of
Many signals transmitted today are colored. The more colored a signal, the less accurately current DFEs may equalize that signal. This document describes tools capable of improving the accuracy of decision feedback equalization (DFE) for colored signals, including those colored by having unequally distributed patterns. By so doing the tools improve the accuracy of data transfer or reduce the cost of data transfer, especially for systems and protocols having high data-transmission rates.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.
This application claims priority to U.S. Provisional Patent Application Ser. No. 60/987,916 filed Nov. 14, 2007, entitled “Methods of DFE Adaptation Protection Against Colored Patterns” to Haoli Qian and Xing Wu, the disclosure of which is incorporated by reference herein in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4449190 | Flanagan et al. | May 1984 | A |
5245704 | Weber et al. | Sep 1993 | A |
5623474 | Oshio et al. | Apr 1997 | A |
5778029 | Kaufman | Jul 1998 | A |
6031628 | Jacob et al. | Feb 2000 | A |
6255906 | Eidson et al. | Jul 2001 | B1 |
6266517 | Fitzpatrick et al. | Jul 2001 | B1 |
6275685 | Wessel et al. | Aug 2001 | B1 |
6639944 | De Haan et al. | Oct 2003 | B1 |
6667659 | Stengel et al. | Dec 2003 | B2 |
6731406 | Ganapathy et al. | May 2004 | B1 |
6912249 | Haartsen | Jun 2005 | B2 |
6950469 | Karczewicz et al. | Sep 2005 | B2 |
6983026 | Pinckley et al. | Jan 2006 | B2 |
7023941 | Rey et al. | Apr 2006 | B1 |
7262722 | Jahanghir et al. | Aug 2007 | B1 |
7362818 | Smith et al. | Apr 2008 | B1 |
7418057 | Shako et al. | Aug 2008 | B2 |
7447274 | Shako et al. | Nov 2008 | B2 |
7450641 | Sun et al. | Nov 2008 | B2 |
7466762 | Shako et al. | Dec 2008 | B2 |
7599431 | Anderson et al. | Oct 2009 | B1 |
7675886 | Agrawal et al. | Mar 2010 | B2 |
7702020 | Gallant et al. | Apr 2010 | B2 |
7706475 | Kopikare et al. | Apr 2010 | B1 |
7782973 | Kim et al. | Aug 2010 | B2 |
7822147 | Huang et al. | Oct 2010 | B2 |
8014737 | Pratt et al. | Sep 2011 | B2 |
8160150 | Moore | Apr 2012 | B2 |
20020067773 | Jackson et al. | Jun 2002 | A1 |
20020072346 | Kato et al. | Jun 2002 | A1 |
20030164736 | Stengel et al. | Sep 2003 | A1 |
20030179831 | Gupta et al. | Sep 2003 | A1 |
20040090909 | Khlat | May 2004 | A1 |
20040232984 | Meade et al. | Nov 2004 | A1 |
20050018519 | Nii | Jan 2005 | A1 |
20050213661 | Xiang et al. | Sep 2005 | A1 |
20050231292 | Akahori et al. | Oct 2005 | A1 |
20050243946 | Chung et al. | Nov 2005 | A1 |
20060126962 | Sun | Jun 2006 | A1 |
20060174236 | Stein et al. | Aug 2006 | A1 |
20060227895 | Booth et al. | Oct 2006 | A1 |
20070025448 | Cha et al. | Feb 2007 | A1 |
20070086528 | Mauchly et al. | Apr 2007 | A1 |
20070118791 | Hepler et al. | May 2007 | A1 |
20070135065 | Leffel et al. | Jun 2007 | A1 |
20070241812 | Yang et al. | Oct 2007 | A1 |
20080031376 | Ban | Feb 2008 | A1 |
20080049709 | Pan et al. | Feb 2008 | A1 |
20080074289 | Sauder et al. | Mar 2008 | A1 |
20080094280 | Fenton | Apr 2008 | A1 |
20080219373 | Zhang et al. | Sep 2008 | A1 |
20080270344 | Yurick et al. | Oct 2008 | A1 |
20090097533 | Lakkis | Apr 2009 | A1 |
20090103622 | Tripathi et al. | Apr 2009 | A1 |
20090181622 | Hardacker | Jul 2009 | A1 |
20090257526 | Wang et al. | Oct 2009 | A1 |
20090310704 | Jethanandani et al. | Dec 2009 | A1 |
20100035554 | Ba et al. | Feb 2010 | A1 |
Entry |
---|
“Non-Final Office Action”, U.S. Appl. No. 12/397,057, (Nov. 9, 2011), 7 pages. |
“Non-Final Office Action”, U.S. Appl. No. 12/510,716, (Nov. 8, 2011), 8 pages. |
Mujtaba, Syed A., “TGn Sync Proposal Technical Specification”, IEEE 802.11-04 / Wireless LANs, (May 2005), pp. 1-131. |
Zhang, Hongyuan et al., “U.S. Appl. No. 12/098,222”, (Apr. 4, 2008), 78 pages. |
“Final Office Action”, U.S. Appl. No. 12/397,057, (Apr. 27, 2012), 11 pages. |
“Non-Final Office Action”, U.S. Appl. No. 12/253,078, (Jun. 8, 2012), 18 pages. |
“Non-Final Office Action”, U.S. Appl. No. 12/511,606, (Jan. 4, 2012), 6 pages. |
“Non-Final Office Action”, U.S. Appl. No. 12/511,629, (Apr. 13, 2012), 6 pages. |
“Non-Final Office Action”, U.S. Appl. No. 12/574,879, (Jun. 4, 2012), 11 pages. |
“Final Office Action”, U.S. Appl. No. 12/574,879, Nov. 20, 2012, 13 pages. |
“Final Office Action”, U.S. Appl. No. 12/511,629, Dec. 7, 2012, 7 pages. |
“Non-Final Office Action”, U.S. Appl. No. 12/767,922, Nov. 2, 2012, 12 pages. |
“Final Office Action”, U.S. Appl. No. 12/510,716, Jun. 28, 2012, 10 pages. |
“Final Office Action”, U.S. Appl. No. 12/511,606, Sep. 13, 2012, 8 pages. |
“Non-Final Office Action”, U.S. Appl. No. 12/397,057, Aug. 1, 2012, 10 pages. |
“Final Office Action”, U.S. Appl. No. 12/397,057, Feb. 1, 2013, 13 pages. |
“Final Office Action”, U.S. Appl. No. 12/253,078, Feb. 13, 2013, 21 pages. |
“Non-Final Office Action”, U.S. Appl. No. 12/574,879, Apr. 23, 2013, 13 pages. |
“Notice of Allowance”, U.S. Appl. No. 12/767,922, Apr. 16, 2013, 5 pages. |
“Notice of Allowance”, U.S. Appl. No. 12/511,629, Mar. 28, 2013, 7 pages. |
Number | Date | Country | |
---|---|---|---|
60987916 | Nov 2007 | US |