#include <float.h>
#include "math.h"
#include "math_private.h"
static const double zero = 0.0;
double
remainder(double x, double p)
{
int32_t hx,hp;
u_int32_t sx,lx,lp;
double p_half;
EXTRACT_WORDS(hx,lx,x);
EXTRACT_WORDS(hp,lp,p);
sx = hx&0x80000000;
hp &= 0x7fffffff;
hx &= 0x7fffffff;
if(((hp|lp)==0)||
(hx>=0x7ff00000)||
((hp>=0x7ff00000)&&
(((hp-0x7ff00000)|lp)!=0)))
return nan_mix_op(x, p, *)/nan_mix_op(x, p, *);
if (hp<=0x7fdfffff) x = fmod(x,p+p);
if (((hx-hp)|(lx-lp))==0) return zero*x;
x = fabs(x);
p = fabs(p);
if (hp<0x00200000) {
if(x+x>p) {
x-=p;
if(x+x>=p) x -= p;
}
} else {
p_half = 0.5*p;
if(x>p_half) {
x-=p;
if(x>=p_half) x -= p;
}
}
EXTRACT_WORDS(hx, lx, x);
if (((hx&0x7fffffff)|lx) == 0) hx = 0;
SET_HIGH_WORD(x,hx^sx);
return x;
}
#if LDBL_MANT_DIG == 53
__weak_reference(remainder, remainderl);
#endif