Программирование. Принципы и практика использования C++ Исправленное издание, стр. 431
class numeric_limits<float> {public: static const bool is_specialized = true; static const int radix = 2; // основание системы счисления // (в данном случае двоичная) static const int digits = 24; // количество цифр в мантиссе // в текущей системе счисления static const int digits10 = 6; // количество десятичных цифр // в мантиссе static const bool is_signed = true; static const bool is_integer = false; static const bool is_exact = false; static float min() { return 1.17549435E–38F; } // пример static float max() { return 3.40282347E+38F; } // пример static float epsilon() { return 1.19209290E–07F; } // пример static float round_error() { return 0.5F; } // пример static float infinity() { return /* какое-то значение */; } static float quiet_NaN() { return /* какое-то значение */; } static float signaling_NaN() { return /* какое-то значение */; } static float denorm_min() { return min(); } static const int min_exponent = –125; // пример static const int min_exponent10 = –37; // пример static const int max_exponent = +128; // пример static const int max_exponent10 = +38; // пример static const bool has_infinity = true; static const bool has_quiet_NaN = true; static const bool has_signaling_NaN = true; static const float_denorm_style has_denorm = denorm_absent; static const bool has_denorm_loss = false; static const bool is_iec559 = true; // соответствует системе IEC-559 static const bool is_bounded = true; static const bool is_modulo = false; static const bool traps = true; static const bool tinyness_before = true; static const float_round_style round_style = round_to_nearest;};В заголовках
<limits.h><float.h>
Б.9.2. Стандартные математические функции
В стандартной библиотеке определены основные математические функции (в заголовках
<cmath><complex>
Существуют версии этих функций, принимающие аргументы типа
floatdoublelong doublecomplexЕсли стандартная математическая функция не может выдать корректный с математической точки зрения результат, она устанавливает переменную
errnoБ.9.3. Комплексные числа
В стандартной библиотеке определены типы для комплексных чисел
complex<float>complex<double>complex<long double><Scalar>Scalartemplate<class Scalar> class complex { // комплексное число — это пара скалярных значений, // по существу — пара координат Scalar re, im;public: complex(const Scalar & r, const Scalar & i):re(r), im(i) { } complex(const Scalar & r):re(r),im(Scalar ()) { } complex():re(Scalar ()), im(Scalar ()) { } Scalar real() { return re; } // действительная часть Scalar imag() { return im; } // мнимая часть // операторы : = += –= *= /=};Кроме этих членов, в классе
<complex>
Кроме того, к комплексным числам можно применять стандартные математические функции (см. раздел Б.9.2). Примечание: в классе
complex<%Б.9.4. Класс valarray
Объект стандартного класса
valarrayMatrix