mirror of
https://github.com/nqrduck/quackseq-limenqr.git
synced 2025-01-04 17:38:07 +00:00
Corrected default sampling frequency. Fixed resampling.
This commit is contained in:
parent
4548513d06
commit
e47f8f9dd3
2 changed files with 45 additions and 26 deletions
|
@ -58,10 +58,15 @@ class LimeNQRController(SpectrometerController):
|
||||||
measurement_data = self.process_measurement_results(lime, sequence)
|
measurement_data = self.process_measurement_results(lime, sequence)
|
||||||
|
|
||||||
# We resample the data to the dwell time settings
|
# We resample the data to the dwell time settings
|
||||||
# measurements = self.resample_data(measurements)
|
measurement_data = self.resample_data(measurement_data)
|
||||||
|
|
||||||
# Check if the measurement data is valid - the +1 comes from the summing of the phase cycles
|
# Check if the measurement data is valid - the +1 comes from the summing of the phase cycles
|
||||||
if n_phase_cycles > 1 and measurement_data.tdy.shape[1] != n_phase_cycles + 1:
|
if n_phase_cycles > 1 and measurement_data.tdy.shape[1] != n_phase_cycles + 1:
|
||||||
|
logger.debug(f"Expected {n_phase_cycles + 1} phase cycles, got {measurement_data.tdy.shape[1]}")
|
||||||
|
self.emit_status_message("Error processing measurement data")
|
||||||
|
return None
|
||||||
|
|
||||||
|
if measurement_data is None:
|
||||||
self.emit_status_message("Error processing measurement data")
|
self.emit_status_message("Error processing measurement data")
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
@ -734,36 +739,50 @@ class LimeNQRController(SpectrometerController):
|
||||||
"""
|
"""
|
||||||
return self.limenqr.model.OFFSET_FIRST_PULSE * (1 / lime.srate)
|
return self.limenqr.model.OFFSET_FIRST_PULSE * (1 / lime.srate)
|
||||||
|
|
||||||
def resample_data(self, measurements: list):
|
def resample_data(self, measurement_data: Measurement) -> Measurement:
|
||||||
"""Resamples the data with the specified dwell time."""
|
"""Resamples the data with the specified dwell time.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
measurement_data (Measurement): The measurement data to resample
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
Measurement: The resampled measurement data
|
||||||
|
"""
|
||||||
# Resample the RX data to the dwell time settings
|
# Resample the RX data to the dwell time settings
|
||||||
dwell_time = self.limenqr.model.settings.rx_dwell_time
|
dwell_time = self.limenqr.model.settings.rx_dwell_time
|
||||||
|
|
||||||
dwell_time = UnitConverter.to_float(dwell_time) * 1e6
|
dwell_time = UnitConverter.to_float(dwell_time) *1e6
|
||||||
logger.debug("Dwell time: %s", dwell_time)
|
logger.debug("Dwell time: %s", dwell_time)
|
||||||
|
|
||||||
resampled_measurements = []
|
original_dwell_time = measurement_data.tdx[1] - measurement_data.tdx[0]
|
||||||
|
logger.debug("Original dwell time: %s", original_dwell_time)
|
||||||
|
|
||||||
for measurement_data in measurements:
|
n_data_points = int(measurement_data.tdx[-1] / dwell_time)
|
||||||
logger.debug(f"Last tdx value: {measurement_data.tdx[-1][-1]}")
|
tdx = np.linspace(0, measurement_data.tdx[-1], n_data_points, endpoint=False)
|
||||||
|
|
||||||
if dwell_time:
|
first_cycle = True
|
||||||
n_data_points = int(measurement_data.tdx[-1][-1] / dwell_time)
|
|
||||||
logger.debug("Resampling to %s data points", n_data_points)
|
# We iterate over the second dimension of tdy
|
||||||
tdx = np.linspace(
|
for tdy_cycle in measurement_data.tdy.T:
|
||||||
0, measurement_data.tdx[-1][-1], n_data_points, endpoint=False
|
logger.debug("Resampling to %s data points", n_data_points)
|
||||||
)
|
tdy = resample(tdy_cycle, n_data_points)
|
||||||
tdy = resample(measurement_data.tdy[-1], n_data_points)
|
#Add empty dimension to make it compatible with the original data
|
||||||
name = measurement_data.name
|
tdy = np.expand_dims(tdy, axis=1)
|
||||||
resampled_measurements.append(
|
logger.debug("Resampled data shape: %s", tdy.shape)
|
||||||
Measurement(
|
logger.debug("Original data shape: %s", measurement_data.tdy.shape)
|
||||||
name,
|
if first_cycle:
|
||||||
tdx,
|
measurement_data_resampled = Measurement(
|
||||||
tdy,
|
measurement_data.name,
|
||||||
measurement_data.target_frequency,
|
tdx,
|
||||||
frequency_shift=measurement_data.frequency_shift,
|
tdy,
|
||||||
IF_frequency=measurement_data.IF_frequency,
|
measurement_data.target_frequency,
|
||||||
)
|
frequency_shift=measurement_data.frequency_shift,
|
||||||
|
IF_frequency=measurement_data.IF_frequency,
|
||||||
)
|
)
|
||||||
|
first_cycle = False
|
||||||
|
else:
|
||||||
|
measurement_data_resampled.add_dataset(tdy)
|
||||||
|
|
||||||
return resampled_measurements
|
logger.debug("Resampled data shape: %s", measurement_data_resampled.tdy.shape)
|
||||||
|
return measurement_data_resampled
|
||||||
|
|
||||||
|
|
|
@ -98,7 +98,7 @@ class LimeNQRModel(SpectrometerModel):
|
||||||
rx_dwell_time_setting = StringSetting(
|
rx_dwell_time_setting = StringSetting(
|
||||||
self.RX_DWELL_TIME,
|
self.RX_DWELL_TIME,
|
||||||
self.ACQUISITION,
|
self.ACQUISITION,
|
||||||
"22n",
|
"32n",
|
||||||
"The time between samples in the receive path.",
|
"The time between samples in the receive path.",
|
||||||
)
|
)
|
||||||
self.add_setting("rx_dwell_time", rx_dwell_time_setting)
|
self.add_setting("rx_dwell_time", rx_dwell_time_setting)
|
||||||
|
|
Loading…
Reference in a new issue