aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/convert/convert_common.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/convert/convert_common.hpp')
-rw-r--r--host/lib/convert/convert_common.hpp33
1 files changed, 21 insertions, 12 deletions
diff --git a/host/lib/convert/convert_common.hpp b/host/lib/convert/convert_common.hpp
index 6ee9a651a..112fe3afc 100644
--- a/host/lib/convert/convert_common.hpp
+++ b/host/lib/convert/convert_common.hpp
@@ -11,6 +11,7 @@
#include <uhd/convert.hpp>
#include <uhd/utils/static.hpp>
#include <stdint.h>
+#include <limits>
#include <complex>
#define _DECLARE_CONVERTER(name, in_form, num_in, out_form, num_out, prio) \
@@ -96,6 +97,14 @@ typedef uint32_t item32_t;
typedef item32_t (*xtox_t)(item32_t);
+template <class T, class U>
+const T clamp(const U v)
+{
+ constexpr T min_t = std::numeric_limits<T>::min();
+ constexpr T max_t = std::numeric_limits<T>::max();
+ return (v < min_t) ? min_t : (v > max_t) ? max_t : T(v);
+}
+
/***********************************************************************
* Convert xx to items32 sc16 buffer
**********************************************************************/
@@ -103,8 +112,8 @@ template <typename T>
UHD_INLINE item32_t xx_to_item32_sc16_x1(
const std::complex<T>& num, const double scale_factor)
{
- uint16_t real = int16_t(num.real() * float(scale_factor));
- uint16_t imag = int16_t(num.imag() * float(scale_factor));
+ uint16_t real = clamp<int16_t>(num.real() * float(scale_factor));
+ uint16_t imag = clamp<int16_t>(num.imag() * float(scale_factor));
return (item32_t(real) << 16) | (item32_t(imag) << 0);
}
@@ -132,8 +141,8 @@ template <typename T>
UHD_FORCE_INLINE sc16_t xx_to_sc16_x1(
const std::complex<T>& num, const double scale_factor)
{
- uint16_t real = int16_t(num.real() * T(scale_factor));
- uint16_t imag = int16_t(num.imag() * T(scale_factor));
+ uint16_t real = clamp<int16_t>(num.real() * float(scale_factor));
+ uint16_t imag = clamp<int16_t>(num.imag() * float(scale_factor));
return sc16_t(real, imag);
}
@@ -203,10 +212,10 @@ template <typename T>
UHD_INLINE item32_t xx_to_item32_sc8_x1(
const std::complex<T>& in0, const std::complex<T>& in1, const double scale_factor)
{
- uint8_t real1 = int8_t(in0.real() * float(scale_factor));
- uint8_t imag1 = int8_t(in0.imag() * float(scale_factor));
- uint8_t real0 = int8_t(in1.real() * float(scale_factor));
- uint8_t imag0 = int8_t(in1.imag() * float(scale_factor));
+ uint8_t real1 = clamp<int8_t>(in0.real() * float(scale_factor));
+ uint8_t imag1 = clamp<int8_t>(in0.imag() * float(scale_factor));
+ uint8_t real0 = clamp<int8_t>(in1.real() * float(scale_factor));
+ uint8_t imag0 = clamp<int8_t>(in1.imag() * float(scale_factor));
return (item32_t(real0) << 8) | (item32_t(imag0) << 0) | (item32_t(real1) << 24)
| (item32_t(imag1) << 16);
}
@@ -215,10 +224,10 @@ template <>
UHD_INLINE item32_t xx_to_item32_sc8_x1(
const sc16_t& in0, const sc16_t& in1, const double)
{
- uint8_t real1 = int8_t(in0.real());
- uint8_t imag1 = int8_t(in0.imag());
- uint8_t real0 = int8_t(in1.real());
- uint8_t imag0 = int8_t(in1.imag());
+ uint8_t real1 = clamp<int8_t>(in0.real());
+ uint8_t imag1 = clamp<int8_t>(in0.imag());
+ uint8_t real0 = clamp<int8_t>(in1.real());
+ uint8_t imag0 = clamp<int8_t>(in1.imag());
return (item32_t(real0) << 8) | (item32_t(imag0) << 0) | (item32_t(real1) << 24)
| (item32_t(imag1) << 16);
}