Blame gnulib/lib/float+.h

Packit eba2e2
/* Supplemental information about the floating-point formats.
Packit eba2e2
   Copyright (C) 2007, 2009-2014 Free Software Foundation, Inc.
Packit eba2e2
   Written by Bruno Haible <bruno@clisp.org>, 2007.
Packit eba2e2
Packit eba2e2
   This program is free software; you can redistribute it and/or modify
Packit eba2e2
   it under the terms of the GNU General Public License as published by
Packit eba2e2
   the Free Software Foundation; either version 3, or (at your option)
Packit eba2e2
   any later version.
Packit eba2e2
Packit eba2e2
   This program is distributed in the hope that it will be useful,
Packit eba2e2
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit eba2e2
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit eba2e2
   GNU General Public License for more details.
Packit eba2e2
Packit eba2e2
   You should have received a copy of the GNU General Public License
Packit eba2e2
   along with this program; if not, see <http://www.gnu.org/licenses/>.  */
Packit eba2e2
Packit eba2e2
#ifndef _FLOATPLUS_H
Packit eba2e2
#define _FLOATPLUS_H
Packit eba2e2
Packit eba2e2
#include <float.h>
Packit eba2e2
#include <limits.h>
Packit eba2e2
Packit eba2e2
/* Number of bits in the mantissa of a floating-point number, including the
Packit eba2e2
   "hidden bit".  */
Packit eba2e2
#if FLT_RADIX == 2
Packit eba2e2
# define FLT_MANT_BIT FLT_MANT_DIG
Packit eba2e2
# define DBL_MANT_BIT DBL_MANT_DIG
Packit eba2e2
# define LDBL_MANT_BIT LDBL_MANT_DIG
Packit eba2e2
#elif FLT_RADIX == 4
Packit eba2e2
# define FLT_MANT_BIT (FLT_MANT_DIG * 2)
Packit eba2e2
# define DBL_MANT_BIT (DBL_MANT_DIG * 2)
Packit eba2e2
# define LDBL_MANT_BIT (LDBL_MANT_DIG * 2)
Packit eba2e2
#elif FLT_RADIX == 16
Packit eba2e2
# define FLT_MANT_BIT (FLT_MANT_DIG * 4)
Packit eba2e2
# define DBL_MANT_BIT (DBL_MANT_DIG * 4)
Packit eba2e2
# define LDBL_MANT_BIT (LDBL_MANT_DIG * 4)
Packit eba2e2
#endif
Packit eba2e2
Packit eba2e2
/* Bit mask that can be used to mask the exponent, as an unsigned number.  */
Packit eba2e2
#define FLT_EXP_MASK ((FLT_MAX_EXP - FLT_MIN_EXP) | 7)
Packit eba2e2
#define DBL_EXP_MASK ((DBL_MAX_EXP - DBL_MIN_EXP) | 7)
Packit eba2e2
#define LDBL_EXP_MASK ((LDBL_MAX_EXP - LDBL_MIN_EXP) | 7)
Packit eba2e2
Packit eba2e2
/* Number of bits used for the exponent of a floating-point number, including
Packit eba2e2
   the exponent's sign.  */
Packit eba2e2
#define FLT_EXP_BIT \
Packit eba2e2
  (FLT_EXP_MASK < 0x100 ? 8 : \
Packit eba2e2
   FLT_EXP_MASK < 0x200 ? 9 : \
Packit eba2e2
   FLT_EXP_MASK < 0x400 ? 10 : \
Packit eba2e2
   FLT_EXP_MASK < 0x800 ? 11 : \
Packit eba2e2
   FLT_EXP_MASK < 0x1000 ? 12 : \
Packit eba2e2
   FLT_EXP_MASK < 0x2000 ? 13 : \
Packit eba2e2
   FLT_EXP_MASK < 0x4000 ? 14 : \
Packit eba2e2
   FLT_EXP_MASK < 0x8000 ? 15 : \
Packit eba2e2
   FLT_EXP_MASK < 0x10000 ? 16 : \
Packit eba2e2
   FLT_EXP_MASK < 0x20000 ? 17 : \
Packit eba2e2
   FLT_EXP_MASK < 0x40000 ? 18 : \
Packit eba2e2
   FLT_EXP_MASK < 0x80000 ? 19 : \
Packit eba2e2
   FLT_EXP_MASK < 0x100000 ? 20 : \
Packit eba2e2
   FLT_EXP_MASK < 0x200000 ? 21 : \
Packit eba2e2
   FLT_EXP_MASK < 0x400000 ? 22 : \
Packit eba2e2
   FLT_EXP_MASK < 0x800000 ? 23 : \
Packit eba2e2
   FLT_EXP_MASK < 0x1000000 ? 24 : \
Packit eba2e2
   FLT_EXP_MASK < 0x2000000 ? 25 : \
Packit eba2e2
   FLT_EXP_MASK < 0x4000000 ? 26 : \
Packit eba2e2
   FLT_EXP_MASK < 0x8000000 ? 27 : \
Packit eba2e2
   FLT_EXP_MASK < 0x10000000 ? 28 : \
Packit eba2e2
   FLT_EXP_MASK < 0x20000000 ? 29 : \
Packit eba2e2
   FLT_EXP_MASK < 0x40000000 ? 30 : \
Packit eba2e2
   FLT_EXP_MASK <= 0x7fffffff ? 31 : \
Packit eba2e2
   32)
Packit eba2e2
#define DBL_EXP_BIT \
Packit eba2e2
  (DBL_EXP_MASK < 0x100 ? 8 : \
Packit eba2e2
   DBL_EXP_MASK < 0x200 ? 9 : \
Packit eba2e2
   DBL_EXP_MASK < 0x400 ? 10 : \
Packit eba2e2
   DBL_EXP_MASK < 0x800 ? 11 : \
Packit eba2e2
   DBL_EXP_MASK < 0x1000 ? 12 : \
Packit eba2e2
   DBL_EXP_MASK < 0x2000 ? 13 : \
Packit eba2e2
   DBL_EXP_MASK < 0x4000 ? 14 : \
Packit eba2e2
   DBL_EXP_MASK < 0x8000 ? 15 : \
Packit eba2e2
   DBL_EXP_MASK < 0x10000 ? 16 : \
Packit eba2e2
   DBL_EXP_MASK < 0x20000 ? 17 : \
Packit eba2e2
   DBL_EXP_MASK < 0x40000 ? 18 : \
Packit eba2e2
   DBL_EXP_MASK < 0x80000 ? 19 : \
Packit eba2e2
   DBL_EXP_MASK < 0x100000 ? 20 : \
Packit eba2e2
   DBL_EXP_MASK < 0x200000 ? 21 : \
Packit eba2e2
   DBL_EXP_MASK < 0x400000 ? 22 : \
Packit eba2e2
   DBL_EXP_MASK < 0x800000 ? 23 : \
Packit eba2e2
   DBL_EXP_MASK < 0x1000000 ? 24 : \
Packit eba2e2
   DBL_EXP_MASK < 0x2000000 ? 25 : \
Packit eba2e2
   DBL_EXP_MASK < 0x4000000 ? 26 : \
Packit eba2e2
   DBL_EXP_MASK < 0x8000000 ? 27 : \
Packit eba2e2
   DBL_EXP_MASK < 0x10000000 ? 28 : \
Packit eba2e2
   DBL_EXP_MASK < 0x20000000 ? 29 : \
Packit eba2e2
   DBL_EXP_MASK < 0x40000000 ? 30 : \
Packit eba2e2
   DBL_EXP_MASK <= 0x7fffffff ? 31 : \
Packit eba2e2
   32)
Packit eba2e2
#define LDBL_EXP_BIT \
Packit eba2e2
  (LDBL_EXP_MASK < 0x100 ? 8 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x200 ? 9 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x400 ? 10 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x800 ? 11 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x1000 ? 12 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x2000 ? 13 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x4000 ? 14 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x8000 ? 15 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x10000 ? 16 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x20000 ? 17 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x40000 ? 18 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x80000 ? 19 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x100000 ? 20 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x200000 ? 21 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x400000 ? 22 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x800000 ? 23 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x1000000 ? 24 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x2000000 ? 25 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x4000000 ? 26 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x8000000 ? 27 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x10000000 ? 28 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x20000000 ? 29 : \
Packit eba2e2
   LDBL_EXP_MASK < 0x40000000 ? 30 : \
Packit eba2e2
   LDBL_EXP_MASK <= 0x7fffffff ? 31 : \
Packit eba2e2
   32)
Packit eba2e2
Packit eba2e2
/* Number of bits used for a floating-point number: the mantissa (not
Packit eba2e2
   counting the "hidden bit", since it may or may not be explicit), the
Packit eba2e2
   exponent, and the sign.  */
Packit eba2e2
#define FLT_TOTAL_BIT ((FLT_MANT_BIT - 1) + FLT_EXP_BIT + 1)
Packit eba2e2
#define DBL_TOTAL_BIT ((DBL_MANT_BIT - 1) + DBL_EXP_BIT + 1)
Packit eba2e2
#define LDBL_TOTAL_BIT ((LDBL_MANT_BIT - 1) + LDBL_EXP_BIT + 1)
Packit eba2e2
Packit eba2e2
/* Number of bytes used for a floating-point number.
Packit eba2e2
   This can be smaller than the 'sizeof'.  For example, on i386 systems,
Packit eba2e2
   'long double' most often have LDBL_MANT_BIT = 64, LDBL_EXP_BIT = 16, hence
Packit eba2e2
   LDBL_TOTAL_BIT = 80 bits, i.e. 10 bytes of consecutive memory, but
Packit eba2e2
   sizeof (long double) = 12 or = 16.  */
Packit eba2e2
#define SIZEOF_FLT ((FLT_TOTAL_BIT + CHAR_BIT - 1) / CHAR_BIT)
Packit eba2e2
#define SIZEOF_DBL ((DBL_TOTAL_BIT + CHAR_BIT - 1) / CHAR_BIT)
Packit eba2e2
#define SIZEOF_LDBL ((LDBL_TOTAL_BIT + CHAR_BIT - 1) / CHAR_BIT)
Packit eba2e2
Packit eba2e2
/* Verify that SIZEOF_FLT <= sizeof (float) etc.  */
Packit eba2e2
typedef int verify_sizeof_flt[SIZEOF_FLT <= sizeof (float) ? 1 : -1];
Packit eba2e2
typedef int verify_sizeof_dbl[SIZEOF_DBL <= sizeof (double) ? 1 : - 1];
Packit eba2e2
typedef int verify_sizeof_ldbl[SIZEOF_LDBL <= sizeof (long double) ? 1 : - 1];
Packit eba2e2
Packit eba2e2
#endif /* _FLOATPLUS_H */