The functions listed here perform operations such as rounding and truncation of floating-point values. Some of these functions convert floating point numbers to integer values. They are all declared in math.h.
You can also convert floating-point numbers to integers simply by
casting them to int. This discards the fractional part,
effectively rounding towards zero. However, this only works if the
result can actually be represented as an int—for very large
numbers, this is impossible. The functions listed here return the
result as a double instead to get around this problem.
The fromfp functions use the following macros, from TS
18661-1:2014, to specify the direction of rounding. These correspond
to the rounding directions defined in IEEE 754-2008.
FP_INT_UPWARDFP_INT_DOWNWARDFP_INT_TOWARDZEROFP_INT_TONEARESTFROMZEROFP_INT_TONEARESTPreliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions round x upwards to the nearest integer, returning that value as a
double. Thus,ceil (1.5)is2.0.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions round x downwards to the nearest integer, returning that value as a
double. Thus,floor (1.5)is1.0andfloor (-1.5)is-2.0.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
The
truncfunctions round x towards zero to the nearest integer (returned in floating-point format). Thus,trunc (1.5)is1.0andtrunc (-1.5)is-1.0.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions round x to an integer value according to the current rounding mode. See Floating Point Parameters, for information about the various rounding modes. The default rounding mode is to round to the nearest integer; some machines support other modes, but round-to-nearest is always used unless you explicitly select another.
If x was not initially an integer, these functions raise the inexact exception.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions return the same value as the
rintfunctions, but do not raise the inexact exception if x is not an integer.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions are similar to
rint, but they round halfway cases away from zero instead of to the nearest integer (or other current rounding mode).
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions, from TS 18661-1:2014 and TS 18661-3:2015, are similar to
round, but they round halfway cases to even instead of away from zero.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions are just like
rint, but they return along intinstead of a floating-point number.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions are just like
rint, but they return along long intinstead of a floating-point number.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions are just like
round, but they return along intinstead of a floating-point number.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions are just like
round, but they return along long intinstead of a floating-point number.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions, from TS 18661-1:2014 and TS 18661-3:2015, convert a floating-point number to an integer according to the rounding direction round (one of the
FP_INT_*macros). If the integer is outside the range of a signed or unsigned (depending on the return type of the function) type of width width bits (or outside the range of the return type, if width is larger), or if x is infinite or NaN, or if width is zero, a domain error occurs and an unspecified value is returned. The functions with an ‘x’ in their names raise the inexact exception when a domain error does not occur and the argument is not an integer; the other functions do not raise the inexact exception.
Preliminary: | MT-Safe | AS-Safe | AC-Safe | See POSIX Safety Concepts.
These functions break the argument value into an integer part and a fractional part (between
-1and1, exclusive). Their sum equals value. Each of the parts has the same sign as value, and the integer part is always rounded toward zero.
modfstores the integer part in*integer-part, and returns the fractional part. For example,modf (2.5, &intpart)returns0.5and stores2.0intointpart.