草庐IT

Double-precision_floating-point_f

全部标签

c++ - 检查 float 是否可以表示为整型

如何检查float是否可以表示为整数类型,而无需通过强制转换调用未定义的行为?这是§4.9.1禁止的:Aprvalueofafloatingpointtypecanbeconvertedtoaprvalueofanintegertype.Theconversiontruncates;thatis,thefractionalpartisdiscarded.Thebehaviorisundefinedifthetruncatedvaluecannotberepresentedinthedestinationtype,有thisC的问题,但接受的答案显然会导致未定义的行为(首先是简单的转换,

c++ - 启用 _GLIBCXX_DEBUG 后,Stringstream 无法使用 double

我正在使用_GLIBCXX_DEBUG模式来帮助查找我的代码中的错误,但我遇到了一个问题,我认为这是库中的一个错误,但希望有人能告诉我我只是做错了什么。这是一个重现问题的简短示例:#define_GLIBCXX_DEBUG#include#includeintmain(intargc,constchar*argv[]){std::ostringstreamostr;ostr如果我注释掉#define,那么输出是(如预期的那样):Result:1.2有了_GLIBCXX_DEBUG定义,但是输出很简单:Result:我已经追踪到流的_M_num_put字段被保留为NULL,这导致在流中抛

c# - 在 C# 和 C++ 中将 float / double 乘以 0.5 而不是除以 2 是否安全?

基本上是这样的(不是真正的代码):for(inti=0;iv0.pos类型为Vector3,但可能是Vector3.这样做安全吗?:Vector3center=(v0.pos+v1.pos)*0.5;这似乎是不成熟的优化,但它必须尽可能快,以便在数十亿点(点云)上调用。 最佳答案 无论如何都不是C++专家,但在C#中,这样做:vara=newFunc((floatf1,floatf2)=>(f1+f2)*0.5);varb=newFunc((floatf1,floatf2)=>(f1+f2)/2);在前者中生成IL:加载参数添加它们

C++ 静态初始化 map<float, float[3]>

因此,我有一个mapmyMap,我正在尝试对其进行静态初始化(必须以这种方式完成)。我正在做以下事情:myMap={{415,{1,52356,2}},{256,{356,23,6}},//...etc};但是我收到以下错误:“数组初始值设定项必须是初始值设定项列表。”我上面的语法有什么问题? 最佳答案 你应该使用array而不是“普通”数组:#include#include#includeintmain(){std::map>myMap{{415,std::array{1,52356,2}},{256,std::array{356

c++ - 使用 Wfloat-equal 选项将 float 与 1 或 0 进行比较

我对在代码中执行浮点相等比较的问题有些熟悉。目前我在(GCC,Clang)上编译的代码库启用了以下选项:-Wfloat-equal在代码库中有以下示例比较:templatevoidfoo(FloatTypev){if(v==FloatType(1)){...}elseif(v==FloatType(0)){....}}foo函数调用如下:doubled=123.98;floatf=123.98f;foo(d);foo(f);考虑到1和0的特殊情况,它们每个都有精确的浮点表示(double,float)并且代码显然在完全相等之后,而不是接近于一些次要的东西区别-有没有一种方法可以重写代码

c++ - optional<double> 可以实现为 8 字节对象吗?

是否可以实现std::optional这样sizeof(std::optional)==8通过某种方式使用它可以将字符存储在NAN中,请参阅http://en.cppreference.com/w/cpp/numeric/math/nan?有实现吗?可以根据标准中提供的功能来完成吗? 最佳答案 我不认为这是可以做到的,因为没有规则阻止程序自己利用和依赖NaN中的额外位。然后,如果您将魔数(MagicNumber)存储到optional中,它看起来就像不存在,而不是应用程序的特殊NaN。

C++ - 如何正确地将 double 转换为 int

我目前正在编写一个需要对平方根取底的程序。因为我取平方根的值是正数,所以我只是将它转换为int。所以说下面的例子:inti=16;intj=std::sqrt(i)j应该是4。不过我想知道,sqrt是否有可能返回3.9999999991而不是4.000000001或其他什么,而j的结果是3?是否有定义浮点行为的规则?我怎样才能正确地将其转换为int? 最佳答案 几乎所有广泛使用的硬件都使用IETF754float,尽管C++不需要它。假设IETF754float和::std::sqrt到IETF754浮点平方根运算的直接映射,您可以

c++ - 交换 float 和 double 的 "endianness"

我想切换float和double值的“字节顺序”,它可以正常工作,方法如下:floatconstv{1.f};swap(reinterpret_cast(v));是否有更好的方式来进行交换,无需强制转换?编辑:swap()是gcc内置函数的C++包装器,我没有在此处包含它。uint16_t__builtin_bswap16(uint16_tx)uint32_t__builtin_bswap32(uint32_tx)uint64_t__builtin_bswap64(uint64_tx)某些数据格式需要字节顺序交换,例如CBOR。 最佳答案

c++ - float 的最小正值?

我是C++新手!Wikisays关于float:最小正正态值为2^−126≈1.18×10^−38,最小正(非正态)值为2^−149≈1.4×10^−45。但是如果一个float最多可以有7位数字(≈7.225),那么最小值不就是0,0000001吗?我很困惑:) 最佳答案 float由3部分组成:符号、分数和指数。这些都是整数,将它们组合起来得到一个实数:(-1)符号×(分数×2-23)×2指数维基百科文章使用带小数点的二进制数作为分数,但我发现将其视为整数乘以固定常数会更清楚。在数学上是一样的。分数是23位,但有一个额外的隐藏位

c++ - 当用户将字符串存储在 float 变量中时如何抛出异常?

floatinput;cin>>input;//iftheusertypestringininputthenthrowexceptionif(!isdigit(input)){throw"error";}但是isdigit也会为数值抛出异常。如何解决? 最佳答案 floatinput;if(cin>>input){//allisgood...}else{throw"error";}是一种方法。如果输入以数字开头,程序将采用if路径,否则采用else路径。 关于c++-当用户将字符串存储在