1FMOD(3)                    Linux Programmer's Manual                   FMOD(3)
2
3
4

NAME

6       fmod, fmodf, fmodl - floating-point remainder function
7

SYNOPSIS

9       #include <math.h>
10
11       double fmod(double x, double y);
12       float fmodf(float x, float y);
13       long double fmodl(long double x, long double y);
14
15       Link with -lm.
16
17   Feature Test Macro Requirements for glibc (see feature_test_macros(7)):
18
19       fmodf(), fmodl():
20           _ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L
21               || /* Since glibc 2.19: */ _DEFAULT_SOURCE
22               || /* Glibc versions <= 2.19: */ _BSD_SOURCE || _SVID_SOURCE
23

DESCRIPTION

25       These  functions  compute the floating-point remainder of dividing x by
26       y.  The return value is x - n * y, where n is the quotient of  x  /  y,
27       rounded toward zero to an integer.
28

RETURN VALUE

30       On  success, these functions return the value x - n*y, for some integer
31       n, such that the returned value has the same sign as x and a  magnitude
32       less than the magnitude of y.
33
34       If x or y is a NaN, a NaN is returned.
35
36       If x is an infinity, a domain error occurs, and a NaN is returned.
37
38       If y is zero, a domain error occurs, and a NaN is returned.
39
40       If x is +0 (-0), and y is not zero, +0 (-0) is returned.
41

ERRORS

43       See  math_error(7) for information on how to determine whether an error
44       has occurred when calling these functions.
45
46       The following errors can occur:
47
48       Domain error: x is an infinity
49              errno is set to EDOM (but see BUGS).  An invalid  floating-point
50              exception (FE_INVALID) is raised.
51
52       Domain error: y is zero
53              errno  is  set  to  EDOM.   An  invalid floating-point exception
54              (FE_INVALID) is raised.
55

ATTRIBUTES

57       For  an  explanation  of  the  terms  used   in   this   section,   see
58       attributes(7).
59
60       ┌─────────────────────────┬───────────────┬─────────┐
61Interface                Attribute     Value   
62       ├─────────────────────────┼───────────────┼─────────┤
63fmod(), fmodf(), fmodl() │ Thread safety │ MT-Safe │
64       └─────────────────────────┴───────────────┴─────────┘

CONFORMING TO

66       C99, POSIX.1-2001, POSIX.1-2008.
67
68       The variant returning double also conforms to SVr4, 4.3BSD, C89.
69

BUGS

71       Before version 2.10, the glibc implementation did not set errno to EDOM
72       when a domain error occurred for an infinite x.
73

SEE ALSO

75       remainder(3)
76

COLOPHON

78       This page is part of release 5.07 of the Linux  man-pages  project.   A
79       description  of  the project, information about reporting bugs, and the
80       latest    version    of    this    page,    can     be     found     at
81       https://www.kernel.org/doc/man-pages/.
82
83
84
85                                  2017-09-15                           FMOD(3)
Impressum