2020-06-30 19:55:47 -07:00
|
|
|
|
#ifndef COSMOPOLITAN_LIBC_TINYMATH_EMODL_H_
|
|
|
|
|
#define COSMOPOLITAN_LIBC_TINYMATH_EMODL_H_
|
|
|
|
|
#include "libc/math.h"
|
|
|
|
|
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns Euclidean floating-point division remainder.
|
|
|
|
|
*
|
|
|
|
|
* @return (𝑥 mod 𝑦) ∈ [0.,𝑦)
|
|
|
|
|
* @see fmodl()
|
|
|
|
|
*/
|
2022-06-20 04:32:25 -07:00
|
|
|
|
#define emodl(x, y) \
|
|
|
|
|
({ \
|
|
|
|
|
long double __x = x; \
|
|
|
|
|
long double __y = y; \
|
|
|
|
|
__x - fabsl(__y) * floorl(__x / fabsl(__y)); \
|
|
|
|
|
})
|
2020-06-30 19:55:47 -07:00
|
|
|
|
|
|
|
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
|
|
|
#endif /* COSMOPOLITAN_LIBC_TINYMATH_EMODL_H_ */
|