floor

From cppreference.com
< c‎ | numeric‎ | math
 
 
 
Common mathematical functions
Functions
Basic operations
(C99)
(C99)
(C99)
(C99)
(C99)
(C99)
(C99)(C99)(C99)
Exponential functions
(C99)
(C99)
(C99)
(C99)
Power functions
(C99)
(C99)
Trigonometric and hyperbolic functions
(C99)
(C99)
(C99)
Error and gamma functions
(C99)
(C99)
(C99)
(C99)
Nearest integer floating point operations
floor
(C99)(C99)(C99)
(C99)
(C99)
(C99)(C99)(C99)
Floating point manipulation functions
(C99)(C99)
(C99)
(C99)
Classification
(C99)
(C99)
(C99)
(C99)
(C99)
(C99)
Macro constants
 
Defined in header <math.h>
float       floorf( float arg );
(since C99)
double      floor( double arg );
long double floorl( long double arg );
(since C99)

Computes nearest integer not greater than arg.

Contents

[edit] Parameters

arg - floating point value

[edit] Return value

Nearest integer not greater than arg

[edit] Notes

The integer value can be always represented by the given floating point type.

[edit] Example

#include <stdio.h>
#include <math.h>
#include <errno.h>
#include <fenv.h>
#include <string.h>
 
#pragma STDC FENV_ACCESS ON
 
void show_fe_exceptions(void)
{
    printf("current exceptions raised: ");
    if(fetestexcept(FE_DIVBYZERO))     printf(" FE_DIVBYZERO");
    if(fetestexcept(FE_INEXACT))       printf(" FE_INEXACT");
    if(fetestexcept(FE_INVALID))       printf(" FE_INVALID");
    if(fetestexcept(FE_OVERFLOW))      printf(" FE_OVERFLOW");
    if(fetestexcept(FE_UNDERFLOW))     printf(" FE_UNDERFLOW");
    if(fetestexcept(FE_ALL_EXCEPT)==0) printf(" none");
    printf("\n");
}
 
int main(void)
{
    printf("floor(+2.4)      = %+.1f\n", floor(+2.4));
    printf("floor(-2.4)      = %+.1f\n", floor(-2.4));
    printf("floor(+0.0)      = %+.1f\n", floor(+0.0));
    printf("floor(-0.0)      = %+.1f\n", floor(-0.0));
    printf("floor(+INFINITY) = %+f\n",   floor(+INFINITY));
    printf("floor(-INFINITY) = %+f\n",   floor(-INFINITY));
    printf("floor(NAN)       = %f\n",    floor(NAN));
    printf("\n");
 
    /* no "inexact" floating-point exception for finite non-integer arguments */
    errno = 0; feclearexcept(FE_ALL_EXCEPT);
    printf("floor(2.4)       = %.1f\n", floor(2.4));
    printf("%s\n",strerror(errno));
    show_fe_exceptions();
 
    return 0;
}

Possible output:

floor(+2.4)      = +2.0
floor(-2.4)      = -3.0
floor(+0.0)      = +0.0
floor(-0.0)      = -0.0
floor(+INFINITY) = +inf
floor(-INFINITY) = -inf
floor(NAN)       = nan
 
floor(2.4)       = 2.0
Success
current exceptions raised:  none

[edit] See also

(C99)(C99)
computes smallest integer not less than the given value
(function)
(C99)(C99)(C99)
rounds to nearest integer not greater in magnitude than the given value
(function)
(C99)(C99)(C99)
rounds to nearest integer, rounding away from zero in halfway cases
(function)
C++ documentation for floor