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
,在哪里n
是x/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。