2018-01-12 21:47:58 +01:00
|
|
|
///////////////////////////////////////////////////////////////
|
|
|
|
// Copyright 2012 John Maddock. Distributed under the Boost
|
|
|
|
// Software License, Version 1.0. (See accompanying file
|
2021-10-05 21:37:46 +02:00
|
|
|
// LICENSE_1_0.txt or copy at https://www.boost.org/LICENSE_1_0.txt
|
2018-01-12 21:47:58 +01:00
|
|
|
|
|
|
|
//
|
|
|
|
// Compare arithmetic results using fixed_int to GMP results.
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifdef _MSC_VER
|
2021-10-05 21:37:46 +02:00
|
|
|
#define _SCL_SECURE_NO_WARNINGS
|
2018-01-12 21:47:58 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <boost/multiprecision/integer.hpp>
|
|
|
|
#include "test.hpp"
|
|
|
|
|
|
|
|
#ifdef BOOST_MSVC
|
2021-10-05 21:37:46 +02:00
|
|
|
#pragma warning(disable : 4146)
|
2018-01-12 21:47:58 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
template <class I, class H>
|
|
|
|
void test()
|
|
|
|
{
|
|
|
|
using namespace boost::multiprecision;
|
|
|
|
|
|
|
|
I i(0);
|
|
|
|
|
|
|
|
#ifndef BOOST_NO_EXCEPTIONS
|
2021-10-05 21:37:46 +02:00
|
|
|
BOOST_CHECK_THROW(lsb(i), std::domain_error);
|
2018-01-12 21:47:58 +01:00
|
|
|
#endif
|
|
|
|
BOOST_CHECK(bit_test(bit_set(i, 0), 0));
|
|
|
|
BOOST_CHECK_EQUAL(bit_set(i, 0), 1);
|
|
|
|
BOOST_CHECK_EQUAL(bit_unset(i, 0), 0);
|
|
|
|
BOOST_CHECK_EQUAL(bit_flip(bit_set(i, 0), 0), 0);
|
|
|
|
|
|
|
|
unsigned max_index = (std::numeric_limits<I>::digits) - 1;
|
|
|
|
BOOST_CHECK(bit_test(bit_set(i, max_index), max_index));
|
|
|
|
BOOST_CHECK_EQUAL(bit_unset(i, max_index), 0);
|
|
|
|
BOOST_CHECK_EQUAL(bit_flip(bit_set(i, max_index), max_index), 0);
|
|
|
|
i = 0;
|
|
|
|
bit_set(i, max_index);
|
|
|
|
BOOST_CHECK_EQUAL(lsb(i), max_index);
|
|
|
|
BOOST_CHECK_EQUAL(msb(i), max_index);
|
|
|
|
bit_set(i, max_index / 2);
|
|
|
|
BOOST_CHECK_EQUAL(lsb(i), max_index / 2);
|
|
|
|
BOOST_CHECK_EQUAL(msb(i), max_index);
|
|
|
|
|
|
|
|
#ifndef BOOST_NO_EXCEPTIONS
|
2021-10-05 21:37:46 +02:00
|
|
|
if (std::numeric_limits<I>::is_signed)
|
2018-01-12 21:47:58 +01:00
|
|
|
{
|
|
|
|
i = static_cast<I>(-1);
|
2021-10-05 21:37:46 +02:00
|
|
|
BOOST_CHECK_THROW(lsb(i), std::domain_error);
|
2018-01-12 21:47:58 +01:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
H mx = (std::numeric_limits<H>::max)();
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL(multiply(i, mx, mx), static_cast<I>(mx) * static_cast<I>(mx));
|
|
|
|
BOOST_CHECK_EQUAL(add(i, mx, mx), static_cast<I>(mx) + static_cast<I>(mx));
|
2021-10-05 21:37:46 +02:00
|
|
|
if (std::numeric_limits<I>::is_signed)
|
2018-01-12 21:47:58 +01:00
|
|
|
{
|
|
|
|
BOOST_CHECK_EQUAL(subtract(i, mx, static_cast<H>(-mx)), static_cast<I>(mx) - static_cast<I>(-mx));
|
|
|
|
BOOST_CHECK_EQUAL(add(i, static_cast<H>(-mx), static_cast<H>(-mx)), static_cast<I>(-mx) + static_cast<I>(-mx));
|
|
|
|
}
|
|
|
|
|
2021-10-05 21:37:46 +02:00
|
|
|
i = (std::numeric_limits<I>::max)();
|
2018-01-12 21:47:58 +01:00
|
|
|
I j = 12345;
|
|
|
|
I r, q;
|
|
|
|
divide_qr(i, j, q, r);
|
|
|
|
BOOST_CHECK_EQUAL(q, i / j);
|
|
|
|
BOOST_CHECK_EQUAL(r, i % j);
|
|
|
|
BOOST_CHECK_EQUAL(integer_modulus(i, j), i % j);
|
|
|
|
I p = 456;
|
|
|
|
BOOST_CHECK_EQUAL(powm(i, p, j), pow(cpp_int(i), static_cast<unsigned>(p)) % j);
|
|
|
|
|
2021-10-05 21:37:46 +02:00
|
|
|
for (I i = 0; i < (2 < 8) - 1; ++i)
|
2018-01-12 21:47:58 +01:00
|
|
|
{
|
|
|
|
I j = i * i;
|
|
|
|
I s, r;
|
|
|
|
s = sqrt(j, r);
|
|
|
|
BOOST_CHECK_EQUAL(s, i);
|
|
|
|
BOOST_CHECK(r == 0);
|
|
|
|
j += 3;
|
|
|
|
s = sqrt(i, r);
|
|
|
|
BOOST_CHECK_EQUAL(s, i);
|
|
|
|
BOOST_CHECK(r == 3);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
using namespace boost::multiprecision;
|
|
|
|
|
2021-10-05 21:37:46 +02:00
|
|
|
test<std::int16_t, boost::int8_t>();
|
|
|
|
test<std::int32_t, std::int16_t>();
|
|
|
|
test<std::int64_t, std::int32_t>();
|
|
|
|
test<std::uint16_t, boost::uint8_t>();
|
|
|
|
test<std::uint32_t, std::uint16_t>();
|
|
|
|
test<std::uint64_t, std::uint32_t>();
|
|
|
|
|
2018-01-12 21:47:58 +01:00
|
|
|
return boost::report_errors();
|
|
|
|
}
|