C++
数字 | Numerics

std::fmod

STD::fmod

Defined in header
float fmod( float x, float y (1)
double fmod( double x, double y (2)
long double fmod( long double x, long double y (3)
Promoted fmod( Arithmetic1 x, Arithmetic2 y (4)(since C++11)

1-3%29计算除法操作的浮点余数。x/y...

的所有参数组合的一组重载或函数模板算术类型不包括在1-3的范围内。如果有任何争论积分型,它被铸造成double.如果任何其他论点是long double,则返回类型为long double,否则就是double...

除法操作的浮点余数。x/y此函数计算的值正好是x - n*y,在哪里nx/y它的分数部分被截断。

返回的值与x而且小于y在震级上。

参数

x, y-floating point values

返回值

如果成功,则返回除法的浮点余数。x/y如上文所述。

如果发生域错误,则返回支持%29的实现定义值%28 NaN。

如果由于下流而发生范围错误,则返回舍入%29后的正确结果%28。

错误处理

错误按数学[医]错误处理...

域错误可能发生在y是零。

如果实现支持ieee浮点算法%28IEC 60559%29,

  • 如果x是±0和y不是零,而是返回±0。

  • 如果x是±∞和y不是南,南回来了FE_INVALID提出来

  • 如果y是±0和x不是南,南回来了FE_INVALID提出来

  • 如果y是±∞和x是有限的,x会被归还。

  • 如果任一参数都是nan,则返回nan。

注记

POSIX要求,则域错误将发生在以下情况下:x是无限的或y是零。

std::fmod,但不是std::remainder对于将浮点类型无声包装为无符号整数类型非常有用:(0.0<=(y = std::fmod(std::rint(x), 65536.0))? y :65536.0+ y)在范围内[-0.0 .. 65535.0],对应于unsigned short,但是std::remainder(std::rint(x), 65536.0在范围内[-32767.0, +32768.0],它超出了signed short...

fmod的双重版本的行为似乎如下所示。

二次

double fmod(double x, double y) { #pragma STDC FENV_ACCESS ON double result = std::remainder(std::fabs(x), (y = std::fabs(y)) if (std::signbit(result)) result += y; return std::copysign(result, x }

二次

二次

#include <iostream> #include <cmath> #include <cfenv> #pragma STDC FENV_ACCESS ON int main() { std::cout << "fmod(+5.1, +3.0) = " << std::fmod(5.1,3) << '\n' << "fmod(-5.1, +3.0) = " << std::fmod(-5.1,3) << '\n' << "fmod(+5.1, -3.0) = " << std::fmod(5.1,-3) << '\n' << "fmod(-5.1, -3.0) = " << std::fmod(-5.1,-3) << '\n'; // special values std::cout << "fmod(+0.0, 1.0) = " << std::fmod(0, 1) << '\n' << "fmod(-0.0, 1.0) = " << std::fmod(-0.0, 1) << '\n' << "fmod(5.1, Inf) = " << std::fmod(5.1, INFINITY) << '\n'; // error handling std::feclearexcept(FE_ALL_EXCEPT std::cout << "fmod(+5.1, 0) = " << std::fmod(5.1, 0) << '\n'; if(std::fetestexcept(FE_INVALID)) std::cout << " FE_INVALID raised\n"; }

二次

可能的产出:

二次

fmod(+5.1, +3.0) = 2.1 fmod(-5.1, +3.0) = -2.1 fmod(+5.1, -3.0) = 2.1 fmod(-5.1, -3.0) = -2.1 fmod(+0.0, 1.0) = 0 fmod(-0.0, 1.0) = -0 fmod(5.1, Inf) = 5.1 fmod(+5.1, 0) = -nan FE_INVALID raised

二次

另见

div(int)ldivlldiv (C++11)computes quotient and remainder of integer division (function)
remainder (C++11)signed remainder of the division operation (function)
remquo (C++11)signed remainder as well as the three last bits of the division operation (function)

c fmod文件

© cppreference.com

在CreativeCommonsAttribution下授权-ShareAlike未移植许可v3.0。

http://en.cppreference.com/w/cpp/数值/maath/fmod