PHase cycling with correct result. Just not sure if there is still a bug...

This commit is contained in:
jupfi 2024-06-08 14:18:52 +02:00
parent f39af81d68
commit 7e954f05e7
2 changed files with 7 additions and 7 deletions

View file

@ -91,7 +91,7 @@ class SimulatorController(SpectrometerController):
if readout_scheme and number_phasecycles > 1: if readout_scheme and number_phasecycles > 1:
# Apply the readout scheme # Apply the readout scheme
tdy = np.zeros(len(measurement_data.tdx[0]), dtype=complex) tdy = np.zeros(len(measurement_data.tdx[0]), dtype=np.complex128)
for cycle in range(number_phasecycles): for cycle in range(number_phasecycles):
tdy += (readout_scheme[cycle][0] * measurement_data.tdy[cycle]) tdy += (readout_scheme[cycle][0] * measurement_data.tdy[cycle])

View file

@ -137,7 +137,7 @@ class TestQuackSequence(unittest.TestCase):
pi = Event("pi", "12u", seq) pi = Event("pi", "12u", seq)
seq.add_event(pi) seq.add_event(pi)
seq.set_tx_amplitude(pi, 100) seq.set_tx_amplitude(pi, 100)
seq.set_tx_phase(pi, 180) seq.set_tx_phase(pi, 90)
seq.set_tx_n_phase_cycles(pi, 1) seq.set_tx_n_phase_cycles(pi, 1)
seq.set_tx_phase_cycle_group(pi, 0) seq.set_tx_phase_cycle_group(pi, 0)
@ -161,7 +161,7 @@ class TestQuackSequence(unittest.TestCase):
seq.set_rx(rx, True) seq.set_rx(rx, True)
# Readout scheme for phase cycling TX pulses have the scheme 0 90 180 270 for the first pulse and 180 always for the second pulse # Readout scheme for phase cycling TX pulses have the scheme 0 90 180 270 for the first pulse and 180 always for the second pulse
readout_scheme = [[1, 0], [1, 270], [1, 180], [1, 90]] readout_scheme = [[1, 0], [1, 90], [1, 180], [1, 270]]
seq.set_rx_readout_scheme(rx, readout_scheme) seq.set_rx_readout_scheme(rx, readout_scheme)
@ -170,10 +170,10 @@ class TestQuackSequence(unittest.TestCase):
# Plotting the results # Plotting the results
plt.title("Phase cycling") plt.title("Phase cycling")
logger.info(f"Number of data sets {len(result.tdy)}") logger.info(f"Number of data sets {len(result.tdy)}")
plt.plot(result.tdx[0], abs(result.tdy[0]), label="pc 1") plt.plot(result.tdx[0], result.tdy[0].real, label="pc 1")
plt.plot(result.tdx[1], abs(result.tdy[1]), label="pc 2") plt.plot(result.tdx[1], result.tdy[1].real, label="pc 2")
plt.plot(result.tdx[2], abs(result.tdy[2]), label="pc 3") plt.plot(result.tdx[2], result.tdy[2].real, label="pc 3")
plt.plot(result.tdx[3], abs(result.tdy[3]), label="pc 4") plt.plot(result.tdx[3], result.tdy[3].real, label="pc 4")
plt.plot(result.tdx[4], abs(result.tdy[4]), label="Phase Cycling") plt.plot(result.tdx[4], abs(result.tdy[4]), label="Phase Cycling")
plt.legend() plt.legend()
plt.show() plt.show()