-
Notifications
You must be signed in to change notification settings - Fork 10
Pulser server
- provide some examples, files
- readout
- time tags
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.
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 5 microsecond difference between frequency and amplitude programming should be sufficient.
- 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
andremote
inHardwareConfiguration.py
.
- Ability to do Line Triggering
- 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.
- Bug fix: InCommunication DeferredLock was not used while using the 'output' setting. This led to freezes while rapidly turning pulser off and on.
- 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.
-
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.