~ubuntu-branches/ubuntu/raring/avr-libc/raring-proposed

« back to all changes in this revision

Viewing changes to tests/simulate/math/fmax-01.c

  • Committer: Bazaar Package Importer
  • Author(s): Hakan Ardo
  • Date: 2008-08-10 09:59:16 UTC
  • mfrom: (1.1.7 upstream) (4.1.1 lenny)
  • Revision ID: james.westby@ubuntu.com-20080810095916-wwyigh3vt0e9s7ud
Tags: 1:1.6.2.cvs20080610-2
Added build-depends on texlive-extra-utils (closes: #493454)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* Test of fmax() function.
 
2
   $Id: fmax-01.c,v 1.1 2007/02/05 21:35:58 dmix Exp $
 
3
 */
 
4
#include <math.h>
 
5
#include <stdio.h>
 
6
#include <stdlib.h>
 
7
#include "progmem.h"
 
8
 
 
9
union lofl_u {
 
10
    long lo;
 
11
    float fl;
 
12
};
 
13
 
 
14
volatile union lofl_u v = { .lo = 1 };
 
15
 
 
16
PROGMEM const struct {          /* Table of test cases  */
 
17
    union lofl_u x, y;          /* args         */
 
18
    union lofl_u z;             /* result       */
 
19
} t[] = {
 
20
 
 
21
    /* fmax (0,0)       */
 
22
    { { .fl=  0.0 }, { .fl=  0.0 }, { .fl=  0.0 } },
 
23
    { { .fl=  0.0 }, { .fl= -0.0 }, { .fl=  0.0 } },
 
24
    { { .fl= -0.0 }, { .fl= -0.0 }, { .fl= -0.0 } },
 
25
#ifdef  __AVR__
 
26
    { { .fl= -0.0 }, { .fl=  0.0 }, { .fl=  0.0 } },    /* Glibc: --> -0.0 */
 
27
#endif
 
28
 
 
29
    /* fmax (NaN, finite)       */
 
30
    { { 0x7f800001 }, { 0x7f7fffff }, { 0x7f7fffff } },
 
31
    { { 0x7f800100 }, { 0xff7fffff }, { 0xff7fffff } },
 
32
    { { 0x7f810000 }, { 0x00000001 }, { 0x00000001 } },
 
33
    { { 0x7fc00000 }, { 0x80000001 }, { 0x80000001 } },
 
34
    { { 0x7ffffffe }, { 0x00000000 }, { 0x00000000 } },
 
35
    { { 0x7fffffff }, { 0x80000000 }, { 0x80000000 } },
 
36
 
 
37
    { { 0xff800001 }, { 0x7f7fffff }, { 0x7f7fffff } },
 
38
    { { 0xff800100 }, { 0xff7fffff }, { 0xff7fffff } },
 
39
    { { 0xff810000 }, { 0x00000001 }, { 0x00000001 } },
 
40
    { { 0xffc00000 }, { 0x80000001 }, { 0x80000001 } },
 
41
    { { 0xfffffffe }, { 0x00000000 }, { 0x00000000 } },
 
42
    { { 0xffffffff }, { 0x80000000 }, { 0x80000000 } },
 
43
 
 
44
    /* fmax (finite, NaN)       */
 
45
    { { 0x7f7fffff }, { 0x7f800001 }, { 0x7f7fffff } },
 
46
    { { 0xff7fffff }, { 0x7f800100 }, { 0xff7fffff } },
 
47
    { { 0x00000001 }, { 0x7f810000 }, { 0x00000001 } },
 
48
    { { 0x80000001 }, { 0x7fc00000 }, { 0x80000001 } },
 
49
    { { 0x00000000 }, { 0x7ffffffe }, { 0x00000000 } },
 
50
    { { 0x80000000 }, { 0x7fffffff }, { 0x80000000 } },
 
51
 
 
52
    { { 0x7f7fffff }, { 0xff800001 }, { 0x7f7fffff } },
 
53
    { { 0xff7fffff }, { 0xff800100 }, { 0xff7fffff } },
 
54
    { { 0x00000001 }, { 0xff810000 }, { 0x00000001 } },
 
55
    { { 0x80000001 }, { 0xffc00000 }, { 0x80000001 } },
 
56
    { { 0x00000000 }, { 0xfffffffe }, { 0x00000000 } },
 
57
    { { 0x80000000 }, { 0xffffffff }, { 0x80000000 } },
 
58
    
 
59
    /* fmax (NaN, Inf)  */
 
60
    { { 0x7f800001 }, { 0x7f800000 }, { 0x7f800000 } },
 
61
    { { 0x7f800001 }, { 0xff800000 }, { 0xff800000 } },
 
62
    { { 0xff800001 }, { 0x7f800000 }, { 0x7f800000 } },
 
63
    { { 0xff800001 }, { 0xff800000 }, { 0xff800000 } },
 
64
    { { 0x7fffffff }, { 0x7f800000 }, { 0x7f800000 } },
 
65
    { { 0x7fffffff }, { 0xff800000 }, { 0xff800000 } },
 
66
    { { 0xffffffff }, { 0x7f800000 }, { 0x7f800000 } },
 
67
    { { 0xffffffff }, { 0xff800000 }, { 0xff800000 } },
 
68
 
 
69
    /* fmax (Inf, NaN)  */
 
70
    { { 0x7f800000 }, { 0x7f800001 }, { 0x7f800000 } },
 
71
    { { 0xff800000 }, { 0x7f800001 }, { 0xff800000 } },
 
72
    { { 0x7f800000 }, { 0xff800001 }, { 0x7f800000 } },
 
73
    { { 0xff800000 }, { 0xff800001 }, { 0xff800000 } },
 
74
    { { 0x7f800000 }, { 0x7fffffff }, { 0x7f800000 } },
 
75
    { { 0xff800000 }, { 0x7fffffff }, { 0xff800000 } },
 
76
    { { 0x7f800000 }, { 0xffffffff }, { 0x7f800000 } },
 
77
    { { 0xff800000 }, { 0xffffffff }, { 0xff800000 } },
 
78
 
 
79
    /* fmax (NaN, NaN)  */
 
80
    { { 0x7f800001 }, { 0x7fffffff }, { 0x7fffffff } },
 
81
    { { 0xffffffff }, { 0xff800001 }, { 0xff800001 } },
 
82
    
 
83
    /* fmax (Inf, Inf)  */
 
84
    { { 0x7f800000 }, { 0x7f800000 }, { 0x7f800000 } },
 
85
    { { 0xff800000 }, { 0x7f800000 }, { 0x7f800000 } },
 
86
    { { 0x7f800000 }, { 0xff800000 }, { 0x7f800000 } },
 
87
    { { 0xff800000 }, { 0xff800000 }, { 0xff800000 } },
 
88
 
 
89
    /* fmax (+Inf, finite)      */
 
90
    { { 0x7f800000 }, { 0x7f7fffff }, { 0x7f800000 } },
 
91
    { { 0x7f800000 }, { 0xff7fffff }, { 0x7f800000 } },
 
92
    
 
93
    /* fmax (-Inf, finite)      */
 
94
    { { 0xff800000 }, { 0x7f7fffff }, { 0x7f7fffff } },
 
95
    { { 0xff800000 }, { 0xff7fffff }, { 0xff7fffff } },
 
96
 
 
97
    /* fmax (finite, +Inf)      */
 
98
    { { 0x7f7fffff }, { 0x7f800000 }, { 0x7f800000 } },
 
99
    { { 0xff7fffff }, { 0x7f800000 }, { 0x7f800000 } },
 
100
    
 
101
    /* fmax (finite, -Inf)      */
 
102
    { { 0x7f7fffff }, { 0xff800000 }, { 0x7f7fffff } },
 
103
    { { 0xff7fffff }, { 0xff800000 }, { 0xff7fffff } },
 
104
    
 
105
    /* x == y   */
 
106
    { { 0x12345678 }, { 0x12345678 }, { 0x12345678 } },
 
107
    
 
108
    /* x < y    */
 
109
    { { 0xff7fffff }, { 0xff7ffffe }, { 0xff7ffffe } },
 
110
    { { 0x80000002 }, { 0x00000001 }, { 0x00000001 } },
 
111
    { { 0x7f7ffffe }, { 0x7f7fffff }, { 0x7f7fffff } },
 
112
    
 
113
    /* x > y    */
 
114
    { { 0xff7ffffe }, { 0xff7fffff }, { 0xff7ffffe } },
 
115
    { { 0x00000000 }, { 0x80000001 }, { 0x00000000 } },
 
116
    { { 0x7f7fffff }, { 0x7f7ffffe }, { 0x7f7fffff } },
 
117
    
 
118
};
 
119
 
 
120
void x_exit (int index)
 
121
{
 
122
#ifndef __AVR__
 
123
    fprintf (stderr, "t[%d]:  %#lx\n", index - 1, v.lo);
 
124
#endif
 
125
    exit (index ? index : -1);
 
126
}
 
127
 
 
128
int main ()
 
129
{
 
130
    union lofl_u x,y,z;
 
131
    int i;
 
132
    
 
133
    for (i = 0; i < (int) (sizeof(t) / sizeof(t[0])); i++) {
 
134
        y.lo = pgm_read_dword (& t[i].y);
 
135
        x.lo = pgm_read_dword (& t[i].x);
 
136
        z.lo = pgm_read_dword (& t[i].z);
 
137
        v.fl = fmax (x.fl, y.fl);
 
138
        
 
139
        if (   v.lo == z.lo
 
140
            || (isnan(v.fl) && isnan(z.fl))     )
 
141
          continue;
 
142
        x_exit (i+1);
 
143
    }
 
144
    return 0;
 
145
}