diff options
author | Lars Amsel <lars.amsel@ni.com> | 2022-03-11 16:15:41 +0100 |
---|---|---|
committer | Aaron Rossetto <aaron.rossetto@ni.com> | 2022-03-23 16:12:03 -0500 |
commit | 2e8f7484a4497c1b3f1f2caff32d9269ca492ffb (patch) | |
tree | 7e69b4d90f99792c52224648ec1047e04410a58c /host/lib/transport/buffer_pool.cpp | |
parent | c0015db3ea80117e8c66966e55f337e4fe8d29c2 (diff) | |
download | uhd-2e8f7484a4497c1b3f1f2caff32d9269ca492ffb.tar.gz uhd-2e8f7484a4497c1b3f1f2caff32d9269ca492ffb.tar.bz2 uhd-2e8f7484a4497c1b3f1f2caff32d9269ca492ffb.zip |
Fix handling of discontinuities in power calibration data
The power that corresponds to a certain gain values depends on the
frequency band we are in. At the edges of these bands discontinuities
can occur (the gain necessary to achieve the same power value changes
non-continuously). The power calibration does a linear interpolation
between two neighbor points in the calibration data set to find at
best fitting value. We therefore have to make sure that this interpolation
does not cross discontinuities.
This is a minimal invasive approach. It adds values at discontinuities
for the lower and the upper band. The power calibration format uses
the frequency for a power to gain mapping as a map key. Therefore two
gain to power mappings cannot be stored for the same frequency as it
would be needed for the discontinuity. Instead the mapping for the
lower band is stored at the discontinuity frequency itself. The mapping
for the upper band is stored at the frequency + 1Hz. The calibration
will therefore still fail to yield proper results within this
sub-Hertz range. The frequency lookup in the power calibration manager
now uses round instead of truncation to find the best mapping frequency
in the calibration table.
With this, searching for neighbor data points now ensures that the data
points used belong to the same band (except for the range of
(f_discontinuity, f_discontinuity + 1Hz) ).
This commit does not solve the issue for calibration data generated
with usrp_power_cal.py because the Python interface has no means to
detect band edges for the USRP it is calibrating.
Diffstat (limited to 'host/lib/transport/buffer_pool.cpp')
0 files changed, 0 insertions, 0 deletions