The present invention relates to a method of acquiring and processing a received data signal for analysis in a digital oscilloscope.
Traditionally, when receiving waveforms for processing by a test instrument, such as an oscilloscope, the waveforms are acquired as a number of discrete acquisitions, the timing of the start and/or end of each acquisition being defined in accordance with a trigger signal. The trigger signal is typically asynchronous with the sampling process and generated in accordance with an external signal, clock or frame synchronization signal. The difference in time of the moment of the trigger and the sampling process is measured, and thus, each acquired waveform's samples are assigned to a particular phase, relative to the trigger signal. These typically brief waveforms, or data acquisition segments, are either stored for later processing, or may be processed immediately. However, this acquisition scheme has a number of significant drawbacks when used in a high-speed data acquisition environment. The quality and consistency of the data acquisitions are dependent on the precision of the timing measurement relating the trigger signal to the timing of the sampling clock used to store the data signal. Any imprecision in the timing measurement between the two, known as trigger jitter, will result in the phase of the discrete data signal acquisitions to be out of synchronization with the true phase of the data signal, as well as with the phase of the other data acquisitions, thus limiting the ability to compare various ones of the data signal acquisitions, and moreover limiting the ability to correctly characterize the signal.
Additionally, the generation of a precisely accurate clock signal is made harder when a high-speed data acquisition with a substantially large number of bits is to be acquired. The high-speed nature of the acquisition requires a very fast clock signal, thus compounding the possibility for jitter. Because of the extremely short acquisition times, any clock jitter becomes a larger percentage of the acquisition time, thus resulting in an even larger phase difference between the various acquisition data segments. While it would be possible to use a slower clock signal and leave out some data from the data signal so that all of the data is not stored and processed, this method is undesirable because, for example, a non-recurring error may be encountered but not properly identified and processed because all of the data will not be considered.
An additional limitation with this method is that a dead-time is incurred between each signal acquisition, while the time measurement apparatus and storage apparatus are prepared to record another acquisition. In the context of measurements performed on a serial data signal, the dead-time inherent in this method prohibits the analysis of immediately adjacent data bits as distinct waveforms, or for that matter a long stream of contiguous data bits as distinct waveforms.
Therefore, an improved method and apparatus for acquiring and processing an acquired data signal for analysis in a test instrument, such as a digital oscilloscope is desired.
In accordance with the invention, a method and apparatus are provided for acquiring a long, continuous portion of a data stream that allows for the capture of every bit in a received signal under test during a predetermined time period, corresponding to up to millions of bits or more. In opposition to current techniques that typically do not save a long record and therefore cannot show individual bits as desired in accordance with the present invention, a long, continuous data signal is acquired so that each and every bit in the signal can be processed and later retrieved.
In order to later process the acquired and stored data signal, since the stored data signal is a single long acquisition with no predetermined dividing points, it is advantageous to generate a clock signal synchronous to some regularly occurring event in the acquired data signal. Therefore, in accordance with the invention, the acquired waveform that is to be divided up to generate a series of “sample sets” or “slices” at nearly uniform sample intervals is analyzed for threshold crossings. The expected times of these threshold crossings obtained after various processing correspond to the regular intervals of an entirely conceptual or virtual “periodic clock”. Such a step in what is called “clock recovery” determines generally the frequency of the virtual clock. However, the complete process of clock recovery further requires synchronizing the recovered virtual periodic clock with the analyzed threshold crossings by adjusting the phase of the virtual clock.
The “error” or time difference between the expected value of a threshold crossing transition time (given by the virtual periodic clock) and the observed threshold crossing time can be used as a feedback to alter the expected value of a threshold crossing time (and therefore the recovered clock). In accordance with this procedure, the expected value of a threshold crossing transition time (recovered clock) is locked to the actual observed value of the threshold crossing transition time. This kind of feed-back in the context of clocks in an analog apparatus is called a “phase-locked-loop” (PLL). In accordance with the invention, the implementation is in software and the expected times are calculated by adding floating-point numbers rather than using resonating circuits. By removing the variability of any physical components, the timing of such a virtual clock can be precisely correlated to the data signal. Furthermore, the response of the PLL can be very precise and stable thereby making its effect on the measurement very predictable and precisely repeatable.
By thus locking the expected value of a threshold crossing transition time to the actual observed value of the threshold crossing transition time, this expected value of a threshold crossing transition time can be used to derive the ideal “sampling times” of the digitally encoded signal in the stored waveform. These sampling times can be used as the virtual clock signal. Using the thus-recovered virtual clock, the long data record can be sliced into smaller data records, each one including one or more bit intervals. These smaller records, or segments, can be overlaid to create an accurate eye diagram. The set of slices extracted from such a signal, allows for very accurate mask violation testing to be performed on a long, high-speed data signal.
By re-sampling the data record exactly between each virtual clock transition, the bit states for each bit interval can be deduced. This allows for the determination of ISI (Inter-Symbol Interference) from such data signals. In addition, since all of the bit periods are derived from the data stream and not from independent triggers, the effect of trigger jitter is eliminated.
Regarding the rendering of an eye diagram, there has been employed a standard method that has been used for many years to observe noise and jitter in communications signals. The procedure consists of triggering an oscilloscope on a data-stream with some trigger delay greater than one bit period so there is some “synchronicity” between the display and the observed data-stream. Since the data (for simplicity assumed to be non-return to zero (NRZ) data) has a relatively random state relative to the initial state at the time of trigger, a shape called an “eye-diagram” appears on the oscilloscope screen. This method is useful for formulating a visual conception of the variations in signal shape with regard to voltage and timing, these factors playing a role in the reliability of operation of the data channel being observed.
A better method for this procedure includes the steps of triggering the oscilloscope on the clock with which the signal would be received. One is therefore able to observe variations in voltage and time in a fashion most similar to such variations in an actual receiver circuit. A significant drawback with this second method is however, that in very many cases, the receive clock is not available. Other complications may also arise even when such a receive clock is available, such as the triggering instability of the measuring instrument contributing significantly to the jitter observed in the eye diagram.
Therefore an improved method and apparatus for generating a clock signal and locking the phase of an acquired signal thereto to allow for improved measurement fidelity thereof would be desirable. Also, an improved method and apparatus for rendering an eye diagram would be desirable. The present invention provides such an improved technique.
Still other objects and advantages of the invention will in part be obvious and will in part be apparent from the specification and the drawings.
The invention accordingly comprises the several steps and the relation of one or more of such steps with respect to each of the others, and the apparatus embodying features of construction, combination(s) of elements and arrangement of parts that are adapted to effect such steps, all as exemplified in the following detailed disclosure, and the scope of the invention will be indicated in the claims.
In accordance with the invention, a long, continuous acquisition record of a data signal is captured and stored, including every bit in the data signal during a predetermined duration corresponding to up to millions of bits or more. Such a long, continuous data signal is acquired and stored so that each and every bit in the signal can be processed and later retrieved, as will be described below.
Clock Recovery
Referring first to
The observed times of threshold crossing are compared to an expected time of threshold crossing at step 130. The expected times of threshold crossing correspond to the regular intervals of an entirely conceptual or virtual “periodic clock” that is intended to correspond, after correction as noted below, to the sequence of expected times of threshold crossing.
The phase of the recovered clock is then adjusted to properly synchronize with the observed times of threshold crossing in the recorded data signal in step 135. The amount of phase adjustment in each bit interval is determined by mathematical algorithms precisely defining the dynamic response of the software PLL. The dynamic response of the PLL can be matched to the communications standard associated with the data signal under analysis under software control.
Because the recorded waveform under analysis is not necessarily of a clock but rather of a data stream presumably generated in accordance with a clock, a transition will not occur for each bit interval. That is, some transitions in the actual data signal may not be present because some consecutive bit locations may have the same value (consecutive logic “1”, for example), and therefore not have a transition between them. It is possible to determine how many of these bit locations do not have transitions by assuming that the observed transitions have a correspondence with the closest expected transition of the generated virtual clock. As such, it is possible to associate every transition observed with a virtual clock transition, and to know exactly how many cycles of the generated virtual clock have passed since the previous observed transition.
As in an analog phase-locked-loop (PLL) a phase error (time interval error “TIE”) between the expected value of a threshold crossing time determined in accordance with the recovered virtual periodic clock and the actual observed value of the threshold crossing time can be used as a feedback signal to alter the expected value of a threshold crossing time, and thus the phase of the recovered virtual clock, as is shown in step 140. In step 145 this generated error feedback signal is fed back and used at step 135 to adjust the phase of the expected time of threshold crossing. This procedure is repeated and continued until all the expected values of threshold crossing times, and therefore phase of the recovered virtual clock is locked to the actual observed values of the threshold crossing times. In accordance with the invention, the implementation is in software; the expected times being calculated by adding floating-point numbers rather than using resonating circuits, but the result being quite similar. The result is also more repeatable than the analog counterpart because the functionality does not depend on manufactured components that have initial inaccuracies and which change over time and varying environmental conditions, but rather is a mathematical calculation. Thus, any additional jitter generated in accordance with physical generation of a clock signal is avoided.
By locking the expected time values of a threshold crossing to the actual observed values of the threshold crossing time, this expected value of a threshold crossing time can be used to derive the ideal “sampling times” of the digitally encoded signal in the recorded waveform, as is shown in step 150. These times are between the expected times of threshold crossing (when that data is NOT changing, rather than when it is changing). Having determined these expected values of time of threshold crossing, and thus ideal sampling times, the recorded waveform can be decoded according to these ideal sampling times (recovered periodic clock) to determine bit states of the data during each “slice” of the data signal.
Each slice of data is therefore obtained from a recorded signal of many bit transitions and by using the clock recovery system in accordance with the invention. The waveform of the data signal can therefore be sliced up and represented as a series of smaller waveforms (each derived from the original) but which span some number of bits from the original data signal in a precisely prescribed period of time. As such, a “slicer” serves the purpose of supplying such waveforms each of which is a subset of the waveform of the input data signal, and that are synchronized with the recovered clock (extracted from the same waveform), and for which the state of the bits in each slice are (or can be) known. Specifically, as displayed on an oscilloscope, it supplies waveforms with an effective trigger time corresponding to, for example, the first division (of ten) and an end of one bit interval (unit-interval) at the 9th division on the oscilloscope display, although other timing sequences may be employed as desired. As such these waveforms are ideal for further processing as they are precisely synchronized and in phase with the recovered virtual clock.
Mask Violation Locator
A mask violation locator is also provided in accordance with the invention. A mask violation locator operates by comparing an acquired signal that is preferably displayed as an eye diagram to a predetermined mask. Any portions of the acquired signal that cross into an excluded region of the mask constitute a violation condition. In this manner, a data signal can be compared to a predefined set of criteria to ensure that the signal is of acceptable quality.
The mask violation locator in accordance with the invention operates by first acquiring a long record of digitized samples of a serial data signal under test (as noted above). This acquired record is stored, and is then subsequently retrieved and divided into intervals including a predetermined number of bits as determined through the clock recovery process and slice generating process performed on the digitized signal as described above.
As is shown in
Referring next to
At step 340, an eye diagram is generated by overlaying each sliced segment of the original data signal and accumulated with all of the others segments in an x,y,z display where the x and y values represent a time of acquisition and corresponding voltage level and the z axis accumulates the frequency of occurrence of each x,y value, as is shown in
A long record is analyzed for threshold crossings, and if (as is usually the case) the signal under test is a data channel, instead of a clock, the crossings are associated with virtual clock edges, as described above.
In what would otherwise be a calculation of the Time Interval Error (TIE) one finds the dependent information of the exact extracted clock edge time, and from this information a small subset of the original waveform can be presented with the “correct” time association with the virtual (expected) clock, as was described in detail above and generated in accordance with the feedback process associated with the clock generation and slicing sequences.
Given these subset representations, the long-memory record containing many symbols duration or bit intervals, can be re-expressed as a multitude of smaller waveforms, each occurring at their exact time and thus eliminating trigger jitter, on a display grid synchronized with the equivalent communications receiver's expected clock timing. This procedure can supply a very rapid response (allowing for a single large acquisition rather than many small acquisitions), the quality of which is independent of the trigger stability of the recording instrument, but which is instead dependent only on the recording instrument's channel noise characteristics and time-base (sampling interval) stability which can be better than the trigger stability by more than an order of magnitude. In a preferred embodiment of the invention, it is estimated that at the current state-of-the-art, it should be possible to acquire and display a sliced-eye-diagram at an equivalent rate of 500 thousand bit waveform acquisitions per second for a communications signal of 2 Gigabits per second, recorded at 20 Gigasamples per second. This is a valuable capability in a single-shot digital oscilloscope or any piece of communications test equipment.
Referring back to
As shown in
Mask Failure Show unit 425 receives two inputs, list values 415 from Mask Failure Accumulator 410 listing segment numbers containing a mask error violation, and the original waveform data from 310 of
Therefore, upon the receipt of various waveform slices and cursors that define an area of interest, the Mask Failure Accumulator accumulates a list of waveform slices, or segments that violate a mask. This list of segments is forwarded to the Mask Failure Show unit, which chooses the corresponding received waveform slices, and forwards them to be displayed in a manner as shown in
The Mask Failure Accumulator contains a 16×20 array of bins, which correspondingly map to a displayed frame. In a preferred embodiment, each bin therefore corresponds to ¼ of a major division square of an oscilloscope display. Each defined bin is associated with a vector containing the indices of segments with any detected mask failures positioned near the location of the particular bin. In a preferred embodiment, this vector is represented as a long integer since a short integer value may not be sufficient. The index of the current segment is obtained from the slicer at step 340 of
The output results provided by the Mask Failure Accumulator 410 corresponding to the parameters 415 are built based on the contents of the array of lists and a bounding box specified by various user-selected control variables. The Parameter output 415 contains representations of all of the failures corresponding to any bins that are at least partially included in the user defined bounding box. The cursor output provided by the Mask Failure Accumulator 410 is based on the control settings (e.g. how many bit intervals before and after the bit containing the error are to be shown) and the failure information provided by the compare to mask unit 350.
The Mask Failure Show unit 425 receives the original waveform from 310, and the list of segment numbers 415. The list 415 includes horizontal coordinate information identifying the region of the original waveform associated with each mask failure to be shown.
Referring back to
There are many significant benefits associated with the present invention.
It is well known that interference between symbols in data or communications signals is a contributor to both vertical and horizontal signal variations. The basic effect is that the shape and timing of the data-symbol is affected by the precise sequence of prior symbols. That is, the symbols immediately preceding an observed bit-interval affect the eye-diagram observed. Thus, even employing the procedure noted above, various other distorting factors must be accounted for.
This portion of the invention described herein provides a method for isolating the individual contributions to ISI based upon an analysis of data acquired in a single (or multiple) acquisitions or recordings of the communications channel under observation. By determining this systematic contribution to horizontal timing jitter, one obtains directly a distribution of jitter which is fundamentally “bounded” and deterministic for a representative data stream. (i.e. one of the components of deterministic jitter is extracted directly from the recording of the communications channel).
The present invention operates as a “sliced-pattern-averager” and therefore employs a variant of the slice method as noted above. In accordance with the invention, one large record of a data or communication channel is assimilated into a series of signal averaged signals, each specific to a certain prior symbol-state pattern or sequence.
In accordance with this invention, a specific ISI component of jitter and of vertical variations in the communications channel may be identified. Thus, a diagram similar to an eye-diagram, but which is (relatively) free of random noise is provided, since the signals are “signal averaged” to eliminate noise. Finally, this method provides a means for obtaining the horizontal distribution of ISI perturbations to the jitter distribution, which can be used as a tool for deconvolution of the total jitter distribution and further for the purpose of identifying the magnitude and shape of non-symbol-dependent jitter and vertical noise.
After obtaining the various slices of the waveform as described above, rather than combining all of these signals into a single persistence display, the information is examined for N intervals prior to an observed bit interval, and for the bit interval immediately following the bit-interval under observation. The signal is analyzed for the NRZ state at the center (between the virtual recovered clocks) to obtain the each bit state and thus the exact bit sequence of each small record (subset) consisting of M=N+1+1 bits. The slices are thus classified into 2 to the power M categories. Then depending on the precise pattern of bits for each slice, one of 2 to the power of M averages is updated. It is important to note that typically each of these averages has greater horizontal resolution than the original waveform, and thus the average is not a simple average. Thus, for each possible pattern of the M bits, an average output for each small record is provided by averaging all of the M bit sequences.
Upon completion of analyzing the entire waveform, the 2 to the M resultant waveforms, which are each an average of the actual signal data, are superimposed on a single bit interval display. This overlaid display is quite similar in scale and shape to the eye-diagram which could have been formed by using all of the actual data signal information before averaging. However the vertical and horizontal randomness, in as much as it is incoherent with the bit patterns (the 2 to the power M sequences) is averaged “out” or removed from the diagram. Thus, as is shown in
This procedure can supply a very rapid response using fewer large acquisitions rather than many small acquisitions, the quality of which is independent of the trigger stability of the recording instrument, but which is instead dependent on the recording instrument's time-base (sampling interval) stability.
There are many significant benefits associated with this invention. This method allows for obtaining ISI contributions to both vertical and horizontal signal variations (jitter and noise). While other methods, such as in a digital sampling-scope (in contrast to a single-shot or real-time digital oscilloscope) are used to measure noise free symbol responses by stimulating the data stream with a known pattern, the method in accordance with the invention does not require a specific stimulus or even a priori knowledge of the patterns present in the data stream. Rather, it sorts the information from any (either PRBS or truly random . . . or even “live”) data stream. The method determines ISI-based deterministic jitter and noise rapidly and free from the statistical assumptions common to the industry for the purposes of obtaining estimates of deterministic jitter.
It will thus be seen that the objects set forth above, among those made apparent from the preceding description, are efficiently attained and, because certain changes may be made in carrying out the above method and in the construction(s) set forth without departing from the spirit and scope of the invention, it is intended that all matter contained in the above description and shown in the accompanying drawings shall be interpreted as illustrative and not in a limiting sense.
It is also to be understood that the following claims are intended to cover all of the generic and specific features of the invention herein described and all statements of the scope of the invention which, as a matter of language, might be said to fall therebetween.
This application claims the benefit of U.S. Provisional Patent Application Ser. No. 60/415,236, filed Sep. 30, 2002, the entire contents of which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
3449671 | Long | Jun 1969 | A |
3562710 | Halleck | Feb 1971 | A |
3778550 | David et al. | Dec 1973 | A |
4100531 | Fletcher et al. | Jul 1978 | A |
4375694 | Kuhn | Mar 1983 | A |
4615040 | Mojoli et al. | Sep 1986 | A |
4633465 | Fitch et al. | Dec 1986 | A |
4680778 | Krinock | Jul 1987 | A |
4694244 | Whiteside et al. | Sep 1987 | A |
4758963 | Gordon et al. | Jul 1988 | A |
4843309 | Kareem et al. | Jun 1989 | A |
4876655 | Carlton et al. | Oct 1989 | A |
4964117 | Shier | Oct 1990 | A |
5159609 | Palicot | Oct 1992 | A |
5180971 | Montijo | Jan 1993 | A |
5214784 | Ward et al. | May 1993 | A |
5222101 | Ariyavisitakul | Jun 1993 | A |
5305635 | James et al. | Apr 1994 | A |
5337403 | Klingman | Aug 1994 | A |
5402443 | Wong | Mar 1995 | A |
5432791 | Gancarcik | Jul 1995 | A |
5631759 | Bogdan et al. | May 1997 | A |
5654987 | Nakamura | Aug 1997 | A |
5714878 | Saito et al. | Feb 1998 | A |
5726607 | Brede et al. | Mar 1998 | A |
5761216 | Sotome et al. | Jun 1998 | A |
5761434 | Hewitt | Jun 1998 | A |
5761537 | Sturges et al. | Jun 1998 | A |
5789954 | Toeppen et al. | Aug 1998 | A |
5825825 | Altmann et al. | Oct 1998 | A |
5900755 | Toeppen et al. | May 1999 | A |
5907587 | Sokoler | May 1999 | A |
5914592 | Saito | Jun 1999 | A |
5943378 | Keba et al. | Aug 1999 | A |
5953071 | Van Zon | Sep 1999 | A |
5966684 | Richardson et al. | Oct 1999 | A |
5978742 | Pickerd | Nov 1999 | A |
5999163 | Ivers et al. | Dec 1999 | A |
6009132 | Sholtz | Dec 1999 | A |
6044123 | Takla | Mar 2000 | A |
6112160 | Salant et al. | Aug 2000 | A |
6188737 | Bruce et al. | Feb 2001 | B1 |
6212246 | Hendrickson | Apr 2001 | B1 |
6215363 | Conta et al. | Apr 2001 | B1 |
6278357 | Croushore et al. | Aug 2001 | B1 |
6295327 | Takla | Sep 2001 | B1 |
6311138 | Miller | Oct 2001 | B2 |
6356127 | Klipper et al. | Mar 2002 | B1 |
6366631 | Nakayama et al. | Apr 2002 | B1 |
6407970 | Verboom | Jun 2002 | B2 |
6445230 | Rupp et al. | Sep 2002 | B1 |
6463109 | McCormack et al. | Oct 2002 | B1 |
6522122 | Watanabe et al. | Feb 2003 | B2 |
6539318 | Miller et al. | Mar 2003 | B2 |
6546345 | Ghiasi | Apr 2003 | B1 |
6549859 | Ward | Apr 2003 | B1 |
6571186 | Ward | May 2003 | B1 |
6615148 | Pickerd | Sep 2003 | B2 |
6642926 | Letts | Nov 2003 | B1 |
6643346 | Pedrotti et al. | Nov 2003 | B1 |
6647523 | Manning | Nov 2003 | B2 |
6675328 | Krishnamachari | Jan 2004 | B1 |
6738922 | Warwar et al. | May 2004 | B1 |
6738992 | Lochtefeld | May 2004 | B2 |
6812688 | Tan et al. | Nov 2004 | B2 |
6836738 | Sepp et al. | Dec 2004 | B2 |
6850852 | Ferguson et al. | Feb 2005 | B1 |
6853696 | Moser et al. | Feb 2005 | B1 |
6922384 | Miyashita et al. | Jul 2005 | B2 |
6996202 | McCormack et al. | Feb 2006 | B2 |
20010021151 | Verboom et al. | Sep 2001 | A1 |
20020018572 | Rhoads | Feb 2002 | A1 |
20020034337 | Shekter | Mar 2002 | A1 |
20020128787 | Seng et al. | Sep 2002 | A1 |
20030004664 | Ward et al. | Jan 2003 | A1 |
20030163266 | Ward et al. | Aug 2003 | A1 |
20040123018 | Miller et al. | Jun 2004 | A1 |
20040123191 | Salant et al. | Jun 2004 | A1 |
20040123208 | Miller et al. | Jun 2004 | A1 |
20040153883 | Miller et al. | Aug 2004 | A1 |
Number | Date | Country |
---|---|---|
2462046 | Nov 1975 | DE |
0 241 142 | Oct 1987 | EP |
0 444 875 | Sep 1991 | EP |
0 631 143 | Dec 1994 | EP |
1 074 845 | Feb 2001 | EP |
1 118 866 | Jul 2001 | EP |
1 244 241 | Sep 2002 | EP |
2 138 575 | Oct 1984 | GB |
62003544 | Jan 1987 | JP |
4105070 | Apr 1992 | JP |
5196641 | Aug 1993 | JP |
5264595 | Oct 1993 | JP |
9005362 | Jan 1997 | JP |
10163859 | Jun 1998 | JP |
11098876 | Apr 1999 | JP |
8220144 | Jun 1999 | JP |
WO 0060806 | Oct 2000 | WO |
WO 2004 032049 | Apr 2004 | WO |
Number | Date | Country | |
---|---|---|---|
20040153883 A1 | Aug 2004 | US |
Number | Date | Country | |
---|---|---|---|
60415236 | Sep 2002 | US |