📄 vcl_limits.cxx
字号:
#endif
}
};
static vcl_numeric_limits_double_nan dnan;
union vcl_numeric_limits_double_inf {
double inf;
unsigned char x[8];
vcl_numeric_limits_double_inf() {
#ifdef __alpha__ // Alpha throws a floating exception when evaluating IEEE Inf
x[7] = 0x7f; x[6] = 0xef;
x[0] = x[1] = x[2] = x[3] = x[4] = x[5] = 0xff;
#elif VXL_BIG_ENDIAN
x[0] = 0x7f; x[1] = 0xf0;
x[2] = x[3] = x[4] = x[5] = x[6] = x[7] = 0x00;
#else
x[7] = 0x7f; x[6] = 0xf0;
x[0] = x[1] = x[2] = x[3] = x[4] = x[5] = 0x00;
#endif
}
};
static vcl_numeric_limits_double_inf dinf;
double vcl_numeric_limits<double>::infinity()
{
return dinf.inf;
}
double vcl_numeric_limits<double>::quiet_NaN()
{
return dnan.nan;
}
double vcl_numeric_limits<double>::signaling_NaN()
{
return quiet_NaN();
}
#if !VCL_STATIC_CONST_INIT_INT_NO_DEFN
const bool vcl_numeric_limits<double>::is_specialized VCL_STATIC_CONST_INIT_INT_DEFN(true);
const int vcl_numeric_limits<double>::digits VCL_STATIC_CONST_INIT_INT_DEFN(53);
const int vcl_numeric_limits<double>::digits10 VCL_STATIC_CONST_INIT_INT_DEFN( 15);
const bool vcl_numeric_limits<double>::is_signed VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<double>::is_integer VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vcl_numeric_limits<double>::is_exact VCL_STATIC_CONST_INIT_INT_DEFN(false);
const int vcl_numeric_limits<double>::radix VCL_STATIC_CONST_INIT_INT_DEFN(2);
const int vcl_numeric_limits<double>::min_exponent VCL_STATIC_CONST_INIT_INT_DEFN(-1021);
const int vcl_numeric_limits<double>::min_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(-307);
const int vcl_numeric_limits<double>::max_exponent VCL_STATIC_CONST_INIT_INT_DEFN(1024);
const int vcl_numeric_limits<double>::max_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(308);
const bool vcl_numeric_limits<double>::has_infinity VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<double>::has_quiet_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<double>::has_signaling_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<double>::has_denorm VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<double>::is_iec559 VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<double>::is_bounded VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<double>::is_modulo VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vcl_numeric_limits<double>::traps VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<double>::tinyness_before VCL_STATIC_CONST_INIT_INT_DEFN(true);
const vcl_float_round_style vcl_numeric_limits<double>::round_style VCL_STATIC_CONST_INIT_INT_DEFN(vcl_round_to_nearest);
#endif
// ----------------------------------------------------------------------
// Constants and functions for long double
static const unsigned int szl = sizeof(long double);
union vcl_numeric_limits_long_double_nan {
long double nan;
unsigned char x[szl];
vcl_numeric_limits_long_double_nan() {
for (unsigned int i=0; i<szl; ++i) x[i] = 0xff;
#if VXL_BIG_ENDIAN
x[0] = 0x7f;
#else
x[szl-1] = 0x7f;
#endif
}
};
static vcl_numeric_limits_long_double_nan ldnan;
union vcl_numeric_limits_long_double_inf {
long double inf;
unsigned char x[szl];
vcl_numeric_limits_long_double_inf() {
for (unsigned int i=0; i<szl; ++i) x[i] = 0x00;
#ifdef __alpha__ // Alpha throws a floating exception when evaluating IEEE Inf
x[szl-1] = 0x7f; x[szl-2] = 0xef;
for (unsigned int i=0; i<szl-2; ++i) x[i] = 0xff;
#elif VXL_BIG_ENDIAN
x[0] = 0x7f; x[1] = 0xf0;
#else
x[szl-1] = 0x7f; x[szl-2] = 0xf0;
if (szl == 12) // intel
x[9]=x[11]=0x7f, x[8]=x[10]=0xff, x[7] = 0x80;
#endif
}
};
static vcl_numeric_limits_long_double_inf ldinf;
long double vcl_numeric_limits<long double>::infinity()
{
return ldinf.inf;
}
long double vcl_numeric_limits<long double>::quiet_NaN()
{
return ldnan.nan;
}
long double vcl_numeric_limits<long double>::signaling_NaN()
{
return quiet_NaN();
}
#if !VCL_STATIC_CONST_INIT_INT_NO_DEFN
const bool vcl_numeric_limits<long double>::is_specialized VCL_STATIC_CONST_INIT_INT_DEFN(true);
const int vcl_numeric_limits<long double>::digits VCL_STATIC_CONST_INIT_INT_DEFN((int)(85-10*szl+.75*szl*szl));
const int vcl_numeric_limits<long double>::digits10 VCL_STATIC_CONST_INIT_INT_DEFN((int)(9-3.5*szl+.25*szl*szl-5));
// this is 15, 21, and 35 for sizes 8, 12, and 16.
const bool vcl_numeric_limits<long double>::is_signed VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<long double>::is_integer VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vcl_numeric_limits<long double>::is_exact VCL_STATIC_CONST_INIT_INT_DEFN(false);
const int vcl_numeric_limits<long double>::radix VCL_STATIC_CONST_INIT_INT_DEFN(2);
const int vcl_numeric_limits<long double>::min_exponent VCL_STATIC_CONST_INIT_INT_DEFN(-1021);
const int vcl_numeric_limits<long double>::min_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(-307);
const int vcl_numeric_limits<long double>::max_exponent VCL_STATIC_CONST_INIT_INT_DEFN(1024);
const int vcl_numeric_limits<long double>::max_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(308);
const bool vcl_numeric_limits<long double>::has_infinity VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<long double>::has_quiet_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<long double>::has_signaling_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<long double>::has_denorm VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<long double>::is_iec559 VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<long double>::is_bounded VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<long double>::is_modulo VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vcl_numeric_limits<long double>::traps VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<long double>::tinyness_before VCL_STATIC_CONST_INIT_INT_DEFN(true);
const vcl_float_round_style vcl_numeric_limits<long double>::round_style VCL_STATIC_CONST_INIT_INT_DEFN(vcl_round_to_nearest);
#endif
// ----------------------------------------------------------------------
// Constants and functions for float
union vcl_numeric_limits_float_nan {
float nan;
unsigned char x[4];
vcl_numeric_limits_float_nan() {
#if VXL_BIG_ENDIAN
x[0] = 0x7f; x[1] = x[2] = x[3] = 0xff;
#else
x[3] = 0x7f; x[0] = x[1] = x[2] = 0xff;
#endif
}
};
static vcl_numeric_limits_float_nan fnan;
union vcl_numeric_limits_float_inf {
float inf;
unsigned char x[4];
vcl_numeric_limits_float_inf() {
#ifdef __alpha__ // Alpha throws a floating exception when evaluating IEEE Inf
x[3] = 0x7f; x[2] = 0x7f; x[1] = x[0] = 0xff;
#elif VXL_BIG_ENDIAN
x[0] = 0x7f; x[1] = 0x80; x[2] = x[3] = 0x00;
#else
x[3] = 0x7f; x[2] = 0x80; x[1] = x[0] = 0x00;
#endif
}
};
static vcl_numeric_limits_float_inf finf;
float vcl_numeric_limits<float>::infinity()
{
return finf.inf;
}
float vcl_numeric_limits<float>::quiet_NaN()
{
return fnan.nan;
}
float vcl_numeric_limits<float>::signaling_NaN()
{
return quiet_NaN();
}
#if !VCL_STATIC_CONST_INIT_INT_NO_DEFN
const bool vcl_numeric_limits<float>::is_specialized VCL_STATIC_CONST_INIT_INT_DEFN(true);
const int vcl_numeric_limits<float>::digits VCL_STATIC_CONST_INIT_INT_DEFN(24);
const int vcl_numeric_limits<float>::digits10 VCL_STATIC_CONST_INIT_INT_DEFN( 6);
const bool vcl_numeric_limits<float>::is_signed VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<float>::is_integer VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vcl_numeric_limits<float>::is_exact VCL_STATIC_CONST_INIT_INT_DEFN(false);
const int vcl_numeric_limits<float>::radix VCL_STATIC_CONST_INIT_INT_DEFN(2);
const int vcl_numeric_limits<float>::min_exponent VCL_STATIC_CONST_INIT_INT_DEFN(-125);
const int vcl_numeric_limits<float>::min_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(-37);
const int vcl_numeric_limits<float>::max_exponent VCL_STATIC_CONST_INIT_INT_DEFN(128);
const int vcl_numeric_limits<float>::max_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(38);
const bool vcl_numeric_limits<float>::has_infinity VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<float>::has_quiet_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<float>::has_signaling_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<float>::has_denorm VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vcl_numeric_limits<float>::is_iec559 VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<float>::is_bounded VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<float>::is_modulo VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vcl_numeric_limits<float>::traps VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vcl_numeric_limits<float>::tinyness_before VCL_STATIC_CONST_INIT_INT_DEFN(true);
const vcl_float_round_style vcl_numeric_limits<float>::round_style VCL_STATIC_CONST_INIT_INT_DEFN(vcl_round_to_nearest);
#endif
#endif // !VCL_CXX_HAS_HEADER_LIMITS || !VCL_USE_NATIVE_STL || (!VCL_NUMERIC_LIMITS_HAS_INFINITY && VCL_PROCESSOR_HAS_INFINITY)
// A dummy symbol to avoid missing symbol warnings from ranlib
int vcl_limits_dummy_to_avoid_ranlib_warning = 0;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -