xref: /haiku/src/system/libroot/posix/musl/math/hypotf.c (revision 68ea01249e1e2088933cb12f9c28d4e5c5d1c9ef)
1 #include <math.h>
2 #include <stdint.h>
3 
4 float hypotf(float x, float y)
5 {
6 	union {float f; uint32_t i;} ux = {x}, uy = {y}, ut;
7 	float_t z;
8 
9 	ux.i &= -1U>>1;
10 	uy.i &= -1U>>1;
11 	if (ux.i < uy.i) {
12 		ut = ux;
13 		ux = uy;
14 		uy = ut;
15 	}
16 
17 	x = ux.f;
18 	y = uy.f;
19 	if (uy.i == 0xff<<23)
20 		return y;
21 	if (ux.i >= 0xff<<23 || uy.i == 0 || ux.i - uy.i >= 25<<23)
22 		return x + y;
23 
24 	z = 1;
25 	if (ux.i >= (0x7f+60)<<23) {
26 		z = 0x1p90f;
27 		x *= 0x1p-90f;
28 		y *= 0x1p-90f;
29 	} else if (uy.i < (0x7f-60)<<23) {
30 		z = 0x1p-90f;
31 		x *= 0x1p90f;
32 		y *= 0x1p90f;
33 	}
34 	return z*sqrtf((double)x*x + (double)y*y);
35 }
36