2013-04-17 00:02:16 -04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <assert.h>
|
2013-04-17 00:02:19 -04:00
|
|
|
#include <sys/types.h>
|
2013-04-17 00:02:16 -04:00
|
|
|
#include <tokudb_math.h>
|
|
|
|
using namespace tokudb;
|
|
|
|
|
|
|
|
static void test_uint_range(uint length_bits) {
|
|
|
|
assert(uint_low_endpoint(length_bits) == 0);
|
|
|
|
if (length_bits == 64)
|
|
|
|
assert(uint_high_endpoint(length_bits) == ~0ULL);
|
|
|
|
else
|
|
|
|
assert(uint_high_endpoint(length_bits) == (1ULL<<length_bits)-1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_uint8() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_uint_range(8);
|
|
|
|
bool over;
|
|
|
|
uint8_t n;
|
|
|
|
uint64_t m;
|
|
|
|
for (uint64_t x = 0; x <= (1ULL<<8)-1; x++) {
|
|
|
|
for (uint64_t y = 0; y <= (1ULL<<8)-1; y++) {
|
2013-04-17 00:02:16 -04:00
|
|
|
n = uint_add(x, y, 8, &over);
|
2013-04-17 00:02:16 -04:00
|
|
|
m = x + y;
|
|
|
|
if (m > (1ULL<<8)-1)
|
|
|
|
assert(over);
|
|
|
|
else
|
|
|
|
assert(!over && n == (m % 256));
|
2013-04-17 00:02:16 -04:00
|
|
|
n = uint_sub(x, y, 8, &over);
|
2013-04-17 00:02:16 -04:00
|
|
|
m = x - y;
|
|
|
|
if (m > x)
|
|
|
|
assert(over);
|
|
|
|
else
|
|
|
|
assert(!over && n == (m % 256));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_uint16() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_uint_range(16);
|
|
|
|
bool over;
|
|
|
|
uint16_t n;
|
|
|
|
uint64_t m;
|
|
|
|
for (uint64_t x = 0; x <= (1ULL<<16)-1; x++) {
|
|
|
|
for (uint64_t y = 0; y <= (1ULL<<16)-1; y++) {
|
2013-04-17 00:02:16 -04:00
|
|
|
n = uint_add(x, y, 16, &over);
|
2013-04-17 00:02:16 -04:00
|
|
|
m = x + y;
|
|
|
|
if (m > (1ULL<<16)-1)
|
|
|
|
assert(over);
|
|
|
|
else
|
|
|
|
assert(!over && n == (m % (1ULL<<16)));
|
2013-04-17 00:02:16 -04:00
|
|
|
n = uint_sub(x, y, 16, &over);
|
2013-04-17 00:02:16 -04:00
|
|
|
m = x - y;
|
|
|
|
if (m > x)
|
|
|
|
assert(over);
|
|
|
|
else
|
|
|
|
assert(!over && n == (m % (1ULL<<16)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_uint24() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_uint_range(24);
|
|
|
|
bool over;
|
|
|
|
uint64_t s;
|
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = uint_add((1ULL<<24)-1, (1ULL<<24)-1, 24, &over); assert(over);
|
|
|
|
s = uint_add((1ULL<<24)-1, 1, 24, &over); assert(over);
|
|
|
|
s = uint_add((1ULL<<24)-1, 0, 24, &over); assert(!over && s == (1ULL<<24)-1);
|
|
|
|
s = uint_add(0, 1, 24, &over); assert(!over && s == 1);
|
|
|
|
s = uint_add(0, 0, 24, &over); assert(!over && s == 0);
|
|
|
|
s = uint_sub(0, 0, 24, &over); assert(!over && s == 0);
|
|
|
|
s = uint_sub(0, 1, 24, &over); assert(over);
|
|
|
|
s = uint_sub(0, (1ULL<<24)-1, 24, &over); assert(over);
|
|
|
|
s = uint_sub((1ULL<<24)-1, (1ULL<<24)-1, 24, &over); assert(!over && s == 0);
|
2013-04-17 00:02:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_uint32() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_uint_range(32);
|
|
|
|
bool over;
|
|
|
|
uint64_t s;
|
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = uint_add((1ULL<<32)-1, (1ULL<<32)-1, 32, &over); assert(over);
|
|
|
|
s = uint_add((1ULL<<32)-1, 1, 32, &over); assert(over);
|
|
|
|
s = uint_add((1ULL<<32)-1, 0, 32, &over); assert(!over && s == (1ULL<<32)-1);
|
|
|
|
s = uint_add(0, 1, 32, &over); assert(!over && s == 1);
|
|
|
|
s = uint_add(0, 0, 32, &over); assert(!over && s == 0);
|
|
|
|
s = uint_sub(0, 0, 32, &over); assert(!over && s == 0);
|
|
|
|
s = uint_sub(0, 1, 32, &over); assert(over);
|
|
|
|
s = uint_sub(0, (1ULL<<32)-1, 32, &over); assert(over);
|
|
|
|
s = uint_sub((1ULL<<32)-1, (1ULL<<32)-1, 32, &over); assert(!over && s == 0);
|
2013-04-17 00:02:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_uint64() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_uint_range(64);
|
|
|
|
bool over;
|
|
|
|
uint64_t s;
|
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = uint_add(~0ULL, ~0ULL, 64, &over); assert(over);
|
|
|
|
s = uint_add(~0ULL, 1, 64, &over); assert(over);
|
|
|
|
s = uint_add(~0ULL, 0, 64, &over); assert(!over && s == ~0ULL);
|
|
|
|
s = uint_add(0, 1, 64, &over); assert(!over && s == 1);
|
|
|
|
s = uint_add(0, 0, 64, &over); assert(!over && s == 0);
|
|
|
|
s = uint_sub(0, 0, 64, &over); assert(!over && s == 0);
|
|
|
|
s = uint_sub(0, 1, 64, &over); assert(over);
|
|
|
|
s = uint_sub(0, ~0ULL, 64, &over); assert(over);
|
|
|
|
s = uint_sub(~0ULL, ~0ULL, 64, &over); assert(!over && s == 0);
|
2013-04-17 00:02:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
static int64_t sign_extend(uint length_bits, int64_t n) {
|
|
|
|
return n | ~((1ULL<<(length_bits-1))-1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_int_range(uint length_bits) {
|
2013-04-17 00:02:18 -04:00
|
|
|
assert(int_high_endpoint(length_bits) == (int64_t)((1ULL<<(length_bits-1))-1));
|
2013-04-17 00:02:16 -04:00
|
|
|
assert(int_low_endpoint(length_bits) == sign_extend(length_bits, 1ULL<<(length_bits-1)));
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_int8() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_int_range(8);
|
|
|
|
int64_t max = (1LL << 7);
|
|
|
|
for (int64_t x = -max; x <= max-1; x++) {
|
|
|
|
for (int64_t y = -max; y <= max-1; y++) {
|
|
|
|
bool over;
|
|
|
|
int64_t n, m;
|
2013-04-17 00:02:16 -04:00
|
|
|
n = int_add(x, y, 8, &over);
|
2013-04-17 00:02:16 -04:00
|
|
|
m = x + y;
|
|
|
|
if (m > max-1)
|
|
|
|
assert(over);
|
|
|
|
else if (m < -max)
|
|
|
|
assert(over);
|
|
|
|
else
|
|
|
|
assert(!over && n == m);
|
2013-04-17 00:02:16 -04:00
|
|
|
n = int_sub(x, y, 8, &over);
|
2013-04-17 00:02:16 -04:00
|
|
|
m = x - y;
|
|
|
|
if (m > max-1)
|
|
|
|
assert(over);
|
|
|
|
else if (m < -max)
|
|
|
|
assert(over);
|
|
|
|
else
|
|
|
|
assert(!over && n == m);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_int16() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_int_range(16);
|
|
|
|
int64_t max = (1LL << 15);
|
|
|
|
for (int64_t x = -max; x <= max-1; x++) {
|
|
|
|
for (int64_t y = -max; y <= max-1; y++) {
|
|
|
|
bool over;
|
|
|
|
int64_t n, m;
|
2013-04-17 00:02:16 -04:00
|
|
|
n = int_add(x, y, 16, &over);
|
2013-04-17 00:02:16 -04:00
|
|
|
m = x + y;
|
|
|
|
if (m > max-1)
|
|
|
|
assert(over);
|
|
|
|
else if (m < -max)
|
|
|
|
assert(over);
|
|
|
|
else
|
|
|
|
assert(!over && n == m);
|
2013-04-17 00:02:16 -04:00
|
|
|
n = int_sub(x, y, 16, &over);
|
2013-04-17 00:02:16 -04:00
|
|
|
m = x - y;
|
|
|
|
if (m > max-1)
|
|
|
|
assert(over);
|
|
|
|
else if (m < -max)
|
|
|
|
assert(over);
|
|
|
|
else
|
|
|
|
assert(!over && n == m);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_int24() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_int_range(24);
|
|
|
|
int64_t s;
|
|
|
|
bool over;
|
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = int_add(1, (1ULL<<23)-1, 24, &over); assert(over);
|
|
|
|
s = int_add((1ULL<<23)-1, 1, 24, &over); assert(over);
|
|
|
|
s = int_sub(-1, (1ULL<<23), 24, &over); assert(!over && s == (1ULL<<23)-1);
|
|
|
|
s = int_sub((1ULL<<23), 1, 24, &over); assert(over);
|
2013-04-17 00:02:16 -04:00
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = int_add(0, 0, 24, &over); assert(!over && s == 0);
|
|
|
|
s = int_sub(0, 0, 24, &over); assert(!over && s == 0);
|
|
|
|
s = int_add(0, -1, 24, &over); assert(!over && s == -1);
|
|
|
|
s = int_sub(0, 1, 24, &over); assert(!over && s == -1);
|
2013-04-17 00:02:18 -04:00
|
|
|
s = int_add(0, (1ULL<<23), 24, &over); assert(!over && (s & ((1ULL<<24)-1)) == (1ULL<<23));
|
|
|
|
s = int_sub(0, (1ULL<<23)-1, 24, &over); assert(!over && (s & ((1ULL<<24)-1)) == (1ULL<<23)+1);
|
2013-04-17 00:02:16 -04:00
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = int_add(-1, 0, 24, &over); assert(!over && s == -1);
|
|
|
|
s = int_add(-1, 1, 24, &over); assert(!over && s == 0);
|
|
|
|
s = int_sub(-1, -1, 24, &over); assert(!over && s == 0);
|
2013-04-17 00:02:18 -04:00
|
|
|
s = int_sub(-1, (1ULL<<23)-1, 24, &over); assert(!over && (s & ((1ULL<<24)-1)) == (1ULL<<23));
|
2013-04-17 00:02:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_int32() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_int_range(32);
|
|
|
|
int64_t s;
|
|
|
|
bool over;
|
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = int_add(1, (1ULL<<31)-1, 32, &over); assert(over);
|
|
|
|
s = int_add((1ULL<<31)-1, 1, 32, &over); assert(over);
|
|
|
|
s = int_sub(-1, (1ULL<<31), 32, &over); assert(s == (1ULL<<31)-1 && !over);
|
|
|
|
s = int_sub((1ULL<<31), 1, 32, &over); assert(over);
|
2013-04-17 00:02:16 -04:00
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = int_add(0, 0, 32, &over); assert(s == 0 && !over);
|
|
|
|
s = int_sub(0, 0, 32, &over); assert(s == 0 && !over);
|
|
|
|
s = int_add(0, -1, 32, &over); assert(s == -1 && !over);
|
|
|
|
s = int_sub(0, 1, 32, &over); assert(s == -1 && !over);
|
2013-04-17 00:02:18 -04:00
|
|
|
s = int_add(0, (1ULL<<31), 32, &over); assert((s & ((1ULL<<32)-1)) == (1ULL<<31) && !over);
|
|
|
|
s = int_sub(0, (1ULL<<31)-1, 32, &over); assert((s & ((1ULL<<32)-1)) == (1ULL<<31)+1 && !over);
|
2013-04-17 00:02:16 -04:00
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = int_add(-1, 0, 32, &over); assert(s == -1 && !over);
|
|
|
|
s = int_add(-1, 1, 32, &over); assert(s == 0 && !over);
|
|
|
|
s = int_sub(-1, -1, 32, &over); assert(s == 0 && !over);
|
2013-04-17 00:02:18 -04:00
|
|
|
s = int_sub(-1, (1ULL<<31)-1, 32, &over); assert((s & ((1ULL<<32)-1)) == (1ULL<<31) && !over);
|
2013-04-17 00:02:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_int64() {
|
|
|
|
printf("%s\n", __FUNCTION__);
|
|
|
|
test_int_range(64);
|
|
|
|
int64_t s;
|
|
|
|
bool over;
|
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = int_add(1, (1ULL<<63)-1, 64, &over); assert(over);
|
|
|
|
s = int_add((1ULL<<63)-1, 1, 64, &over); assert(over);
|
|
|
|
s = int_sub(-1, (1ULL<<63), 64, &over); assert(s == (1ULL<<63)-1 && !over);
|
|
|
|
s = int_sub((1ULL<<63), 1, 64, &over); assert(over);
|
2013-04-17 00:02:16 -04:00
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = int_add(0, 0, 64, &over); assert(s == 0 && !over);
|
|
|
|
s = int_sub(0, 0, 64, &over); assert(s == 0 && !over);
|
|
|
|
s = int_add(0, -1, 64, &over); assert(s == -1 && !over);
|
|
|
|
s = int_sub(0, 1, 64, &over); assert(s == -1 && !over);
|
2013-04-17 00:02:18 -04:00
|
|
|
s = int_add(0, (1ULL<<63), 64, &over); assert(s == (int64_t)(1ULL<<63) && !over);
|
|
|
|
s = int_sub(0, (1ULL<<63)-1, 64, &over); assert(s == (int64_t)((1ULL<<63)+1) && !over);
|
2013-04-17 00:02:16 -04:00
|
|
|
|
2013-04-17 00:02:16 -04:00
|
|
|
s = int_add(-1, 0, 64, &over); assert(s == -1 && !over);
|
|
|
|
s = int_add(-1, 1, 64, &over); assert(s == 0 && !over);
|
|
|
|
s = int_sub(-1, -1, 64, &over); assert(s == 0 && !over);
|
2013-04-17 00:02:18 -04:00
|
|
|
s = int_sub(-1, (1ULL<<63)-1, 64, &over); assert(s == (int64_t)(1ULL<<63) && !over);
|
2013-04-17 00:02:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_int_sign(uint length_bits) {
|
|
|
|
printf("%s %u\n", __FUNCTION__, length_bits);
|
|
|
|
int64_t n;
|
|
|
|
|
|
|
|
n = int_high_endpoint(length_bits);
|
|
|
|
assert(int_sign_extend(n, length_bits) == n);
|
|
|
|
n = (1ULL<<(length_bits-1));
|
|
|
|
assert(int_sign_extend(n, length_bits) == -n);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void test_int_sign() {
|
|
|
|
test_int_sign(8);
|
|
|
|
test_int_sign(16);
|
|
|
|
test_int_sign(24);
|
|
|
|
test_int_sign(32);
|
|
|
|
test_int_sign(64);
|
|
|
|
}
|
|
|
|
|
2013-04-17 00:02:18 -04:00
|
|
|
int main() {
|
2013-04-17 00:02:16 -04:00
|
|
|
if (1) test_int_sign();
|
|
|
|
if (1) test_int8();
|
|
|
|
if (1) test_int16();
|
|
|
|
if (1) test_int24();
|
|
|
|
if (1) test_int32();
|
|
|
|
if (1) test_int64();
|
|
|
|
|
|
|
|
if (1) test_uint8();
|
|
|
|
if (1) test_uint16();
|
|
|
|
if (1) test_uint24();
|
|
|
|
if (1) test_uint32();
|
|
|
|
if (1) test_uint64();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|