mirror of
https://github.com/moses-smt/mosesdecoder.git
synced 2024-09-19 15:17:10 +03:00
88e90957a1
This is one of those little chores in managing a long-lived C++ project: standard C headers like stdio.h and math.h now have their own place in the C++ standard as resp. cstdio, cmath, and so on. In this branch the #include names are updated for the util/ subdirectory; more branches to follow. C++11 adds cstdint, but to support compilation with the previous standard, that change is left for later.
41 lines
1.2 KiB
C++
41 lines
1.2 KiB
C++
#include "util/bit_packing.hh"
|
|
#include "util/exception.hh"
|
|
|
|
#include <cstring>
|
|
|
|
namespace util {
|
|
|
|
namespace {
|
|
template <bool> struct StaticCheck {};
|
|
template <> struct StaticCheck<true> { typedef bool StaticAssertionPassed; };
|
|
|
|
// If your float isn't 4 bytes, we're hosed.
|
|
typedef StaticCheck<sizeof(float) == 4>::StaticAssertionPassed FloatSize;
|
|
|
|
} // namespace
|
|
|
|
uint8_t RequiredBits(uint64_t max_value) {
|
|
if (!max_value) return 0;
|
|
uint8_t ret = 1;
|
|
while (max_value >>= 1) ++ret;
|
|
return ret;
|
|
}
|
|
|
|
void BitPackingSanity() {
|
|
const FloatEnc neg1 = { -1.0 }, pos1 = { 1.0 };
|
|
if ((neg1.i ^ pos1.i) != 0x80000000) UTIL_THROW(Exception, "Sign bit is not 0x80000000");
|
|
char mem[57+8];
|
|
memset(mem, 0, sizeof(mem));
|
|
const uint64_t test57 = 0x123456789abcdefULL;
|
|
for (uint64_t b = 0; b < 57 * 8; b += 57) {
|
|
WriteInt57(mem, b, 57, test57);
|
|
}
|
|
for (uint64_t b = 0; b < 57 * 8; b += 57) {
|
|
if (test57 != ReadInt57(mem, b, 57, (1ULL << 57) - 1))
|
|
UTIL_THROW(Exception, "The bit packing routines are failing for your architecture. Please send a bug report with your architecture, operating system, and compiler.");
|
|
}
|
|
// TODO: more checks.
|
|
}
|
|
|
|
} // namespace util
|