The current invention relates to arbitrary waveform generators for playing back stored waveforms, and more particularly to phase coherent playbacks of stored waveforms when switching between different stored waveforms.
Arbitrary waveform generators (AWG), such as the AWG7000 series manufactured by Tektronix, Inc. of Beaverton, Oreg., use a digital-to-analog (D/A) converter to play out waveforms that are stored digitally in a memory. The AWG provides various methods for switching playout on and off, and for switching between waveforms.
The waveform playout system produces an output analog voltage from a D/A converter on a waveform output line by repeatedly converting the digitized samples into output analog voltage levels. The rate of this conversion is given by an output sample rate, R, which is a number measured in samples per second, and which is a parameter of operation of the waveform playout system. The parameter, R, typically may be altered by a user of the AWG. The rate at which the waveform playout system uses the memory access connection to access the waveform memory is not necessarily the same as R. All that is required is that, on average, the waveform playout system obtains digitized samples from the memory at a higher rate than the rate needed to produce the waveform output, as is well known in the art.
The operation of the waveform playout system is further governed by a sequencer, as described below.
The time delay, Td, is provided because the mechanism by which the waveform playout system accesses the waveform memory requires time to adjust from one waveform to another after receiving the step indication from the sequencer. The time delay also allows the sequencer to align with greater resolution the time of playout change with the detailed timing behaviors of event inputs supplied to the sequencer.
As a result of the mechanism described above, the sequencer is able to instruct the waveform playout system to begin playout of the waveforms that the sequencer selects, such playouts beginning at times which the sequencer selects. In a typical AWG the sequencer may be controlled by a user-supplied program, and may engage in behaviors such as (1) selecting particular waveforms in a user-specified order, (2) repeating a waveform for a user-specified number of cycles, (3) making decisions based on the behavior of event inputs, (4) making decisions based on moments in time when the behaviors of the event inputs occur, and (5) various combinations of these behaviors, as is well known in the art and represented in commercially available products.
AWGs are used in the test and measurement environment to simulate a real life situation for testing various devices. For example, a test signal from an AWG, such as a wireless communication signal, may be used to test the operation of a cellular telephone. In a real environment the wireless communication signal may be interrupted by some form of interference, such as electrical or physical interference. Electrical interference may take the form of a radiated signal that swamps the wireless communication signal. Physical interference may take the form of a building or terrain that temporarily blocks the wireless communication signal. However, the wireless communication signal continues to transmit even though the signal is not being received. When the interference is removed, the received wireless communication signal has phase coherence with the wireless communication signal prior to the interference.
When switching between waveforms in the waveform memory, current practice is for the AWG to start at the beginning of each new waveform, i.e., the waveform playout system always starts the waveform playout with digitized sample w0. However, sometimes the user wants the switching to be phase coherent to simulate a wireless communication signal, as discussed above, which means that the output waveforms should behave as though the waveform is being switched between generators that are synchronized with each other, i.e., the generators are always playing, rather than as though the switching operation resets the generator.
What is desired is a phase coherent playback in an arbitrary waveform generator when switching between waveforms to a previously selected waveform.
Accordingly, the present invention provides for phase coherent playback in an arbitrary waveform generator when switching between waveforms to a previously selected waveform. The arbitrary waveform generator has a waveform memory for storing data samples representing multiple waveforms, a waveform playout for playing out the multiple waveforms from the waveform memory as analog waveforms, and a sequencer for controlling the waveform playout by providing a waveform selection indication, a step indication and a delay indication so the waveform playout plays out a selected one of the multiple waveforms from the waveform memory according to a desired event. Additionally the arbitrary waveform generator provides a waveform starting position indication from the sequencer to the waveform playout, the waveform starting position indication tracking a conceptual data sample position within the data samples for the selected one of the multiple waveforms, the data samples for the selected one of the multiple waveforms being tracked by the sequencer to produce phase coherence of the selected one of the multiple waveforms when played out again by the waveform playout according to the desired event. To generate the waveform starting position indication, the sequencer has a clock generator for providing a clock signal at a desired playout rate, and a counter having as inputs the clock signal from the clock generator and a modulus representing a number of data samples for the selected one of the multiple waveforms. The counter continuously counts pulses of the clock signal from zero to (modulus−1) to produce an offset signal to the sequencer that tracks the conceptual data sample position within the selected one of the multiple waveforms. The sequencer generates the waveform starting position indication from the offset signal when the selected one of the multiple waveforms is played out by the waveform playout again according to the desired event.
The objects, advantages and other special features of the present invention are apparent from the following detailed description when read in conjunction with the attached drawing figures and appended claims.
The present invention has two parts: (1) adding an indication of a waveform starting position that is provided by a sequencer to a waveform playout in an arbitrary waveform generator (AWG); and (2) adding to the sequencer a means of tracking the phase of a previously output waveform to achieve phase coherence when the waveform playout returns to the previously output waveform.
Referring now to
Instead of beginning with a digitized sample, w0, of a selected waveform as in the prior art described above, the waveform playout 16 begins with a sample, Wn, where “n” is the content of the waveform starting position indicator 22 provided to the waveform playout by the sequencer 20. In other words, the waveform playout 16 does not begin playing the waveform from the waveform memory 12 at the waveform's beginning, but at an offset from the beginning of the waveform as indicated by the waveform starting position indicator 22.
Referring back to
It is desired to use the AWG 10 of
The operation of starting phase coherently is achieved by the sequencer 20 sending an appropriate waveform starting position indicator 22 to the waveform playout 16. As a result of the waveform starting position indicator 22, in step E7 the waveform playout 16 does not start playback of the waveform E3 at its beginning, but instead the waveform playout starts playback of waveform E3 in such a way that the graph of the output in
In order for the sequencer 20 to support the operation of re-starting a waveform phase coherently, as described above, the sequencer requires some means for computing an appropriate value of the waveform starting position indicator 22. The output of the signal generator 40 of
h1(t)=A cos(2πFt+θ)
where A, F and θ are numerical values chosen according to the characteristics of the signal generator 40. The effect is to switch between the waveform h1(t) and a different function h2(t) of time, where h(2)=0. At the moment t2 the output is switched from waveform h2 back to h1, where the desired output is h1(t2) rather than h1(0). The quantity 2πFt+θ is called the “phase”, and the value of h1 at time t2 is substituted by the sequencer 20 rather than another value, such as t=0. This is the origin of the term “phase coherent.”
Therefore the sequencer 20 has to “track the phase”, i.e., be able to provide a starting position that corresponds to the desired phase at h1(t2).
At time t1 of
A clock generator 50, a counter 56, a rate parameter source 58 and a modulus parameter source 59 together create the desired behavior of the offset input 52. The counter 56 holds a value whose meaning is the sample position that travels through the waveform. The clock generator 50 applies its clock output to the counter 56 in order to increment the counter. The rate parameter source 58 is adjusted to apply the output sample rate R to the clock generator 50 so that the counter 56 increments at the output sample rate R. To achieve looping through the waveform, the modulus source 59 applies a modulus to the counter 56 so that, whenever the counter reaches the modulus, the counter returns to zero. As a result the counter 56 counts from 0 to (modulus−1) and then repeats. The modulus parameter source 59 is set to the number of data points in the stored waveform. Thus the behavior of the counter 56 is just what is needed to represent the conceptual sample position that loops back to the beginning of the waveform when it reaches the end of the waveform.
When the sequencer 20 asserts the reset signal to the counter 56, the counter is reset to zero, which has the effect of moving the concpetual sample position to the beginning of the stored waveform, i.e., the reset signal establishes a point in time at which the sample position is at the beginning of the stored waveform. The reset signal is asserted at the beginning of the execution of the sequencer program, as shown in the Table E2 of
To start playing a waveform phase coherently, the rate parameter source 58 is set to the output sample rate, R, and the modulus parameter source 59 is set to the data length of the stored waveform. The sequencer 20 asserts the reset signal at a moment when the sample position within the waveform should be aligned to zero, such as at the beginning of a sequencer program. Then, when the sequencer 20 desires to switch back to the waveform and start its playback coherently, the sequencer consults the offset input 52 to determine the current conceptual sample position of the waveform. The sequencer 20 uses this information, together with the value of the delay indication 28 that the sequencer intends to apply to the waveform playout 16, to determine the appropriate value of the waveform starting position indicator 22 to use when the sequencer asserts the step indication 26.
More specifically, if the sequencer 20 intends to assert the step indication 26 at a time that is Tstep after the moment the sequencer samples the offset input 52, if the sequencer intends to send Tdelay as the value of the delay indication 28 along with the step indication, if the value sampled for the offset input is Noffset, if the output sample rate is R, and if the data length of the stored waveform to be started phase coherently is Nwfmlength, then the appropriate value of the waveform starting position indicator 22 is computed as
(Noffset+round((Tstep+Tdelay)*R))mod Nwfmlength
The design of a high speed counter, such as counter 56, in a modern digital system may use a variety of implementation techniques, such as pipelining, that are well known to those skilled in the art.
The essence of the present invention is that the sequencer 20 keeps track of conceptual sample position that loops through the samples of a stored waveform, by means of the modulo counter 56, and uses this information to choose the sample position within the stored waveform at which the waveform's playback starts phase coherently. The sequencer 20 may use a multiplicity of counters 56 to track the sample positions of a multiplicity of waveforms. The sequencer 20 may control a multiplicity of waveform playouts 16, thereby achieving phase coherency between waveforms that are played out on different channels of the AWG 10. Two sequencers 20 may share the use of a single counter 56 to establish a common notion of the conceptual sample position of the stored waveform, thereby achieving phase coherence between waveforms that are played out on different channels of the AWG 10.
Referring now to
Another extension of the present invention is shown in
Nderived=(M1/M2)
Therefore the sample position of the second waveform may be obtained as:
(Offset)/M2
And the number so calculated travels from zero to M2−1, repeating this loop Nderived times as the offset input travels once through its range.
It might be desirable to establish a more general relationship in time between the first and second stored waveforms, so the offset adjustment source 70 also accepts as an input a phase, PH, from a derived phase parameter source 74, which is a number between 0 and M−1 inclusive. The offset adjustment source 70 computes the derived offset as:
(Derived Offset)=(Offset mod M)+PH
As shown in
Thus the present invention provides an arbitrary waveform generator that produces phase coherent waveforms when switching back to a prior waveform by tracking sample position within the prior waveform when the waveform is not being played out.