test(mpz): add unit tests for mpz

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2013-09-26 19:56:12 -07:00
parent 5cce74d116
commit 9d8ff0eadb
2 changed files with 48 additions and 0 deletions

View file

@ -7,3 +7,6 @@ add_test(mpbq ${CMAKE_CURRENT_BINARY_DIR}/mpbq)
add_executable(mpfp mpfp.cpp) add_executable(mpfp mpfp.cpp)
target_link_libraries(mpfp ${EXTRA_LIBS}) target_link_libraries(mpfp ${EXTRA_LIBS})
add_test(mpfp ${CMAKE_CURRENT_BINARY_DIR}/mpfp) add_test(mpfp ${CMAKE_CURRENT_BINARY_DIR}/mpfp)
add_executable(mpz mpz.cpp)
target_link_libraries(mpz ${EXTRA_LIBS})
add_test(mpz ${CMAKE_CURRENT_BINARY_DIR}/mpz)

View file

@ -0,0 +1,45 @@
/*
Copyright (c) 2013 Microsoft Corporation. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Author: Leonardo de Moura
*/
#include <iostream>
#include <sstream>
#include <string>
#include "util/test.h"
#include "util/numerics/mpz.h"
using namespace lean;
static void tst1() {
mpz a(-10);
lean_assert_eq(a.log2(), 0);
lean_assert_eq(a.mlog2(), 3);
lean_assert_eq(a.is_power_of_two(), false);
lean_assert_eq(mpz(10).mlog2(), 0);
mpz r;
lean_assert(root(r, mpz(4), 2));
lean_assert(r == 2);
lean_assert(!root(r, mpz(10), 2));
lean_assert(r == 3);
lean_assert(mpz(10) % mpz(3) == mpz(1));
lean_assert(mpz(10) % mpz(-3) == 1);
lean_assert(mpz(-10) % mpz(-3) == 2);
lean_assert(mpz(-10) % mpz(3) == 2);
mpz big;
big = power(mpz(10), 10000);
std::ostringstream out;
out << big;
std::string s = out.str();
lean_assert(s.size() == 10001);
lean_assert(s[0] == '1');
for (unsigned i = 1; i < 10001; i++) {
lean_assert(s[i] == '0');
}
}
int main() {
tst1();
return has_violations() ? 1 : 0;
}