#ifndef _FLOAT_H_
#define _FLOAT_H_
#undef FLT_RADIX
#define FLT_RADIX 2
#undef FLT_MANT_DIG
#define FLT_MANT_DIG 24
#undef FLT_DIG
#define FLT_DIG 6
#undef FLT_ROUNDS
#define FLT_ROUNDS 1
#undef FLT_EPSILON
#define FLT_EPSILON 1.19209290e-07F
#undef FLT_MIN_EXP
#define FLT_MIN_EXP (-125)
#undef FLT_MIN
#define FLT_MIN 1.17549435e-38F
#undef FLT_MIN_10_EXP
#define FLT_MIN_10_EXP (-37)
#undef FLT_MAX_EXP
#define FLT_MAX_EXP 128
#undef FLT_MAX
#define FLT_MAX 3.40282347e+38F
#undef FLT_MAX_10_EXP
#define FLT_MAX_10_EXP 38
#undef DBL_MANT_DIG
#define DBL_MANT_DIG 53
#undef DBL_DIG
#define DBL_DIG 15
#undef DBL_EPSILON
#define DBL_EPSILON 2.2204460492503131e-16
#undef DBL_MIN_EXP
#define DBL_MIN_EXP (-1021)
#undef DBL_MIN
#define DBL_MIN 2.2250738585072014e-308
#undef DBL_MIN_10_EXP
#define DBL_MIN_10_EXP (-307)
#undef DBL_MAX_EXP
#define DBL_MAX_EXP 1024
#undef DBL_MAX
#define DBL_MAX 1.7976931348623157e+308
#undef DBL_MAX_10_EXP
#define DBL_MAX_10_EXP 308
#undef LDBL_MANT_DIG
#define LDBL_MANT_DIG 64
#undef LDBL_DIG
#define LDBL_DIG 18
#undef LDBL_EPSILON
#ifndef __LDBL_UNION__
#define __LDBL_UNION__
union __convert_long_double {
unsigned __convert_long_double_i[4];
long double __convert_long_double_d;
};
#endif
#define LDBL_EPSILON (__extension__ ((union __convert_long_double) {__convert_long_double_i: {0x0, 0x80000000, 0x3fc0, 0x0}}).__convert_long_double_d)
#undef LDBL_MIN_EXP
#define LDBL_MIN_EXP (-16381)
#undef LDBL_MIN
#define LDBL_MIN (__extension__ ((union __convert_long_double) {__convert_long_double_i: {0x0, 0x80000000, 0x1, 0x0}}).__convert_long_double_d)
#undef LDBL_MIN_10_EXP
#define LDBL_MIN_10_EXP (-4931)
#undef LDBL_MAX_EXP
#define LDBL_MAX_EXP 16384
#undef LDBL_MAX
#define LDBL_MAX (__extension__ ((union __convert_long_double) {__convert_long_double_i: {0xffffffff, 0xffffffff, 0x107ffe, 0x0}}).__convert_long_double_d)
#undef LDBL_MAX_10_EXP
#define LDBL_MAX_10_EXP 4932
#endif