//
// Copyright 2014 Ettus Research LLC
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
//
#include
#include
using namespace uhd::math::fp_compare;
BOOST_AUTO_TEST_CASE(fp_compare_delta_constructors) {
// Test default constructor
fp_compare_delta alpha = fp_compare_delta(7457392.0);
fp_compare_delta beta = fp_compare_delta(alpha._value);
BOOST_CHECK_EQUAL(alpha._value, beta._value);
BOOST_CHECK_EQUAL(alpha._delta, beta._delta);
// Test constructor with specified delta
fp_compare_delta foxtrot = fp_compare_delta(alpha._value,
uhd::math::SINGLE_PRECISION_DELTA);
fp_compare_delta gamma = fp_compare_delta(alpha._value,
2 * uhd::math::SINGLE_PRECISION_DELTA);
BOOST_CHECK_EQUAL(alpha._delta, foxtrot._delta);
BOOST_CHECK(not (alpha._delta == gamma._delta));
// Test copy-constructor
fp_compare_delta charlie = fp_compare_delta(alpha);
BOOST_CHECK_EQUAL(alpha._value, charlie._value);
BOOST_CHECK_EQUAL(alpha._delta, charlie._delta);
// Test assignment operator
fp_compare_delta delta = beta;
BOOST_CHECK_EQUAL(alpha._value, delta._value);
BOOST_CHECK_EQUAL(alpha._delta, delta._delta);
}
BOOST_AUTO_TEST_CASE(double_compare_constructors) {
// Test default constructor
fp_compare_delta alpha = fp_compare_delta(45739210286.0101);
fp_compare_delta beta = fp_compare_delta(alpha._value);
BOOST_CHECK_EQUAL(alpha._value, beta._value);
BOOST_CHECK_EQUAL(alpha._delta, beta._delta);
// Test constructor with specified delta
fp_compare_delta foxtrot = fp_compare_delta(alpha._value,
uhd::math::DOUBLE_PRECISION_DELTA);
fp_compare_delta gamma = fp_compare_delta(alpha._value, 2.0e-6);
BOOST_CHECK_EQUAL(alpha._delta, foxtrot._delta);
BOOST_CHECK(not (alpha._delta == gamma._delta));
// Test copy-constructor
fp_compare_delta charlie = fp_compare_delta(alpha);
BOOST_CHECK_EQUAL(alpha._value, charlie._value);
BOOST_CHECK_EQUAL(alpha._delta, charlie._delta);
// Test assignment operator
fp_compare_delta delta = beta;
BOOST_CHECK_EQUAL(alpha._value, delta._value);
BOOST_CHECK_EQUAL(alpha._delta, delta._delta);
}
BOOST_AUTO_TEST_CASE(float_equality_operators) {
// Test basic equality operator
fp_compare_delta alpha = fp_compare_delta(1.0);
fp_compare_delta beta = fp_compare_delta(alpha._value);
BOOST_CHECK(alpha == beta);
BOOST_CHECK(alpha == float(alpha._value));
// Test equality edge case at difference = delta
fp_compare_delta charlie = fp_compare_delta(alpha._value
+ uhd::math::SINGLE_PRECISION_DELTA);
BOOST_CHECK(not (alpha == charlie));
BOOST_CHECK(not (alpha == float(alpha._value + uhd::math::SINGLE_PRECISION_DELTA)));
}
BOOST_AUTO_TEST_CASE(double_equality_operators) {
// Test basic equality operator
fp_compare_delta alpha = fp_compare_delta(1.0);
fp_compare_delta beta = fp_compare_delta(alpha._value);
BOOST_CHECK(alpha == beta);
BOOST_CHECK(alpha == double(beta._value));
// Test equality edge case at delta = delta
fp_compare_delta charlie = fp_compare_delta(alpha._value
+ uhd::math::DOUBLE_PRECISION_DELTA);
BOOST_CHECK(not (alpha == charlie));
BOOST_CHECK(not (alpha == double(alpha._value + uhd::math::DOUBLE_PRECISION_DELTA)));
}
BOOST_AUTO_TEST_CASE(float_inequality_operators) {
// Test inequality operator, which is based on equality operator
fp_compare_delta alpha = fp_compare_delta(127.0f);
fp_compare_delta beta = fp_compare_delta(alpha._value + 1.19e-3f);
BOOST_CHECK(alpha != beta);
BOOST_CHECK(alpha != float(alpha._value + 1.19e-3));
}
BOOST_AUTO_TEST_CASE(double_inequality_operators) {
// Test inequality operator, which is based on equality operator
fp_compare_delta alpha = fp_compare_delta(1.0);
fp_compare_delta beta = fp_compare_delta(alpha._value + 1.19e-5);
BOOST_CHECK(alpha != beta);
BOOST_CHECK(alpha != double(alpha._value + 1.19e-5));
}
BOOST_AUTO_TEST_CASE(float_lessthan_operators) {
// Test less-than operator
fp_compare_delta alpha = fp_compare_delta(274192.7f);
fp_compare_delta beta = fp_compare_delta(alpha._value - 0.2f);
BOOST_CHECK(beta < alpha);
BOOST_CHECK(float(alpha._value - 0.2) < alpha);
// Confirm false less-than case
fp_compare_delta charlie = fp_compare_delta(alpha._value - 1.2f);
BOOST_CHECK(not (alpha < charlie));
BOOST_CHECK(not (alpha < float(alpha._value - 1.2f)));
}
BOOST_AUTO_TEST_CASE(double_lessthan_operators) {
// Test less-than operator
fp_compare_delta alpha = fp_compare_delta(274192856.762312);
fp_compare_delta beta = fp_compare_delta(alpha._value - 0.0002);
BOOST_CHECK(beta < alpha);
BOOST_CHECK(double(alpha._value - 0.0002) < alpha);
// Confirm false less-than case
fp_compare_delta charlie = fp_compare_delta(alpha._value - 1.0012);
BOOST_CHECK(not (alpha < charlie));
BOOST_CHECK(not (alpha < double(alpha._value - 1.0012)));
}
BOOST_AUTO_TEST_CASE(float_lessthanequals_operators) {
// Test that <= correctly reports for equal values
fp_compare_delta alpha = fp_compare_delta(827.3f);
fp_compare_delta beta = fp_compare_delta(alpha._value);
BOOST_CHECK(alpha <= beta);
BOOST_CHECK(alpha <= float(alpha._value));
// Test that <= correctly reports for less-than values
fp_compare_delta charlie = fp_compare_delta(alpha._value - 1.2f);
BOOST_CHECK(charlie <= alpha);
BOOST_CHECK(float(alpha._value - 1.2) <= alpha);
}
BOOST_AUTO_TEST_CASE(double_lessthanequals_operators) {
// Test that <= correctly reports for equal values
fp_compare_delta alpha = fp_compare_delta(837652123.383764);
fp_compare_delta beta = fp_compare_delta(alpha._value);
BOOST_CHECK(alpha <= beta);
BOOST_CHECK(alpha <= double(alpha._value));
// Test that <= correctly reports for less-than values
fp_compare_delta charlie = fp_compare_delta(alpha._value - 0.0012);
BOOST_CHECK(charlie <= alpha);
BOOST_CHECK(double(alpha._value - 0.0012) <= alpha);
}
BOOST_AUTO_TEST_CASE(float_greaterthan_operators) {
// Test basic greater-than functionality
fp_compare_delta alpha = fp_compare_delta(98325.4f);
fp_compare_delta beta = fp_compare_delta(alpha._value + 0.15f);
BOOST_CHECK(beta > alpha);
BOOST_CHECK(float(alpha._value + 0.15) > alpha);
// Test false greater-than case
fp_compare_delta charlie = fp_compare_delta(alpha._value + 1.2f);
BOOST_CHECK(not (alpha > charlie));
BOOST_CHECK(not (alpha > float(alpha._value + 1.2)));
}
BOOST_AUTO_TEST_CASE(double_greaterthan_operators) {
// Test basic greater-than functionality
fp_compare_delta alpha = fp_compare_delta(643907213.428475);
fp_compare_delta beta = fp_compare_delta(alpha._value + 0.0002);
BOOST_CHECK(beta > alpha);
BOOST_CHECK(double(alpha._value + 0.0002) > alpha);
// Test false greater-than case
fp_compare_delta charlie = fp_compare_delta(alpha._value + 0.0012);
BOOST_CHECK(not (alpha > charlie));
BOOST_CHECK(not (alpha > double(alpha._value + 0.0012)));
}
BOOST_AUTO_TEST_CASE(float_greaterthanequals_operators) {
// Test that >= correctly reports for equal values
fp_compare_delta alpha = fp_compare_delta(7834.89f);
fp_compare_delta beta = fp_compare_delta(alpha._value);
BOOST_CHECK(alpha >= beta);
BOOST_CHECK(alpha >= float(alpha._value));
// Test that >= correctly reports for greater-than values
fp_compare_delta charlie = fp_compare_delta(alpha._value + 4.8f);
BOOST_CHECK(charlie >= alpha);
BOOST_CHECK(float(alpha._value + 4.8) >= alpha);
}
BOOST_AUTO_TEST_CASE(double_greaterthanequals_operators) {
// Test that >= correctly reports for equal values
fp_compare_delta alpha = fp_compare_delta(737623834.89843);
fp_compare_delta beta = fp_compare_delta(alpha._value);
BOOST_CHECK(alpha >= beta);
BOOST_CHECK(alpha >= double(alpha._value));
// Test that >= correctly reports for greater-than values
fp_compare_delta charlie = fp_compare_delta(alpha._value + 3.0008);
BOOST_CHECK(charlie >= alpha);
BOOST_CHECK(double(alpha._value + 3.0008) >= alpha);
}
BOOST_AUTO_TEST_CASE(fp_compare_large_delta) {
BOOST_CHECK(fp_compare_delta(61440000.047870710492, 0.1) == 61440000.000000000000);
BOOST_CHECK(fp_compare_delta(61440000.047870710492, 0.1) <= 61440000.000000000000);
BOOST_CHECK(fp_compare_delta(61440000.047870710492, 0.1) >= 61440000.000000000000);
BOOST_CHECK(fp_compare_delta(1.0, 10.0) == 2.0);
}
BOOST_AUTO_TEST_CASE(frequency_compare_function) {
BOOST_CHECK(uhd::math::frequencies_are_equal(6817333232.0, 6817333232.0));
BOOST_CHECK(!uhd::math::frequencies_are_equal(6817333233.0, 6817333232.0));
BOOST_CHECK(uhd::math::frequencies_are_equal(6817333232.1, 6817333232.1));
BOOST_CHECK(!uhd::math::frequencies_are_equal(6817333232.5, 6817333232.6));
BOOST_CHECK(uhd::math::frequencies_are_equal(16.8173332321e9, 16.8173332321e9));
BOOST_CHECK(!uhd::math::frequencies_are_equal(16.8173332322e9, 16.8173332321e9));
BOOST_CHECK(!uhd::math::frequencies_are_equal(5.0, 4.0));
BOOST_CHECK(uhd::math::frequencies_are_equal(48750000.0, 48749999.9946));
}