Next: Remainder Functions, Previous: Normalization Functions, Up: Arithmetic Functions [Contents][Index]
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.
These functions round x upwards to the nearest integer,
returning that value as a double
. Thus, ceil (1.5)
is 2.0
.
These functions round x downwards to the nearest
integer, returning that value as a double
. Thus, floor
(1.5)
is 1.0
and floor (-1.5)
is -2.0
.
The trunc
functions round x towards zero to the nearest
integer (returned in floating-point format). Thus, trunc (1.5)
is 1.0
and trunc (-1.5)
is -1.0
.
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.
These functions return the same value as the rint
functions, but
do not raise the inexact exception if x is not an integer.
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).
These functions are just like rint
, but they return a
long int
instead of a floating-point number.
These functions are just like rint
, but they return a
long long int
instead of a floating-point number.
These functions are just like round
, but they return a
long int
instead of a floating-point number.
These functions are just like round
, but they return a
long long int
instead of a floating-point number.
These functions break the argument value into an integer part and a
fractional part (between -1
and 1
, exclusive). Their sum
equals value. Each of the parts has the same sign as value,
and the integer part is always rounded toward zero.
modf
stores the integer part in *integer-part
, and
returns the fractional part. For example, modf (2.5, &intpart)
returns 0.5
and stores 2.0
into intpart
.
Next: Remainder Functions, Previous: Normalization Functions, Up: Arithmetic Functions [Contents][Index]