BitHacksTest.cpp 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /*
  2. * Copyright 2018 Axel Waggershauser
  3. */
  4. // SPDX-License-Identifier: Apache-2.0
  5. #include "BitHacks.h"
  6. #include "gtest/gtest.h"
  7. #include <vector>
  8. TEST(BitHackTest, BitHacks)
  9. {
  10. using namespace ZXing::BitHacks;
  11. EXPECT_EQ(NumberOfLeadingZeros(0), 32);
  12. EXPECT_EQ(NumberOfLeadingZeros(1), 31);
  13. EXPECT_EQ(NumberOfLeadingZeros(0xffffffff), 0);
  14. // EXPECT_EQ(NumberOfTrailingZeros(0), 32);
  15. EXPECT_EQ(NumberOfTrailingZeros(1), 0);
  16. EXPECT_EQ(NumberOfTrailingZeros(2), 1);
  17. EXPECT_EQ(NumberOfTrailingZeros(0xffffffff), 0);
  18. EXPECT_EQ(Reverse(0), 0);
  19. EXPECT_EQ(Reverse(1), 0x80000000);
  20. EXPECT_EQ(Reverse(0xffffffff), 0xffffffff);
  21. EXPECT_EQ(Reverse(0xff00ff00), 0x00ff00ff);
  22. EXPECT_EQ(CountBitsSet(0), 0);
  23. EXPECT_EQ(CountBitsSet(1), 1);
  24. EXPECT_EQ(CountBitsSet(2), 1);
  25. EXPECT_EQ(CountBitsSet(0xffffffff), 32);
  26. EXPECT_EQ(CountBitsSet(0x11111111), 8);
  27. EXPECT_EQ(HighestBitSet(0x1), 0);
  28. EXPECT_EQ(HighestBitSet(0xffffffff), 31);
  29. EXPECT_EQ(HighestBitSet(0x1F), 4);
  30. using V = std::vector<uint32_t>;
  31. auto checkReverse = [](V&& v1, int p, V&& v2) {
  32. Reverse(v1, p);
  33. EXPECT_EQ(v1, v2);
  34. };
  35. checkReverse(V{1}, 0, V{0x80000000});
  36. checkReverse(V{0, 1}, 0, V{0x80000000, 0});
  37. checkReverse(V{0, 1}, 31, V{1, 0});
  38. checkReverse(V{0xffffffff, 0}, 16, V{0xffff0000, 0xffff});
  39. }