Add test for mpfp
This commit is contained in:
parent
fb41a4f5a3
commit
975730a3fb
2 changed files with 51 additions and 0 deletions
|
@ -4,3 +4,6 @@ add_test(mpq ${CMAKE_CURRENT_BINARY_DIR}/mpq)
|
||||||
add_executable(mpbq mpbq.cpp)
|
add_executable(mpbq mpbq.cpp)
|
||||||
target_link_libraries(mpbq ${EXTRA_LIBS})
|
target_link_libraries(mpbq ${EXTRA_LIBS})
|
||||||
add_test(mpbq ${CMAKE_CURRENT_BINARY_DIR}/mpbq)
|
add_test(mpbq ${CMAKE_CURRENT_BINARY_DIR}/mpbq)
|
||||||
|
add_executable(mpfp mpfp.cpp)
|
||||||
|
target_link_libraries(mpfp ${EXTRA_LIBS})
|
||||||
|
add_test(mpfp ${CMAKE_CURRENT_BINARY_DIR}/mpfp)
|
||||||
|
|
48
src/tests/util/numerics/mpfp.cpp
Normal file
48
src/tests/util/numerics/mpfp.cpp
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2013 Microsoft Corporation. All rights reserved.
|
||||||
|
Released under Apache 2.0 license as described in the file LICENSE.
|
||||||
|
|
||||||
|
Author: Soonho Kong
|
||||||
|
*/
|
||||||
|
#include <iostream>
|
||||||
|
#include "test.h"
|
||||||
|
#include "mpfp.h"
|
||||||
|
using namespace lean;
|
||||||
|
|
||||||
|
static void tst1() {
|
||||||
|
mpfp a(3.141592, 64);
|
||||||
|
std::cout << "a = |" << a << "|" << std::endl;
|
||||||
|
std::cout << "exp(a, UP ) = |" << exp(a, MPFR_RNDU) << "|" << std::endl;
|
||||||
|
std::cout << "exp(a, NEAR) = |" << exp(a, MPFR_RNDN) << "|" << std::endl;
|
||||||
|
std::cout << "exp(a, DOWN) = |" << exp(a, MPFR_RNDD) << "|" << std::endl;
|
||||||
|
|
||||||
|
mpfp b = mpfp(5.141592, 128);
|
||||||
|
std::cout << "b = |" << b << "|" << std::endl;
|
||||||
|
std::cout << "exp(b, UP ) = |" << exp(b, MPFR_RNDU) << "|" << std::endl;
|
||||||
|
std::cout << "exp(b, NEBR) = |" << exp(b, MPFR_RNDN) << "|" << std::endl;
|
||||||
|
std::cout << "exp(b, DOWN) = |" << exp(b, MPFR_RNDD) << "|" << std::endl;
|
||||||
|
|
||||||
|
mpfp c = mpfp(6.141592, 256);
|
||||||
|
std::cout << "c = |" << c << "|" << std::endl;
|
||||||
|
std::cout << "exp(c, UP ) = |" << exp(c, MPFR_RNDU) << "|" << std::endl;
|
||||||
|
std::cout << "exp(c, NEAR) = |" << exp(c, MPFR_RNDN) << "|" << std::endl;
|
||||||
|
std::cout << "exp(c, DOWN) = |" << exp(c, MPFR_RNDD) << "|" << std::endl;
|
||||||
|
|
||||||
|
std::cout << "a = |" << a << "|" << std::endl;
|
||||||
|
std::cout << "exp(a, UP ) = |" << exp(a, MPFR_RNDU) << "|" << std::endl;
|
||||||
|
std::cout << "exp(a, NEAR) = |" << exp(a, MPFR_RNDN) << "|" << std::endl;
|
||||||
|
std::cout << "exp(a, DOWN) = |" << exp(a, MPFR_RNDD) << "|" << std::endl;
|
||||||
|
|
||||||
|
std::cout << "b = |" << b << "|" << std::endl;
|
||||||
|
std::cout << "exp(b, UP ) = |" << exp(b, MPFR_RNDU) << "|" << std::endl;
|
||||||
|
std::cout << "exp(b, NEAR) = |" << exp(b, MPFR_RNDN) << "|" << std::endl;
|
||||||
|
std::cout << "exp(b, DOWN) = |" << exp(b, MPFR_RNDD) << "|" << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
continue_on_violation(true);
|
||||||
|
tst1();
|
||||||
|
return has_violations() ? 1 : 0;
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in a new issue