std:: modf, std:: modff, std:: modfl
|
Определено в заголовочном файле
<cmath>
|
||
| (1) | ||
|
float
modf
(
float
num,
float
*
iptr
)
;
double
modf
(
double
num,
double
*
iptr
)
;
|
(до C++23) | |
|
constexpr
/* floating-point-type */
modf
(
/* floating-point-type */
num,
|
(начиная с C++23) | |
|
float
modff
(
float
num,
float
*
iptr
)
;
|
(2) |
(начиная с C++11)
(constexpr начиная с C++23) |
|
long
double
modfl
(
long
double
num,
long
double
*
iptr
)
;
|
(3) |
(начиная с C++11)
(constexpr начиная с C++23) |
|
Дополнительные перегрузки
(начиная с C++11)
|
||
|
Определено в заголовочном файле
<cmath>
|
||
|
template
<
class
Integer
>
double modf ( Integer num, double * iptr ) ; |
(A) | (constexpr начиная с C++23) |
std::modf
для всех cv-неквалифицированных типов с плавающей точкой в качестве типа параметра
num
и указываемого типа
iptr
.
(since C++23)
|
A)
Для всех целочисленных типов предоставлены дополнительные перегрузки, которые обрабатываются как
double
.
|
(since C++11) |
Содержание |
Параметры
| num | - | значение с плавающей точкой или целое число |
| iptr | - | указатель на значение с плавающей точкой для сохранения целой части |
Возвращаемое значение
Если ошибок не возникает, возвращает дробную часть num с тем же знаком, что и num . Целая часть помещается в значение, на которое указывает iptr .
Сумма возвращаемого значения и значения, хранящегося в * iptr дает num (с учетом округления).
Обработка ошибок
Эта функция не подвержена никаким ошибкам, указанным в math_errhandling .
Если реализация поддерживает арифметику с плавающей запятой IEEE (IEC 60559),
- Если num равен ±0, возвращается ±0, и ±0 сохраняется в * iptr .
- Если num равен ±∞, возвращается ±0, и ±∞ сохраняется в * iptr .
- Если num является NaN, возвращается NaN, и NaN сохраняется в * iptr .
- Возвращаемое значение является точным, текущий режим округления игнорируется.
Примечания
Эта функция ведет себя так, как если бы была реализована следующим образом:
double modf(double num, double* iptr) { #pragma STDC FENV_ACCESS ON int save_round = std::fegetround(); std::fesetround(FE_TOWARDZERO); *iptr = std::nearbyint(num); std::fesetround(save_round); return std::copysign(std::isinf(num) ? 0.0 : num - (*iptr), num); }
Дополнительные перегрузки не обязаны быть предоставлены в точности как (A) . Они лишь должны быть достаточными для обеспечения того, чтобы для их аргумента num целочисленного типа std :: modf ( num, iptr ) имел тот же эффект, что и std :: modf ( static_cast < double > ( num ) , iptr ) .
Пример
Сравнивает различные функции декомпозиции чисел с плавающей запятой:
#include <cmath> #include <iostream> #include <limits> int main() { double f = 123.45; std::cout << "Given the number " << f << " or " << std::hexfloat << f << std::defaultfloat << " in hex,\n"; double f3; double f2 = std::modf(f, &f3); std::cout << "modf() makes " << f3 << " + " << f2 << '\n'; int i; f2 = std::frexp(f, &i); std::cout << "frexp() makes " << f2 << " * 2^" << i << '\n'; i = std::ilogb(f); std::cout << "logb()/ilogb() make " << f / std::scalbn(1.0, i) << " * " << std::numeric_limits<double>::radix << "^" << std::ilogb(f) << '\n'; // special values f2 = std::modf(-0.0, &f3); std::cout << "modf(-0) makes " << f3 << " + " << f2 << '\n'; f2 = std::modf(-INFINITY, &f3); std::cout << "modf(-Inf) makes " << f3 << " + " << f2 << '\n'; }
Возможный вывод:
Given the number 123.45 or 0x1.edccccccccccdp+6 in hex, modf() makes 123 + 0.45 frexp() makes 0.964453 * 2^7 logb()/ilogb() make 1.92891 * 2^6 modf(-0) makes -0 + -0 modf(-Inf) makes -INF + -0
Смотрите также
|
(C++11)
(C++11)
(C++11)
|
ближайшее целое число, не превышающее по модулю заданное значение
(функция) |
|
Документация C
для
modf
|
|