aboutsummaryrefslogtreecommitdiffstats
path: root/host/tests
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2020-03-03 16:10:06 -0800
committerAaron Rossetto <aaron.rossetto@ni.com>2020-04-02 11:55:17 -0500
commit3fe5ccf700a0c6f27dca9511386460194dcc593c (patch)
tree19d394faac0581601d3d6e5d35a7a82e325bf245 /host/tests
parent1e016e49e82c430197a90a018fbc7613cc654088 (diff)
downloaduhd-3fe5ccf700a0c6f27dca9511386460194dcc593c.tar.gz
uhd-3fe5ccf700a0c6f27dca9511386460194dcc593c.tar.bz2
uhd-3fe5ccf700a0c6f27dca9511386460194dcc593c.zip
uhd: cal: Add iq_cal calibration data container class
This class can be used to store calibration coefficients for the X300 DC offset and IQ imbalance calibration. Note: This also modifies Doxyfile.in to not document files generated by flatc.
Diffstat (limited to 'host/tests')
-rw-r--r--host/tests/CMakeLists.txt1
-rw-r--r--host/tests/cal_data_iq_test.cpp81
2 files changed, 82 insertions, 0 deletions
diff --git a/host/tests/CMakeLists.txt b/host/tests/CMakeLists.txt
index f987aa194..2742c0385 100644
--- a/host/tests/CMakeLists.txt
+++ b/host/tests/CMakeLists.txt
@@ -26,6 +26,7 @@ set(test_sources
byteswap_test.cpp
cast_test.cpp
cal_database_test.cpp
+ cal_data_iq_test.cpp
chdr_test.cpp
constrained_device_args_test.cpp
convert_test.cpp
diff --git a/host/tests/cal_data_iq_test.cpp b/host/tests/cal_data_iq_test.cpp
new file mode 100644
index 000000000..97b35a331
--- /dev/null
+++ b/host/tests/cal_data_iq_test.cpp
@@ -0,0 +1,81 @@
+//
+// Copyright 2020 Ettus Research, a National Instruments Brand
+//
+// SPDX-License-Identifier: GPL-3.0-or-later
+//
+
+#include <uhd/cal/iq_cal.hpp>
+#include <uhd/exception.hpp>
+#include <boost/test/unit_test.hpp>
+#include <iostream>
+
+using namespace uhd::usrp::cal;
+
+BOOST_AUTO_TEST_CASE(test_iq_cal_api)
+{
+ const std::string name = "Mock IQ Data";
+ const std::string serial = "ABC1234";
+ const uint64_t timestamp = 0x12340000;
+
+ auto iq_cal_data = iq_cal::make(name, serial, timestamp);
+ BOOST_CHECK_EQUAL(iq_cal_data->get_name(), name);
+ BOOST_CHECK_EQUAL(iq_cal_data->get_serial(), serial);
+ BOOST_CHECK_EQUAL(iq_cal_data->get_timestamp(), timestamp);
+ // Nothing there yet
+ BOOST_REQUIRE_THROW(iq_cal_data->get_cal_coeff(0.0), uhd::assertion_error);
+
+ iq_cal_data->set_cal_coeff(1.0, {1.0, 1.0});
+ iq_cal_data->set_cal_coeff(2.0, {2.0, 2.0});
+
+ // We're in linear interpolation mode
+ auto lo_coeff = iq_cal_data->get_cal_coeff(0.5);
+ auto hi_coeff = iq_cal_data->get_cal_coeff(2.5);
+ BOOST_CHECK_EQUAL(lo_coeff, std::complex<double>(1.0, 1.0));
+ BOOST_CHECK_EQUAL(hi_coeff, std::complex<double>(2.0, 2.0));
+ auto mid_coeff = iq_cal_data->get_cal_coeff(1.75);
+ BOOST_CHECK_EQUAL(mid_coeff, std::complex<double>(1.75, 1.75));
+
+ iq_cal_data->set_interp_mode(interp_mode::NEAREST_NEIGHBOR);
+ lo_coeff = iq_cal_data->get_cal_coeff(0.5);
+ hi_coeff = iq_cal_data->get_cal_coeff(2.5);
+ BOOST_CHECK_EQUAL(lo_coeff, std::complex<double>(1.0, 1.0));
+ BOOST_CHECK_EQUAL(hi_coeff, std::complex<double>(2.0, 2.0));
+ mid_coeff = iq_cal_data->get_cal_coeff(1.75);
+ BOOST_CHECK_EQUAL(mid_coeff, std::complex<double>(2.0, 2.0));
+
+ iq_cal_data->clear();
+ BOOST_REQUIRE_THROW(iq_cal_data->get_cal_coeff(0.0), uhd::assertion_error);
+}
+
+BOOST_AUTO_TEST_CASE(test_iq_cal_serdes)
+{
+ const std::string name = "Mock IQ Data";
+ const std::string serial = "ABC1234";
+ const uint64_t timestamp = 0x12340000;
+
+ auto iq_cal_data_blueprint = iq_cal::make(name, serial, timestamp);
+ for (double d = 0; d < 5.0; d += 1.0) {
+ iq_cal_data_blueprint->set_cal_coeff(d, {d, d}, d * 10, d * 20);
+ }
+
+ const auto serialized = iq_cal_data_blueprint->serialize();
+
+ auto iq_cal_data = container::make<iq_cal>(serialized);
+
+ BOOST_CHECK_EQUAL(iq_cal_data->get_name(), name);
+ BOOST_CHECK_EQUAL(iq_cal_data->get_serial(), serial);
+ BOOST_CHECK_EQUAL(iq_cal_data->get_timestamp(), timestamp);
+
+ iq_cal_data->set_interp_mode(interp_mode::NEAREST_NEIGHBOR);
+ for (double d = 0; d < 5.0; d += 1.0) {
+ BOOST_CHECK_EQUAL(iq_cal_data->get_cal_coeff(d), std::complex<double>(d, d));
+ }
+}
+
+BOOST_AUTO_TEST_CASE(test_iq_cal_des_fail)
+{
+ std::vector<uint8_t> not_actual_data(42, 23);
+
+ // FIXME: Re-enable this test when the verification works
+ // BOOST_REQUIRE_THROW(container::make<iq_cal>(not_actual_data), uhd::runtime_error);
+}