2021-10-11 18:37:13 -03:00

41 lines
1.0 KiB
C

#if !defined(lint) && defined(SCCSIDS)
static char sccsid[] = "@(#)fmod.c 1.1 94/10/31 SMI"; /* from S5R3 1.12 */
#endif
/* Copyright (c) 1984 AT&T */
/* All Rights Reserved */
/* THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF AT&T */
/* The copyright notice above does not evidence any */
/* actual or intended publication of such source code. */
/*LINTLIBRARY*/
/*
* fmod(x, y) returns the remainder of x on division by y,
* with the same sign as x,
* except that if |y| << |x|, it returns 0.
*/
#include <math.h>
double
fmod(x, y)
register double x, y;
{
double d; /* can't be in register because of modf() below */
/*
* The next lines determine if |y| is negligible compared to |x|,
* without dividing, and without adding values of the same sign.
*/
d = _ABS(x);
if (d - _ABS(y) == d)
return (x);
#if !defined(pdp11) && !defined(M32) /* pdp11 and M32 "cc" cant handle
cast of a double to a void */
(void)
#endif
modf(x/y, &d); /* now it's safe to divide without overflow */
return (x - d * y);
}