aboutsummaryrefslogtreecommitdiffstats
path: root/host/include
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2021-08-31 11:49:51 +0200
committerAaron Rossetto <aaron.rossetto@ni.com>2021-10-19 12:21:33 -0700
commit5ee6b828debbd60e03aff805bfd80e2030715a6f (patch)
treeef3a02b0c2dd055988c376f4bbf1c8e71ea6a330 /host/include
parent91c10b66c23178e27bbff0e9173570c63e342736 (diff)
downloaduhd-5ee6b828debbd60e03aff805bfd80e2030715a6f.tar.gz
uhd-5ee6b828debbd60e03aff805bfd80e2030715a6f.tar.bz2
uhd-5ee6b828debbd60e03aff805bfd80e2030715a6f.zip
uhd: math: Replace wrap-frequency math with a single function
In multiple places in the UHD code, we were doing the same calculation for a wrapped frequency (wrap it into the first Nyquist zone). This math was using boost::math, too. Instead of editing every instance, we create a new function, uhd::math::wrap_frequency(), and replace all of its separate implementations with this function. The new function also no longer relies on boost::math::sign.
Diffstat (limited to 'host/include')
-rw-r--r--host/include/uhd/utils/math.hpp18
1 files changed, 18 insertions, 0 deletions
diff --git a/host/include/uhd/utils/math.hpp b/host/include/uhd/utils/math.hpp
index 4918ddf2e..6c8fceae9 100644
--- a/host/include/uhd/utils/math.hpp
+++ b/host/include/uhd/utils/math.hpp
@@ -278,6 +278,24 @@ inline constexpr int sign(T x)
return (T(0) < x) - (x < T(0));
}
+//! Return a wrapped frequency that is the equivalent frequency in the first
+// Nyquist zone.
+//
+// Examples:
+// - Just above the sampling rate:
+// wrap_frequency(250e6, 200e6) == 50e6
+// - Just outside the Nyquist zone:
+// wrap_frequency(120e6, 200e6) == -80e6
+// - Also works for negative frequencies:
+// wrap_frequency(-250e6, 200e6) == -50e6
+inline double wrap_frequency(const double requested_freq, const double rate)
+{
+ double freq = std::fmod(requested_freq, rate);
+ if (std::abs(freq) > rate / 2.0)
+ freq -= uhd::math::sign(freq) * rate;
+ return freq;
+}
+
} // namespace math
} // namespace uhd