Coverage Report

Created: 2026-06-28 06:39

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/moddable/xs/tools/fdlibm/e_rem_pio2.c
Line
Count
Source
1
2
/*
3
 * ====================================================
4
 * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
5
 *
6
 * Developed at SunSoft, a Sun Microsystems, Inc. business.
7
 * Permission to use, copy, modify, and distribute this
8
 * software is freely granted, provided that this notice 
9
 * is preserved.
10
 * ====================================================
11
 *
12
 * Optimized by Bruce D. Evans.
13
 */
14
15
/* __ieee754_rem_pio2(x,y)
16
 * 
17
 * return the remainder of x rem pi/2 in y[0]+y[1] 
18
 * use __kernel_rem_pio2()
19
 */
20
21
#include "math_private.h"
22
23
/*
24
 * invpio2:  53 bits of 2/pi
25
 * pio2_1:   first  33 bit of pi/2
26
 * pio2_1t:  pi/2 - pio2_1
27
 * pio2_2:   second 33 bit of pi/2
28
 * pio2_2t:  pi/2 - (pio2_1+pio2_2)
29
 * pio2_3:   third  33 bit of pi/2
30
 * pio2_3t:  pi/2 - (pio2_1+pio2_2+pio2_3)
31
 */
32
33
static const double
34
zero =  0.00000000000000000000e+00, /* 0x00000000, 0x00000000 */
35
two24 =  1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */
36
invpio2 =  6.36619772367581382433e-01, /* 0x3FE45F30, 0x6DC9C883 */
37
pio2_1  =  1.57079632673412561417e+00, /* 0x3FF921FB, 0x54400000 */
38
pio2_1t =  6.07710050650619224932e-11, /* 0x3DD0B461, 0x1A626331 */
39
pio2_2  =  6.07710050630396597660e-11, /* 0x3DD0B461, 0x1A600000 */
40
pio2_2t =  2.02226624879595063154e-21, /* 0x3BA3198A, 0x2E037073 */
41
pio2_3  =  2.02226624871116645580e-21, /* 0x3BA3198A, 0x2E000000 */
42
pio2_3t =  8.47842766036889956997e-32; /* 0x397B839A, 0x252049C1 */
43
44
#ifdef INLINE_REM_PIO2
45
static inline
46
#endif
47
int
48
__ieee754_rem_pio2(double x, double *y)
49
336k
{
50
336k
  double z,w,t,r,fn;
51
336k
  double tx[3],ty[2];
52
336k
  int32_t e0,i,j,nx,n,ix,hx;
53
336k
  u_int32_t low;
54
55
336k
  GET_HIGH_WORD(hx,x);   /* high word of x */
56
336k
  ix = hx&0x7fffffff;
57
#if 0 /* Must be handled in caller. */
58
  if(ix<=0x3fe921fb)   /* |x| ~<= pi/4 , no need for reduction */
59
      {y[0] = x; y[1] = 0; return 0;}
60
#endif
61
336k
  if (ix <= 0x400f6a7a) {   /* |x| ~<= 5pi/4 */
62
201k
      if ((ix & 0xfffff) == 0x921fb)  /* |x| ~= pi/2 or 2pi/2 */
63
0
    goto medium;   /* cancellation -- use medium case */
64
201k
      if (ix <= 0x4002d97c) { /* |x| ~<= 3pi/4 */
65
192k
    if (hx > 0) {
66
187k
        z = x - pio2_1; /* one round good to 85 bits */
67
187k
        y[0] = z - pio2_1t;
68
187k
        y[1] = (z-y[0])-pio2_1t;
69
187k
        return 1;
70
187k
    } else {
71
4.66k
        z = x + pio2_1;
72
4.66k
        y[0] = z + pio2_1t;
73
4.66k
        y[1] = (z-y[0])+pio2_1t;
74
4.66k
        return -1;
75
4.66k
    }
76
192k
      } else {
77
9.16k
    if (hx > 0) {
78
2.88k
        z = x - 2*pio2_1;
79
2.88k
        y[0] = z - 2*pio2_1t;
80
2.88k
        y[1] = (z-y[0])-2*pio2_1t;
81
2.88k
        return 2;
82
6.27k
    } else {
83
6.27k
        z = x + 2*pio2_1;
84
6.27k
        y[0] = z + 2*pio2_1t;
85
6.27k
        y[1] = (z-y[0])+2*pio2_1t;
86
6.27k
        return -2;
87
6.27k
    }
88
9.16k
      }
89
201k
  }
90
134k
  if (ix <= 0x401c463b) {   /* |x| ~<= 9pi/4 */
91
10.6k
      if (ix <= 0x4015fdbc) { /* |x| ~<= 7pi/4 */
92
4.57k
    if (ix == 0x4012d97c)  /* |x| ~= 3pi/2 */
93
0
        goto medium;
94
4.57k
    if (hx > 0) {
95
2.03k
        z = x - 3*pio2_1;
96
2.03k
        y[0] = z - 3*pio2_1t;
97
2.03k
        y[1] = (z-y[0])-3*pio2_1t;
98
2.03k
        return 3;
99
2.53k
    } else {
100
2.53k
        z = x + 3*pio2_1;
101
2.53k
        y[0] = z + 3*pio2_1t;
102
2.53k
        y[1] = (z-y[0])+3*pio2_1t;
103
2.53k
        return -3;
104
2.53k
    }
105
6.12k
      } else {
106
6.12k
    if (ix == 0x401921fb)  /* |x| ~= 4pi/2 */
107
0
        goto medium;
108
6.12k
    if (hx > 0) {
109
1.68k
        z = x - 4*pio2_1;
110
1.68k
        y[0] = z - 4*pio2_1t;
111
1.68k
        y[1] = (z-y[0])-4*pio2_1t;
112
1.68k
        return 4;
113
4.44k
    } else {
114
4.44k
        z = x + 4*pio2_1;
115
4.44k
        y[0] = z + 4*pio2_1t;
116
4.44k
        y[1] = (z-y[0])+4*pio2_1t;
117
4.44k
        return -4;
118
4.44k
    }
119
6.12k
      }
120
10.6k
  }
121
123k
  if(ix<0x413921fb) { /* |x| ~< 2^20*(pi/2), medium size */
122
111k
medium:
123
111k
      fn = rnint((double_t)x*invpio2);
124
111k
      n  = irint(fn);
125
111k
      r  = x-fn*pio2_1;
126
111k
      w  = fn*pio2_1t;  /* 1st round good to 85 bit */
127
111k
      {
128
111k
          u_int32_t high;
129
111k
          j  = ix>>20;
130
111k
          y[0] = r-w; 
131
111k
    GET_HIGH_WORD(high,y[0]);
132
111k
          i = j-((high>>20)&0x7ff);
133
111k
          if(i>16) {  /* 2nd iteration needed, good to 118 */
134
2.63k
        t  = r;
135
2.63k
        w  = fn*pio2_2; 
136
2.63k
        r  = t-w;
137
2.63k
        w  = fn*pio2_2t-((t-r)-w);  
138
2.63k
        y[0] = r-w;
139
2.63k
        GET_HIGH_WORD(high,y[0]);
140
2.63k
        i = j-((high>>20)&0x7ff);
141
2.63k
        if(i>49)  { /* 3rd iteration need, 151 bits acc */
142
0
          t  = r; /* will cover all possible cases */
143
0
          w  = fn*pio2_3; 
144
0
          r  = t-w;
145
0
          w  = fn*pio2_3t-((t-r)-w);  
146
0
          y[0] = r-w;
147
0
        }
148
2.63k
    }
149
111k
      }
150
111k
      y[1] = (r-y[0])-w;
151
111k
      return n;
152
111k
  }
153
    /* 
154
     * all other (large) arguments
155
     */
156
12.7k
  if(ix>=0x7ff00000) {   /* x is inf or NaN */
157
0
      y[0]=y[1]=x-x; return 0;
158
0
  }
159
    /* set z = scalbn(|x|,ilogb(x)-23) */
160
12.7k
  GET_LOW_WORD(low,x);
161
12.7k
  e0  = (ix>>20)-1046;  /* e0 = ilogb(z)-23; */
162
12.7k
  INSERT_WORDS(z, ix - ((int32_t)((u_int32_t)e0<<20)), low);
163
38.2k
  for(i=0;i<2;i++) {
164
25.4k
    tx[i] = (double)((int32_t)(z));
165
25.4k
    z     = (z-tx[i])*two24;
166
25.4k
  }
167
12.7k
  tx[2] = z;
168
12.7k
  nx = 3;
169
23.3k
  while(tx[nx-1]==zero) nx--; /* skip zero term */
170
12.7k
  n  =  __kernel_rem_pio2(tx,ty,e0,nx,1);
171
12.7k
  if(hx<0) {y[0] = -ty[0]; y[1] = -ty[1]; return -n;}
172
3.74k
  y[0] = ty[0]; y[1] = ty[1]; return n;
173
12.7k
}
Unexecuted instantiation: __ieee754_rem_pio2
s_cos.c:__ieee754_rem_pio2
Line
Count
Source
49
284k
{
50
284k
  double z,w,t,r,fn;
51
284k
  double tx[3],ty[2];
52
284k
  int32_t e0,i,j,nx,n,ix,hx;
53
284k
  u_int32_t low;
54
55
284k
  GET_HIGH_WORD(hx,x);   /* high word of x */
56
284k
  ix = hx&0x7fffffff;
57
#if 0 /* Must be handled in caller. */
58
  if(ix<=0x3fe921fb)   /* |x| ~<= pi/4 , no need for reduction */
59
      {y[0] = x; y[1] = 0; return 0;}
60
#endif
61
284k
  if (ix <= 0x400f6a7a) {   /* |x| ~<= 5pi/4 */
62
190k
      if ((ix & 0xfffff) == 0x921fb)  /* |x| ~= pi/2 or 2pi/2 */
63
0
    goto medium;   /* cancellation -- use medium case */
64
190k
      if (ix <= 0x4002d97c) { /* |x| ~<= 3pi/4 */
65
185k
    if (hx > 0) {
66
181k
        z = x - pio2_1; /* one round good to 85 bits */
67
181k
        y[0] = z - pio2_1t;
68
181k
        y[1] = (z-y[0])-pio2_1t;
69
181k
        return 1;
70
181k
    } else {
71
3.89k
        z = x + pio2_1;
72
3.89k
        y[0] = z + pio2_1t;
73
3.89k
        y[1] = (z-y[0])+pio2_1t;
74
3.89k
        return -1;
75
3.89k
    }
76
185k
      } else {
77
4.45k
    if (hx > 0) {
78
797
        z = x - 2*pio2_1;
79
797
        y[0] = z - 2*pio2_1t;
80
797
        y[1] = (z-y[0])-2*pio2_1t;
81
797
        return 2;
82
3.65k
    } else {
83
3.65k
        z = x + 2*pio2_1;
84
3.65k
        y[0] = z + 2*pio2_1t;
85
3.65k
        y[1] = (z-y[0])+2*pio2_1t;
86
3.65k
        return -2;
87
3.65k
    }
88
4.45k
      }
89
190k
  }
90
93.9k
  if (ix <= 0x401c463b) {   /* |x| ~<= 9pi/4 */
91
6.55k
      if (ix <= 0x4015fdbc) { /* |x| ~<= 7pi/4 */
92
2.63k
    if (ix == 0x4012d97c)  /* |x| ~= 3pi/2 */
93
0
        goto medium;
94
2.63k
    if (hx > 0) {
95
579
        z = x - 3*pio2_1;
96
579
        y[0] = z - 3*pio2_1t;
97
579
        y[1] = (z-y[0])-3*pio2_1t;
98
579
        return 3;
99
2.05k
    } else {
100
2.05k
        z = x + 3*pio2_1;
101
2.05k
        y[0] = z + 3*pio2_1t;
102
2.05k
        y[1] = (z-y[0])+3*pio2_1t;
103
2.05k
        return -3;
104
2.05k
    }
105
3.92k
      } else {
106
3.92k
    if (ix == 0x401921fb)  /* |x| ~= 4pi/2 */
107
0
        goto medium;
108
3.92k
    if (hx > 0) {
109
381
        z = x - 4*pio2_1;
110
381
        y[0] = z - 4*pio2_1t;
111
381
        y[1] = (z-y[0])-4*pio2_1t;
112
381
        return 4;
113
3.54k
    } else {
114
3.54k
        z = x + 4*pio2_1;
115
3.54k
        y[0] = z + 4*pio2_1t;
116
3.54k
        y[1] = (z-y[0])+4*pio2_1t;
117
3.54k
        return -4;
118
3.54k
    }
119
3.92k
      }
120
6.55k
  }
121
87.3k
  if(ix<0x413921fb) { /* |x| ~< 2^20*(pi/2), medium size */
122
86.2k
medium:
123
86.2k
      fn = rnint((double_t)x*invpio2);
124
86.2k
      n  = irint(fn);
125
86.2k
      r  = x-fn*pio2_1;
126
86.2k
      w  = fn*pio2_1t;  /* 1st round good to 85 bit */
127
86.2k
      {
128
86.2k
          u_int32_t high;
129
86.2k
          j  = ix>>20;
130
86.2k
          y[0] = r-w; 
131
86.2k
    GET_HIGH_WORD(high,y[0]);
132
86.2k
          i = j-((high>>20)&0x7ff);
133
86.2k
          if(i>16) {  /* 2nd iteration needed, good to 118 */
134
262
        t  = r;
135
262
        w  = fn*pio2_2; 
136
262
        r  = t-w;
137
262
        w  = fn*pio2_2t-((t-r)-w);  
138
262
        y[0] = r-w;
139
262
        GET_HIGH_WORD(high,y[0]);
140
262
        i = j-((high>>20)&0x7ff);
141
262
        if(i>49)  { /* 3rd iteration need, 151 bits acc */
142
0
          t  = r; /* will cover all possible cases */
143
0
          w  = fn*pio2_3; 
144
0
          r  = t-w;
145
0
          w  = fn*pio2_3t-((t-r)-w);  
146
0
          y[0] = r-w;
147
0
        }
148
262
    }
149
86.2k
      }
150
86.2k
      y[1] = (r-y[0])-w;
151
86.2k
      return n;
152
86.2k
  }
153
    /* 
154
     * all other (large) arguments
155
     */
156
1.07k
  if(ix>=0x7ff00000) {   /* x is inf or NaN */
157
0
      y[0]=y[1]=x-x; return 0;
158
0
  }
159
    /* set z = scalbn(|x|,ilogb(x)-23) */
160
1.07k
  GET_LOW_WORD(low,x);
161
1.07k
  e0  = (ix>>20)-1046;  /* e0 = ilogb(z)-23; */
162
1.07k
  INSERT_WORDS(z, ix - ((int32_t)((u_int32_t)e0<<20)), low);
163
3.22k
  for(i=0;i<2;i++) {
164
2.15k
    tx[i] = (double)((int32_t)(z));
165
2.15k
    z     = (z-tx[i])*two24;
166
2.15k
  }
167
1.07k
  tx[2] = z;
168
1.07k
  nx = 3;
169
1.72k
  while(tx[nx-1]==zero) nx--; /* skip zero term */
170
1.07k
  n  =  __kernel_rem_pio2(tx,ty,e0,nx,1);
171
1.07k
  if(hx<0) {y[0] = -ty[0]; y[1] = -ty[1]; return -n;}
172
524
  y[0] = ty[0]; y[1] = ty[1]; return n;
173
1.07k
}
s_sin.c:__ieee754_rem_pio2
Line
Count
Source
49
18.4k
{
50
18.4k
  double z,w,t,r,fn;
51
18.4k
  double tx[3],ty[2];
52
18.4k
  int32_t e0,i,j,nx,n,ix,hx;
53
18.4k
  u_int32_t low;
54
55
18.4k
  GET_HIGH_WORD(hx,x);   /* high word of x */
56
18.4k
  ix = hx&0x7fffffff;
57
#if 0 /* Must be handled in caller. */
58
  if(ix<=0x3fe921fb)   /* |x| ~<= pi/4 , no need for reduction */
59
      {y[0] = x; y[1] = 0; return 0;}
60
#endif
61
18.4k
  if (ix <= 0x400f6a7a) {   /* |x| ~<= 5pi/4 */
62
9.85k
      if ((ix & 0xfffff) == 0x921fb)  /* |x| ~= pi/2 or 2pi/2 */
63
0
    goto medium;   /* cancellation -- use medium case */
64
9.85k
      if (ix <= 0x4002d97c) { /* |x| ~<= 3pi/4 */
65
5.51k
    if (hx > 0) {
66
4.99k
        z = x - pio2_1; /* one round good to 85 bits */
67
4.99k
        y[0] = z - pio2_1t;
68
4.99k
        y[1] = (z-y[0])-pio2_1t;
69
4.99k
        return 1;
70
4.99k
    } else {
71
519
        z = x + pio2_1;
72
519
        y[0] = z + pio2_1t;
73
519
        y[1] = (z-y[0])+pio2_1t;
74
519
        return -1;
75
519
    }
76
5.51k
      } else {
77
4.34k
    if (hx > 0) {
78
1.83k
        z = x - 2*pio2_1;
79
1.83k
        y[0] = z - 2*pio2_1t;
80
1.83k
        y[1] = (z-y[0])-2*pio2_1t;
81
1.83k
        return 2;
82
2.50k
    } else {
83
2.50k
        z = x + 2*pio2_1;
84
2.50k
        y[0] = z + 2*pio2_1t;
85
2.50k
        y[1] = (z-y[0])+2*pio2_1t;
86
2.50k
        return -2;
87
2.50k
    }
88
4.34k
      }
89
9.85k
  }
90
8.58k
  if (ix <= 0x401c463b) {   /* |x| ~<= 9pi/4 */
91
2.94k
      if (ix <= 0x4015fdbc) { /* |x| ~<= 7pi/4 */
92
1.34k
    if (ix == 0x4012d97c)  /* |x| ~= 3pi/2 */
93
0
        goto medium;
94
1.34k
    if (hx > 0) {
95
967
        z = x - 3*pio2_1;
96
967
        y[0] = z - 3*pio2_1t;
97
967
        y[1] = (z-y[0])-3*pio2_1t;
98
967
        return 3;
99
967
    } else {
100
376
        z = x + 3*pio2_1;
101
376
        y[0] = z + 3*pio2_1t;
102
376
        y[1] = (z-y[0])+3*pio2_1t;
103
376
        return -3;
104
376
    }
105
1.60k
      } else {
106
1.60k
    if (ix == 0x401921fb)  /* |x| ~= 4pi/2 */
107
0
        goto medium;
108
1.60k
    if (hx > 0) {
109
807
        z = x - 4*pio2_1;
110
807
        y[0] = z - 4*pio2_1t;
111
807
        y[1] = (z-y[0])-4*pio2_1t;
112
807
        return 4;
113
807
    } else {
114
796
        z = x + 4*pio2_1;
115
796
        y[0] = z + 4*pio2_1t;
116
796
        y[1] = (z-y[0])+4*pio2_1t;
117
796
        return -4;
118
796
    }
119
1.60k
      }
120
2.94k
  }
121
5.63k
  if(ix<0x413921fb) { /* |x| ~< 2^20*(pi/2), medium size */
122
2.27k
medium:
123
2.27k
      fn = rnint((double_t)x*invpio2);
124
2.27k
      n  = irint(fn);
125
2.27k
      r  = x-fn*pio2_1;
126
2.27k
      w  = fn*pio2_1t;  /* 1st round good to 85 bit */
127
2.27k
      {
128
2.27k
          u_int32_t high;
129
2.27k
          j  = ix>>20;
130
2.27k
          y[0] = r-w; 
131
2.27k
    GET_HIGH_WORD(high,y[0]);
132
2.27k
          i = j-((high>>20)&0x7ff);
133
2.27k
          if(i>16) {  /* 2nd iteration needed, good to 118 */
134
329
        t  = r;
135
329
        w  = fn*pio2_2; 
136
329
        r  = t-w;
137
329
        w  = fn*pio2_2t-((t-r)-w);  
138
329
        y[0] = r-w;
139
329
        GET_HIGH_WORD(high,y[0]);
140
329
        i = j-((high>>20)&0x7ff);
141
329
        if(i>49)  { /* 3rd iteration need, 151 bits acc */
142
0
          t  = r; /* will cover all possible cases */
143
0
          w  = fn*pio2_3; 
144
0
          r  = t-w;
145
0
          w  = fn*pio2_3t-((t-r)-w);  
146
0
          y[0] = r-w;
147
0
        }
148
329
    }
149
2.27k
      }
150
2.27k
      y[1] = (r-y[0])-w;
151
2.27k
      return n;
152
2.27k
  }
153
    /* 
154
     * all other (large) arguments
155
     */
156
3.36k
  if(ix>=0x7ff00000) {   /* x is inf or NaN */
157
0
      y[0]=y[1]=x-x; return 0;
158
0
  }
159
    /* set z = scalbn(|x|,ilogb(x)-23) */
160
3.36k
  GET_LOW_WORD(low,x);
161
3.36k
  e0  = (ix>>20)-1046;  /* e0 = ilogb(z)-23; */
162
3.36k
  INSERT_WORDS(z, ix - ((int32_t)((u_int32_t)e0<<20)), low);
163
10.0k
  for(i=0;i<2;i++) {
164
6.73k
    tx[i] = (double)((int32_t)(z));
165
6.73k
    z     = (z-tx[i])*two24;
166
6.73k
  }
167
3.36k
  tx[2] = z;
168
3.36k
  nx = 3;
169
9.10k
  while(tx[nx-1]==zero) nx--; /* skip zero term */
170
3.36k
  n  =  __kernel_rem_pio2(tx,ty,e0,nx,1);
171
3.36k
  if(hx<0) {y[0] = -ty[0]; y[1] = -ty[1]; return -n;}
172
1.50k
  y[0] = ty[0]; y[1] = ty[1]; return n;
173
3.36k
}
s_tan.c:__ieee754_rem_pio2
Line
Count
Source
49
33.4k
{
50
33.4k
  double z,w,t,r,fn;
51
33.4k
  double tx[3],ty[2];
52
33.4k
  int32_t e0,i,j,nx,n,ix,hx;
53
33.4k
  u_int32_t low;
54
55
33.4k
  GET_HIGH_WORD(hx,x);   /* high word of x */
56
33.4k
  ix = hx&0x7fffffff;
57
#if 0 /* Must be handled in caller. */
58
  if(ix<=0x3fe921fb)   /* |x| ~<= pi/4 , no need for reduction */
59
      {y[0] = x; y[1] = 0; return 0;}
60
#endif
61
33.4k
  if (ix <= 0x400f6a7a) {   /* |x| ~<= 5pi/4 */
62
1.35k
      if ((ix & 0xfffff) == 0x921fb)  /* |x| ~= pi/2 or 2pi/2 */
63
0
    goto medium;   /* cancellation -- use medium case */
64
1.35k
      if (ix <= 0x4002d97c) { /* |x| ~<= 3pi/4 */
65
991
    if (hx > 0) {
66
745
        z = x - pio2_1; /* one round good to 85 bits */
67
745
        y[0] = z - pio2_1t;
68
745
        y[1] = (z-y[0])-pio2_1t;
69
745
        return 1;
70
745
    } else {
71
246
        z = x + pio2_1;
72
246
        y[0] = z + pio2_1t;
73
246
        y[1] = (z-y[0])+pio2_1t;
74
246
        return -1;
75
246
    }
76
991
      } else {
77
364
    if (hx > 0) {
78
250
        z = x - 2*pio2_1;
79
250
        y[0] = z - 2*pio2_1t;
80
250
        y[1] = (z-y[0])-2*pio2_1t;
81
250
        return 2;
82
250
    } else {
83
114
        z = x + 2*pio2_1;
84
114
        y[0] = z + 2*pio2_1t;
85
114
        y[1] = (z-y[0])+2*pio2_1t;
86
114
        return -2;
87
114
    }
88
364
      }
89
1.35k
  }
90
32.1k
  if (ix <= 0x401c463b) {   /* |x| ~<= 9pi/4 */
91
1.18k
      if (ix <= 0x4015fdbc) { /* |x| ~<= 7pi/4 */
92
597
    if (ix == 0x4012d97c)  /* |x| ~= 3pi/2 */
93
0
        goto medium;
94
597
    if (hx > 0) {
95
492
        z = x - 3*pio2_1;
96
492
        y[0] = z - 3*pio2_1t;
97
492
        y[1] = (z-y[0])-3*pio2_1t;
98
492
        return 3;
99
492
    } else {
100
105
        z = x + 3*pio2_1;
101
105
        y[0] = z + 3*pio2_1t;
102
105
        y[1] = (z-y[0])+3*pio2_1t;
103
105
        return -3;
104
105
    }
105
597
      } else {
106
591
    if (ix == 0x401921fb)  /* |x| ~= 4pi/2 */
107
0
        goto medium;
108
591
    if (hx > 0) {
109
492
        z = x - 4*pio2_1;
110
492
        y[0] = z - 4*pio2_1t;
111
492
        y[1] = (z-y[0])-4*pio2_1t;
112
492
        return 4;
113
492
    } else {
114
99
        z = x + 4*pio2_1;
115
99
        y[0] = z + 4*pio2_1t;
116
99
        y[1] = (z-y[0])+4*pio2_1t;
117
99
        return -4;
118
99
    }
119
591
      }
120
1.18k
  }
121
30.9k
  if(ix<0x413921fb) { /* |x| ~< 2^20*(pi/2), medium size */
122
22.6k
medium:
123
22.6k
      fn = rnint((double_t)x*invpio2);
124
22.6k
      n  = irint(fn);
125
22.6k
      r  = x-fn*pio2_1;
126
22.6k
      w  = fn*pio2_1t;  /* 1st round good to 85 bit */
127
22.6k
      {
128
22.6k
          u_int32_t high;
129
22.6k
          j  = ix>>20;
130
22.6k
          y[0] = r-w; 
131
22.6k
    GET_HIGH_WORD(high,y[0]);
132
22.6k
          i = j-((high>>20)&0x7ff);
133
22.6k
          if(i>16) {  /* 2nd iteration needed, good to 118 */
134
2.04k
        t  = r;
135
2.04k
        w  = fn*pio2_2; 
136
2.04k
        r  = t-w;
137
2.04k
        w  = fn*pio2_2t-((t-r)-w);  
138
2.04k
        y[0] = r-w;
139
2.04k
        GET_HIGH_WORD(high,y[0]);
140
2.04k
        i = j-((high>>20)&0x7ff);
141
2.04k
        if(i>49)  { /* 3rd iteration need, 151 bits acc */
142
0
          t  = r; /* will cover all possible cases */
143
0
          w  = fn*pio2_3; 
144
0
          r  = t-w;
145
0
          w  = fn*pio2_3t-((t-r)-w);  
146
0
          y[0] = r-w;
147
0
        }
148
2.04k
    }
149
22.6k
      }
150
22.6k
      y[1] = (r-y[0])-w;
151
22.6k
      return n;
152
22.6k
  }
153
    /* 
154
     * all other (large) arguments
155
     */
156
8.30k
  if(ix>=0x7ff00000) {   /* x is inf or NaN */
157
0
      y[0]=y[1]=x-x; return 0;
158
0
  }
159
    /* set z = scalbn(|x|,ilogb(x)-23) */
160
8.30k
  GET_LOW_WORD(low,x);
161
8.30k
  e0  = (ix>>20)-1046;  /* e0 = ilogb(z)-23; */
162
8.30k
  INSERT_WORDS(z, ix - ((int32_t)((u_int32_t)e0<<20)), low);
163
24.9k
  for(i=0;i<2;i++) {
164
16.6k
    tx[i] = (double)((int32_t)(z));
165
16.6k
    z     = (z-tx[i])*two24;
166
16.6k
  }
167
8.30k
  tx[2] = z;
168
8.30k
  nx = 3;
169
12.5k
  while(tx[nx-1]==zero) nx--; /* skip zero term */
170
8.30k
  n  =  __kernel_rem_pio2(tx,ty,e0,nx,1);
171
8.30k
  if(hx<0) {y[0] = -ty[0]; y[1] = -ty[1]; return -n;}
172
1.71k
  y[0] = ty[0]; y[1] = ty[1]; return n;
173
8.30k
}