我需要一个简单的浮点舍入函数,因此:
double round(double);
round(0.1) = 0
round(-0.1) = 0
round(-0.9) = -1
我可以在 math.h 中找到 ceil()
和 floor()
- 但不是 round()
。
它是否以另一个名称出现在标准 C++ 库中,还是丢失了?
原文由 Roddy 发布,翻译遵循 CC BY-SA 4.0 许可协议
我需要一个简单的浮点舍入函数,因此:
double round(double);
round(0.1) = 0
round(-0.1) = 0
round(-0.9) = -1
我可以在 math.h 中找到 ceil()
和 floor()
- 但不是 round()
。
它是否以另一个名称出现在标准 C++ 库中,还是丢失了?
原文由 Roddy 发布,翻译遵循 CC BY-SA 4.0 许可协议
round_f 用于带有数学的 ARM
static inline float round_f(float value)
{
float rep;
asm volatile ("vrinta.f32 %0,%1" : "=t"(rep) : "t"(value));
return rep;
}
round_f 用于没有数学的 ARM
union f__raw {
struct {
uint32_t massa :23;
uint32_t order :8;
uint32_t sign :1;
};
int32_t i_raw;
float f_raw;
};
float round_f(float value)
{
union f__raw raw;
int32_t exx;
uint32_t ex_mask;
raw.f_raw = value;
exx = raw.order - 126;
if (exx < 0) {
raw.i_raw &= 0x80000000;
} else if (exx < 24) {
ex_mask = 0x00ffffff >> exx;
raw.i_raw += 0x00800000 >> exx;
if (exx == 0) ex_mask >>= 1;
raw.i_raw &= ~ex_mask;
};
return raw.f_raw;
};
原文由 AVI-crak Home 发布,翻译遵循 CC BY-SA 4.0 许可协议
3 回答2k 阅读✓ 已解决
2 回答3.9k 阅读✓ 已解决
2 回答3.2k 阅读✓ 已解决
1 回答3.2k 阅读✓ 已解决
1 回答2.7k 阅读✓ 已解决
3 回答3.4k 阅读
1 回答1.6k 阅读✓ 已解决
它从 cmath 中的 C++11 开始可用(根据 http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2012/n3337.pdf )
输出: