Spaces:
Runtime error
Runtime error
File size: 1,717 Bytes
be11144 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
#include <unittest/unittest.h>
#include <thrust/detail/mpl/math.h>
void TestLog2(void)
{
unsigned int result;
result = thrust::detail::mpl::math::log2< 1>::value; ASSERT_EQUAL(result, 0lu);
result = thrust::detail::mpl::math::log2< 2>::value; ASSERT_EQUAL(result, 1lu);
result = thrust::detail::mpl::math::log2< 3>::value; ASSERT_EQUAL(result, 1lu);
result = thrust::detail::mpl::math::log2< 4>::value; ASSERT_EQUAL(result, 2lu);
result = thrust::detail::mpl::math::log2< 5>::value; ASSERT_EQUAL(result, 2lu);
result = thrust::detail::mpl::math::log2< 6>::value; ASSERT_EQUAL(result, 2lu);
result = thrust::detail::mpl::math::log2< 7>::value; ASSERT_EQUAL(result, 2lu);
result = thrust::detail::mpl::math::log2< 8>::value; ASSERT_EQUAL(result, 3lu);
result = thrust::detail::mpl::math::log2< 9>::value; ASSERT_EQUAL(result, 3lu);
result = thrust::detail::mpl::math::log2< 15>::value; ASSERT_EQUAL(result, 3lu);
result = thrust::detail::mpl::math::log2< 16>::value; ASSERT_EQUAL(result, 4lu);
result = thrust::detail::mpl::math::log2< 17>::value; ASSERT_EQUAL(result, 4lu);
result = thrust::detail::mpl::math::log2<127>::value; ASSERT_EQUAL(result, 6lu);
result = thrust::detail::mpl::math::log2<128>::value; ASSERT_EQUAL(result, 7lu);
result = thrust::detail::mpl::math::log2<129>::value; ASSERT_EQUAL(result, 7lu);
result = thrust::detail::mpl::math::log2<256>::value; ASSERT_EQUAL(result, 8lu);
result = thrust::detail::mpl::math::log2<511>::value; ASSERT_EQUAL(result, 8lu);
result = thrust::detail::mpl::math::log2<512>::value; ASSERT_EQUAL(result, 9lu);
}
DECLARE_UNITTEST(TestLog2);
|