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