File: test_ldexp.cl

package info (click to toggle)
pocl 6.0-7
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 25,320 kB
  • sloc: lisp: 149,513; ansic: 103,778; cpp: 54,947; python: 1,513; sh: 949; ruby: 255; pascal: 226; tcl: 180; makefile: 175; java: 72; xml: 49
file content (49 lines) | stat: -rw-r--r-- 1,133 bytes parent folder | download | duplicates (4)
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
#include "common.cl"

DEFINE_BODY_V (
    test_ldexp, ({
      /* ldexp */
      Ivec ival2;
      ival2.v = (itype)4;
      res.v = ldexp (val.v, ival2.v);
      Tvec goodres;
      equal = true;
      for (int n = 0; n < vecsize; ++n)
        {
          if (ISNAN (val.s[n]))
            {
              goodres.s[n] = NAN;
            }
          else if (val.s[n] == (stype)0)
            {
              goodres.s[n] = val.s[n];
            }
          else if (isinf (val.s[n]))
            {
              goodres.s[n] = val.s[n];
            }
          else
            {
              goodres.s[n] = val.s[n] * (stype) (16.0f);
            }
          equal = equal && ISEQ (res.s[n], goodres.s[n]);
        }
      if (!equal)
        {
          for (int n = 0; n < vecsize; ++n)
            {
              printf ("FAIL: ldexp type=%s val=%.17g val2=%d res=%.17g "
                      "good=%.17g\n",
                      typename, val.s[n], (int)ival2.s[n], res.s[n],
                      goodres.s[n]);
            }
          return;
        }
    }))


kernel void
test_ldexp ()
{
  CALL_FUNC_V (test_ldexp)
}