From a5127ec990e9e9dde036e047f6c25bdf0b1c3669 Mon Sep 17 00:00:00 2001 From: Justin Haze Date: Mon, 6 May 2024 09:50:09 -0600 Subject: [PATCH] calc num samples based on requested sample rate --- scos_actions/actions/acquire_single_freq_tdomain_iq.py | 3 ++- scos_actions/actions/acquire_stepped_freq_tdomain_iq.py | 3 ++- scos_actions/hardware/sensor.py | 2 +- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/scos_actions/actions/acquire_single_freq_tdomain_iq.py b/scos_actions/actions/acquire_single_freq_tdomain_iq.py index faa3ece9..9995b5ca 100644 --- a/scos_actions/actions/acquire_single_freq_tdomain_iq.py +++ b/scos_actions/actions/acquire_single_freq_tdomain_iq.py @@ -78,10 +78,11 @@ def __init__(self, parameters: dict): self.frequency_Hz = get_parameter(FREQUENCY, self.parameters) self.classification = get_parameter(CLASSIFICATION, self.parameters) self.cal_adjust = get_parameter(CAL_ADJUST, self.parameters) + self.requested_sample_rate = get_parameter(SAMPLE_RATE, self.parameters) def execute(self, schedule_entry: dict, task_id: int) -> dict: # Use the sigan's actual reported instead of requested sample rate - sample_rate = self.sensor.signal_analyzer.sample_rate + sample_rate = self.requested_sample_rate num_samples = int(sample_rate * self.duration_ms * 1e-3) measurement_result = self.acquire_data( num_samples, self.nskip, self.cal_adjust, cal_params=self.parameters diff --git a/scos_actions/actions/acquire_stepped_freq_tdomain_iq.py b/scos_actions/actions/acquire_stepped_freq_tdomain_iq.py index 6fd4c685..f29f8eac 100644 --- a/scos_actions/actions/acquire_stepped_freq_tdomain_iq.py +++ b/scos_actions/actions/acquire_stepped_freq_tdomain_iq.py @@ -45,6 +45,7 @@ DURATION_MS, FREQUENCY, NUM_SKIP, + SAMPLE_RATE, SingleFrequencyTimeDomainIqAcquisition, ) from scos_actions.hardware.sensor import Sensor @@ -98,7 +99,7 @@ def __call__(self, sensor: Sensor, schedule_entry: dict, task_id: int): duration_ms = get_parameter(DURATION_MS, measurement_params) nskip = get_parameter(NUM_SKIP, measurement_params) cal_adjust = get_parameter(CAL_ADJUST, measurement_params) - sample_rate = self.sensor.signal_analyzer.sample_rate + sample_rate = get_parameter(SAMPLE_RATE, measurement_params) num_samples = int(sample_rate * duration_ms * 1e-3) measurement_result = super().acquire_data( num_samples, nskip, cal_adjust, cal_params=measurement_params diff --git a/scos_actions/hardware/sensor.py b/scos_actions/hardware/sensor.py index 6a9e9701..c9eaa2a8 100644 --- a/scos_actions/hardware/sensor.py +++ b/scos_actions/hardware/sensor.py @@ -5,9 +5,9 @@ from typing import Any, Dict, List, Optional import numpy as np -from numpy.typing import ArrayLike from its_preselector.preselector import Preselector from its_preselector.web_relay import WebRelay +from numpy.typing import ArrayLike from scos_actions.calibration.differential_calibration import DifferentialCalibration from scos_actions.calibration.sensor_calibration import SensorCalibration