PostGIS  2.2.7dev-r@@SVN_REVISION@@
static float nextafterf_custom ( float  x,
float  y 
)
static

Definition at line 76 of file lwgeom_api.c.

References GET_FLOAT_WORD, SET_FLOAT_WORD, pixval::x, and pixval::y.

Referenced by next_double_down(), next_double_up(), next_float_down(), and next_float_up().

77 {
78  int hx,hy,ix,iy;
79 
80  GET_FLOAT_WORD(hx,x);
81  GET_FLOAT_WORD(hy,y);
82  ix = hx&0x7fffffff; /* |x| */
83  iy = hy&0x7fffffff; /* |y| */
84 
85  if ((ix>0x7f800000) || /* x is nan */
86  (iy>0x7f800000)) /* y is nan */
87  return x+y;
88  if (x==y) return y; /* x=y, return y */
89  if (ix==0)
90  {
91  /* x == 0 */
92  SET_FLOAT_WORD(x,(hy&0x80000000)|1);/* return +-minsubnormal */
93  y = x*x;
94  if (y==x) return y;
95  else return x; /* raise underflow flag */
96  }
97  if (hx>=0)
98  {
99  /* x > 0 */
100  if (hx>hy)
101  {
102  /* x > y, x -= ulp */
103  hx -= 1;
104  }
105  else
106  {
107  /* x < y, x += ulp */
108  hx += 1;
109  }
110  }
111  else
112  {
113  /* x < 0 */
114  if (hy>=0||hx>hy)
115  {
116  /* x < y, x -= ulp */
117  hx -= 1;
118  }
119  else
120  {
121  /* x > y, x += ulp */
122  hx += 1;
123  }
124  }
125  hy = hx&0x7f800000;
126  if (hy>=0x7f800000) return x+x; /* overflow */
127  if (hy<0x00800000)
128  {
129  /* underflow */
130  y = x*x;
131  if (y!=x)
132  {
133  /* raise underflow flag */
134  SET_FLOAT_WORD(y,hx);
135  return y;
136  }
137  }
138  SET_FLOAT_WORD(x,hx);
139  return x;
140 }
tuple x
Definition: pixval.py:53
#define SET_FLOAT_WORD(d, i)
Definition: lwgeom_api.c:63
tuple y
Definition: pixval.py:54
#define GET_FLOAT_WORD(i, d)
Definition: lwgeom_api.c:55

Here is the caller graph for this function: