-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathxlnsbothtest.cpp
85 lines (74 loc) · 1.51 KB
/
xlnsbothtest.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// this tests that xlns16.cpp and xlns32.cpp can coexist in the same executable using either C calls or C++ overloaded ops
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#define xlns32_ideal
#include "xlns32.cpp"
#define xlns16_ideal
#include "xlns16.cpp"
void test1xlns32()
{
xlns32 odd,sum,two;
int i;
odd = fp2xlns32(1.0);
sum = fp2xlns32(0.0);
two = fp2xlns32(2.0);
for (i=1; i<=10000; i++)
{
sum = xlns32_add(sum,odd);
odd = xlns32_add(odd,two);
}
printf("test1xlns32 odd=%f sum=%f\n", xlns322fp(odd),xlns322fp(sum));
}
void test1xlns16()
{
xlns16 odd,sum,two;
int i;
odd = fp2xlns16(1.0);
sum = fp2xlns16(0.0);
two = fp2xlns16(2.0);
for (i=1; i<=10000; i++)
{
sum = xlns16_add(sum,odd);
odd = xlns16_add(odd,two);
}
printf("test1xlns16 odd=%f sum=%f\n", xlns162fp(odd),xlns162fp(sum));
}
void test5xlns16_float()
{
xlns16_float num,val,sum;
long i;
num = 1.0;
sum = 0.0;
val = num;
for (i=1; i<=1000; i++)
{
sum = sum + val/num;
val = -val;
num = num + 2.0;
}
std::cout << "test5xlns16_float num=" << num << " 4*sum=" << 4*sum << "\n";
}
void test5xlns32_float()
{
xlns32_float num,val,sum;
long i;
num = 1.0;
sum = 0.0;
val = num;
for (i=1; i<=1000; i++)
{
sum = sum + val/num;
val = -val;
num = num + 2.0;
}
std::cout << "test5xlns32_float num=" << num << " 4*sum=" << 4*sum << "\n";
}
int main()
{
test5xlns32_float();
test5xlns16_float();
test1xlns32();
test1xlns16();
return 1;
}