草庐IT

floating-point-comparison

全部标签

c++ - float 的小数部分最多有多少位 10 位数字

如果可以输出一个float,这样就没有值的截断(例如使用setpercision)并且数字以固定表示法输出(例如使用fixed>)保证float的整个小数部分可以存储在缓冲区中所需的缓冲区大小是多少?我希望标准中有一些东西,比如#define或numeric_limits中的东西,它会告诉我小数的以10为底的最大值位置浮点类型的一部分。我在这里询问了浮点类型的小数部分中以10为底的数字的最大数量:WhatAretheMaximumNumberofBase-10DigitsintheIntegralPartofaFloatingPointNumber但我意识到这可能更复杂。例如,1.0/

c++ - float 减法返回不正确的值

所以我有一个计算,减去作为vector对象组件的两个float,然后似乎返回了不正确的结果。我尝试使用的代码是:cout运行此代码将返回的位置1617-1.00002如您所见,打印出xresult.x和vec1.x的值告诉您它们分别为16和17,但减法运算似乎引入了错误。有什么想法吗? 最佳答案 Asyoucansee,printingoutthevaluesofxresult.xandvec1.xtellsyouthattheyare16and17respectively,yetthesubtractionoperationsee

c++ - 如何将float值传递给以double为引用值的函数

我有一个函数,其原型(prototype)如下所示:voidexample(double&var);但是,我的问题是我可能还需要使用一些浮点值来调用函数。例如floattemp=10.1;example(temp)如果我这样做,我的代码不会编译,可能是因为将浮点值传递给双引用变量。我想避免为double和float编写重载函数。有人可以建议一个更清洁/更好的方法来实现这个吗?函数基本上是一个截断函数,它截断给定的输入&是的,原始文件被修改了。谢谢。 最佳答案 模板函数怎么样?templatevoidexample(T&var);编译

c++ - 使用 chrono 将 time_point 转换为特定持续时间

/*definitionofstartandendstd::chrono::time_pointstart;std::chrono::time_point_end;*/std::chrono::time_pointsomeclass::spf(){_end=std::chrono::system_clock::now();std::chrono::time_pointtime(_end-start);start=std::chrono::system_clock::now();returntime;}unsignedintsomeclass::secs(){returnstd::chr

c++ - 使用 chrono::time_point 获取当前小时数和分钟数

我一直试图找到一个使用std::chrono的示例,它只获取一个chrono::time_point并将小时数和分钟数提取为整数。我有:std::chrono::system_clock::time_pointnow=std::chrono::system_clock::now();但我不知道如何提取小时和分钟(从午夜开始)?我正在寻找类似的东西:inthours=now.clock.hours(); 最佳答案 这是免费的,open-sourcedatelibrary这将为你做这件事。如果您想确切了解它是如何完成的,请随时检查代码。

c++ - 在 C++ 中返回一个 float 组

我目前在C++中有一个4x4矩阵类,我将每个值存储为float:Matrix4d::Matrix4d(constfloat&m00,constfloat&m01,constfloat&m02,constfloat&m03,constfloat&m10,constfloat&m11,constfloat&m12,constfloat&m13,constfloat&m20,constfloat&m21,constfloat&m22,constfloat&m23,constfloat&m30,constfloat&m31,constfloat&m32,constfloat&m33){_m00

C++ 虚拟类 : interesting point

请告诉我为什么以下程序的输出如下所示。我没有得到C++中的虚拟类。观察下面的代码:classB{public:B(charc='a'):m_c(c){}public:charget_c()const{returnm_c;}voidset_c(charc){m_c=c;}private:charm_c;};classC:publicB{};classD:publicB{};classE:publicC,publicD{};intmain(){Ee;C&c=e;D&d=e;std::coutO/P:aa我希望输出是ab。获得“aa”的原因是什么?如果我有c.set_c('b')而不是d.s

python ‘float‘object is not iterable

目录Python'float'objectisnotiterable错误背景错误示例错误解决方法结论应用场景错误解决方法介绍迭代(Iteration)迭代的工作方式迭代可迭代对象迭代其他数据结构自定义可迭代对象Python'float'objectisnotiterable在Python中,​​'float'objectisnotiterable​​是一个常见的错误消息。它在迭代(iteration)过程中表示发生了错误,因为我们试图对浮点数进行迭代操作,但是浮点数是不可迭代的。错误背景在Python中,可迭代对象(iterable)是一种能够被遍历(iterating)的数据类型,例如列表(

c++ - 让 std::complex<double> 通过 std::is_floating_point 测试

我想要类型double,float,complex和complex通过static_assert健康)状况。我想static_assert(std::is_floating::value,"somemessage")可以解决问题,但是复杂类型没有通过这个测试(至少在gcc-4.10下是这样)。我应该添加什么谓词来确保这四种类型(可能还有longdoubles)被允许作为模板实例化,但没有别的? 最佳答案 为标准库类型特征类添加特化通常是非法的,即使是用户定义的类型也是如此。§20.10.2[meta.type.synop]/p1:T

c++ - IEEE754 float 在多大程度上满足 LessThanComparable?

TL;DR包括NaN的IEEE754浮点值是否满足LessThanComparable?具体来说,问题“WhydoesRelease/Debughaveadifferentresultforstd::min?”让我查找了LessThanComparable:ThetypemustworkwithRequirementsThetypeTsatisfiesLessThanComparableifGivena,b,andc,expressionsoftypeTorconstTThefollowingexpressionsmustbevalidandhavetheirspecifiedeffe