2021-04-27 18:33:31 +02:00
|
|
|
/* Copyright (C) 1996 DJ Delorie, see COPYING.DJ for details */
|
|
|
|
/* Copyright (C) 1995 DJ Delorie, see COPYING.DJ for details */
|
|
|
|
#include <math.h>
|
|
|
|
|
2022-04-15 11:00:55 +02:00
|
|
|
double ldexp(double v, int e)
|
2021-04-27 18:33:31 +02:00
|
|
|
{
|
2022-04-15 11:00:55 +02:00
|
|
|
double two = 2.0;
|
2021-04-27 18:33:31 +02:00
|
|
|
|
2022-04-15 11:00:55 +02:00
|
|
|
if (e < 0) {
|
|
|
|
e = -e; /* This just might overflow on two-complement machines. */
|
|
|
|
if (e < 0)
|
|
|
|
return 0.0;
|
|
|
|
while (e > 0) {
|
|
|
|
if (e & 1)
|
|
|
|
v /= two;
|
|
|
|
two *= two;
|
|
|
|
e >>= 1;
|
|
|
|
}
|
|
|
|
} else if (e > 0) {
|
|
|
|
while (e > 0) {
|
|
|
|
if (e & 1)
|
|
|
|
v *= two;
|
|
|
|
two *= two;
|
|
|
|
e >>= 1;
|
|
|
|
}
|
2021-04-27 18:33:31 +02:00
|
|
|
}
|
2022-04-15 11:00:55 +02:00
|
|
|
return v;
|
2021-04-27 18:33:31 +02:00
|
|
|
}
|