Corrected default sampling frequency. Fixed resampling.

This commit is contained in:
jupfi 2024-12-30 10:40:05 +01:00
parent 4548513d06
commit e47f8f9dd3
2 changed files with 45 additions and 26 deletions

View file

@ -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

View file

@ -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)