Damien George
10 years ago
7 changed files with 73 additions and 1 deletions
@ -0,0 +1,33 @@ |
|||
/*****************************************************************************/ |
|||
/*****************************************************************************/ |
|||
// roundf from musl-0.9.15
|
|||
/*****************************************************************************/ |
|||
/*****************************************************************************/ |
|||
|
|||
#include "libm.h" |
|||
|
|||
float roundf(float x) |
|||
{ |
|||
union {float f; uint32_t i;} u = {x}; |
|||
int e = u.i >> 23 & 0xff; |
|||
float_t y; |
|||
|
|||
if (e >= 0x7f+23) |
|||
return x; |
|||
if (u.i >> 31) |
|||
x = -x; |
|||
if (e < 0x7f-1) { |
|||
FORCE_EVAL(x + 0x1p23f); |
|||
return 0*u.f; |
|||
} |
|||
y = (float)(x + 0x1p23f) - 0x1p23f - x; |
|||
if (y > 0.5f) |
|||
y = y + x - 1; |
|||
else if (y <= -0.5f) |
|||
y = y + x + 1; |
|||
else |
|||
y = y + x; |
|||
if (u.i >> 31) |
|||
y = -y; |
|||
return y; |
|||
} |
@ -0,0 +1,14 @@ |
|||
# test round() |
|||
|
|||
# check basic cases |
|||
tests = [ |
|||
False, True, |
|||
0, 1, -1, 10, |
|||
0.0, 1.0, 0.1, -0.1, 123.4, 123.6, -123.4, -123.6 |
|||
] |
|||
for t in tests: |
|||
print(round(t)) |
|||
|
|||
# check .5 cases |
|||
for i in range(11): |
|||
print(round((i - 5) / 2)) |
Loading…
Reference in new issue