blob: 75e7f6d9b5608559b492341cf865c96d5d5c0be7 (
plain)
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
86
87
88
89
|
/** Simple set of tests for floating pt.
*/
#include <testfwk.h>
#include <math.h>
#if (PORT_HOST)
# define FCOMP(a,b) (fabsf((a) - (b)) < ((b) * 1e-7))
#else
/* Testing floats for equality is normally a bug,
but too keep this test simple we dare it. And
it works with the exception of the division on
the host port. */
# define FCOMP(a,b) ((a) == (b))
#endif
void
testCmp (void)
{
#if !defined( __SDCC_pdk14) && !defined( __SDCC_pdk15) // Lack of memory
volatile float left, right;
left = 5;
right = 13;
ASSERT (left + right == 18);
ASSERT (left + right <= 18);
ASSERT (left + right >= 18);
ASSERT (left + right > 17.9);
ASSERT (left + right < 18.1);
#endif
}
void
testDiv (void)
{
#if !defined( __SDCC_pdk14) && !defined(__SDCC_pdk15) // Lack of memory
#if defined (__SDCC_mcs51) && !defined (__SDCC_STACK_AUTO)
volatile __idata float __at 0xd0 left;
#else
volatile float left;
#endif
volatile float right;
left = 17;
right = 343;
ASSERT (FCOMP (left / right, (17.0 / 343.0)));
ASSERT (FCOMP (right / left, (343.0 / 17.0)));
right = 17;
ASSERT (FCOMP (left / right, 1.0));
#endif
}
void
testDivNearOne (void)
{
#if !defined( __SDCC_pdk14) && !defined(__SDCC_pdk15) // Lack of memory
volatile float left, right, result;
left = 12392.4;
right = 12392.4;
result = left / right;
if (result > 0.999999)
{
/* Fine */
}
else
{
FAIL ();
}
if (result < 1.00001)
{
/* Fine */
}
else
{
FAIL ();
}
if (result > 0.999999 && result < 1.00001)
{
/* Fine */
}
else
{
FAIL ();
}
#endif
}
|