forked from Z3Prover/z3
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathf2n.cpp
68 lines (57 loc) · 1.53 KB
/
f2n.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/*++
Copyright (c) 2012 Microsoft Corporation
Module Name:
f2n.cpp
Abstract:
Author:
Leonardo de Moura (leonardo) 2012-08-17.
Revision History:
--*/
#include "util/f2n.h"
#include "util/hwf.h"
#include "util/mpf.h"
static void tst1() {
hwf_manager hm;
f2n<hwf_manager> m(hm);
hwf a, b;
m.set(a, 11, 3);
m.floor(a, b);
std::cout << "floor(11/3): " << m.to_double(b) << "\n";
m.ceil(a, b);
std::cout << "ceil(11/3): " << m.to_double(b) << "\n";
m.set(a, -11, 3);
m.floor(a, b);
std::cout << "floor(-11/3): " << m.to_double(b) << "\n";
m.ceil(a, b);
std::cout << "ceil(-11/3): " << m.to_double(b) << "\n";
m.set(a, 11, 1);
m.floor(a, b);
std::cout << "floor(11): " << m.to_double(b) << "\n";
m.ceil(a, b);
std::cout << "ceil(11): " << m.to_double(b) << "\n";
}
static void tst2() {
std::cout << "using mpf...\n";
mpf_manager fm;
f2n<mpf_manager> m(fm);
scoped_mpf a(fm), b(fm);
m.set(a, 11, 3);
m.floor(a, b);
std::cout << "floor(11/3): " << m.to_double(b) << "\n";
m.ceil(a, b);
std::cout << "ceil(11/3): " << m.to_double(b) << "\n";
m.set(a, -11, 3);
m.floor(a, b);
std::cout << "floor(-11/3): " << m.to_double(b) << "\n";
m.ceil(a, b);
std::cout << "ceil(-11/3): " << m.to_double(b) << "\n";
m.set(a, 11, 1);
m.floor(a, b);
std::cout << "floor(11): " << m.to_double(b) << "\n";
m.ceil(a, b);
std::cout << "ceil(11): " << m.to_double(b) << "\n";
}
void tst_f2n() {
tst1();
tst2();
}