1 /* Multiply a 'float' by a power of 2.
2 Copyright 2002-2003, 2007-2024 Free Software Foundation, Inc.
4 This file is free software: you can redistribute it and/or modify
5 it under the terms of the GNU Lesser General Public License as
6 published by the Free Software Foundation; either version 2.1 of the
7 License, or (at your option) any later version.
9 This file is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU Lesser General Public License for more details.
14 You should have received a copy of the GNU Lesser General Public License
15 along with this program. If not, see <https://www.gnu.org/licenses/>. */
17 /* Written by Paolo Bonzini and Bruno Haible. */
24 /* Avoid some warnings from "gcc -Wshadow".
25 This file doesn't use the exp() function. */
29 #if HAVE_SAME_LONG_DOUBLE_AS_DOUBLE
32 ldexpl (long double x
, int exp
)
34 return ldexp (x
, exp
);
39 # define USE_LONG_DOUBLE
50 for (y
= 0; y
< 29; y
++)
51 printf ("%5d %.16Lg %.16Lg\n", y
, ldexpl (0.8L, y
), ldexpl (0.8L, -y
) * ldexpl (0.8L, y
));