Skip to content
Hlab edited this page Jan 29, 2013 · 22 revisions

Programming Pulse Sequences

DDS and TTL Pulses

Using pulse_sequence

  • provide some examples, files

Photon Counting

  • readout
  • time tags

Plot Sequence / Human Readout

DDS (phase coherent dds board)

Phase Coherence

The phase coherent DDS boards maintain phase coherence of the generated RF signal if the generated frequency is kept constant. For example, if the pulse sequence has two back-to-back pulses of the same frequency, they will have the same phase as measured relative to an external clock. Any change of frequency destroys phase coherence. As long as the frequency is kept constant, however, the phase can be set to an arbitrary value for every pulse.

Immediate Switching

Switching the frequency on the DDS board takes several microseconds but changing the amplitude is immediate. Therefore to achieve switch to the new pulse conditions with no delays, the frequency has to be programmed first, and then the amplitude should be changed at the start time of the pulse. A 6 microsecond difference between frequency and amplitude programming should be sufficient.

Version Tracking

Version 1.15

  • DDS Hardware settings distinguish between remote dds boards and phase coherent dds boards. This allows for phase coherent boards that are local. See parameters phase_coherent_model and remote in HardwareConfiguration.py.sample.

Version 1.1

  • Ability to do Line Triggering

Version 1.0.3

  • Simplified clearing pmt counts when either the count rate or the mode is changed. Now, after every change first two counts from the FPGA are removed. This removed all spikes.

Version 1.0.2

  • Bug fix: InCommunication DeferredLock was not used while using the 'output' setting. This led to freezes while rapidly turning pulser off and on.

Version 1.0.1

  • Added resetstepDuration parameter to the HardwareConfiguration. This controls the duration of the TTL pulses used to advance and reset the DDS boards. Should be set to 2.

Version 1.0

  • Adds the ability to have an optical 2nd PMT, and DAC. (Merge from Dylan, CCT).

  • Fixed bug of not programming remaining pulses if a 0-length dds pulse encountered.

  • Syntax changed required for simpifying GUIs:

    self.pulser.output(name, False)

instead of

self.pulser.select_channel(name)
self.pulser.output(False)
  • DDS Lock Behavior Change:

The dds lock is activated when any pulse sequence is programmed. It can now be cleared only when the pulse sequence is completed or a a new setting called clear_dds_lock is called. This setting has to be called at the end of each experiment that requires to pulser even if the measurement is interrupted. This means one needs a try, except block and run the experiment in a console where it is sensitive to keyboard interrupt.