📄 vnl_numeric_limits.cxx
字号:
// ----------------------------------------------------------------------
// Constants and functions for double
union vnl_numeric_limits_double_nan {
double nan;
unsigned char x[8];
vnl_numeric_limits_double_nan() {
#if VXL_BIG_ENDIAN
x[0] = 0x7f;
x[1] = x[2] = x[3] = x[4] = x[5] = x[6] = x[7] = 0xff;
#else
x[7] = 0x7f;
x[0] = x[1] = x[2] = x[3] = x[4] = x[5] = x[6] = 0xff;
#endif
}
};
static vnl_numeric_limits_double_nan dnan;
union vnl_numeric_limits_double_inf {
double inf;
unsigned char x[8];
vnl_numeric_limits_double_inf() {
#if 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 vnl_numeric_limits_double_inf dinf;
double vnl_numeric_limits<double>::infinity()
{
return dinf.inf;
}
double vnl_numeric_limits<double>::quiet_NaN()
{
return dnan.nan;
}
double vnl_numeric_limits<double>::signaling_NaN()
{
return quiet_NaN();
}
const bool vnl_numeric_limits<double>::is_specialized VCL_STATIC_CONST_INIT_INT_DEFN(true);
const int vnl_numeric_limits<double>::digits VCL_STATIC_CONST_INIT_INT_DEFN(53);
const int vnl_numeric_limits<double>::digits10 VCL_STATIC_CONST_INIT_INT_DEFN( 15);
const bool vnl_numeric_limits<double>::is_signed VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<double>::is_integer VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vnl_numeric_limits<double>::is_exact VCL_STATIC_CONST_INIT_INT_DEFN(false);
const int vnl_numeric_limits<double>::radix VCL_STATIC_CONST_INIT_INT_DEFN(2);
const int vnl_numeric_limits<double>::min_exponent VCL_STATIC_CONST_INIT_INT_DEFN(-1021);
const int vnl_numeric_limits<double>::min_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(-307);
const int vnl_numeric_limits<double>::max_exponent VCL_STATIC_CONST_INIT_INT_DEFN(1024);
const int vnl_numeric_limits<double>::max_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(308);
const bool vnl_numeric_limits<double>::has_infinity VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<double>::has_quiet_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<double>::has_signaling_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<double>::has_denorm VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<double>::is_iec559 VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<double>::is_bounded VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<double>::is_modulo VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vnl_numeric_limits<double>::traps VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<double>::tinyness_before VCL_STATIC_CONST_INIT_INT_DEFN(true);
const vnl_float_round_style vnl_numeric_limits<double>::round_style VCL_STATIC_CONST_INIT_INT_DEFN(vnl_round_to_nearest);
// ----------------------------------------------------------------------
// Constants and functions for float
union vnl_numeric_limits_float_nan {
float nan;
unsigned char x[4];
vnl_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 vnl_numeric_limits_float_nan fnan;
union vnl_numeric_limits_float_inf {
float inf;
unsigned char x[4];
vnl_numeric_limits_float_inf() {
#if VXL_BIG_ENDIAN
x[0] = 0x7f; x[1] = 0x80; x[2] = x[3] = 0x00;
#else
x[3] = 0x7f; x[2] = 0x80; x[0] = x[1] = 0x00;
#endif
}
};
static vnl_numeric_limits_float_inf finf;
float vnl_numeric_limits<float>::infinity()
{
return finf.inf;
}
float vnl_numeric_limits<float>::quiet_NaN()
{
return fnan.nan;
}
float vnl_numeric_limits<float>::signaling_NaN()
{
return quiet_NaN();
}
const bool vnl_numeric_limits<float>::is_specialized VCL_STATIC_CONST_INIT_INT_DEFN(true);
const int vnl_numeric_limits<float>::digits VCL_STATIC_CONST_INIT_INT_DEFN(24);
const int vnl_numeric_limits<float>::digits10 VCL_STATIC_CONST_INIT_INT_DEFN( 6);
const bool vnl_numeric_limits<float>::is_signed VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<float>::is_integer VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vnl_numeric_limits<float>::is_exact VCL_STATIC_CONST_INIT_INT_DEFN(false);
const int vnl_numeric_limits<float>::radix VCL_STATIC_CONST_INIT_INT_DEFN(2);
const int vnl_numeric_limits<float>::min_exponent VCL_STATIC_CONST_INIT_INT_DEFN(-125);
const int vnl_numeric_limits<float>::min_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(-37);
const int vnl_numeric_limits<float>::max_exponent VCL_STATIC_CONST_INIT_INT_DEFN(128);
const int vnl_numeric_limits<float>::max_exponent10 VCL_STATIC_CONST_INIT_INT_DEFN(38);
const bool vnl_numeric_limits<float>::has_infinity VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<float>::has_quiet_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<float>::has_signaling_NaN VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<float>::has_denorm VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vnl_numeric_limits<float>::is_iec559 VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<float>::is_bounded VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<float>::is_modulo VCL_STATIC_CONST_INIT_INT_DEFN(false);
const bool vnl_numeric_limits<float>::traps VCL_STATIC_CONST_INIT_INT_DEFN(true);
const bool vnl_numeric_limits<float>::tinyness_before VCL_STATIC_CONST_INIT_INT_DEFN(true);
const vnl_float_round_style vnl_numeric_limits<float>::round_style VCL_STATIC_CONST_INIT_INT_DEFN(vnl_round_to_nearest);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -