草庐IT

floating-point-precision

全部标签

C++ 32 位与 64 位 float 限制

鉴于代码段如下,我只想知道为什么longdouble的最大值在64位比32位小?为什么64位版本不能像32位版本那样扩展数字来填充“40”精度输出?LDBL_MIN和LDBL_MAX的值似乎相等,这是一个错误吗?我查看了我机器中的float.h文件,但找不到这些宏常量的明确定义。测试代码(平台=Win7-64bit)#include#includecout32位结果(MinGW-20120426)FLT_MAX=340282346638528859811704183484516925440DBL_MAX=1.797693134862315708145274237317043567981

c++ - 可以使用 memset 来填充一组 std::complex<float> 吗?

具体来说,我想知道这一行是否:memset(cjzyp,(0,0),size_cjzy*sizeof(std::complex));将填写cjzyp,complex的数组s,具有复数零值((0,0))。 最佳答案 std::memset将转换为unsignedchar的int作为第二个参数,它不会工作。使用std::fill代替http://www.cplusplus.com/reference/algorithm/fill/cjzyp=newstd::complex[100]std::fill(cjzyp,cjzyp+100,st

c++ - 将 float 转换为表示为 int 的通用定点

我正在为我构建的一些硬件编写一个软件驱动程序,它只实现定点运算。我搜索了高低但似乎无法找到允许我将float转换为固定(x:y)+1符号位的通用算法。我还想将其表示为一个int,以便我可以测试用python和c++编写的一般模拟算法的准确性和速度比较。(我使用的是64位MacbookPro)我在诺基亚网站上找到的最接近我需要的东西http://developer.nokia.com/Community/Wiki/Fixed-point_math_for_Python但他们只转换为16:16并且不太了解常量65536.0从何而来,而我需要x:y。编辑---我仍然发现在转换回来时所有小数部

c++ - 如何继承boost::geometry::model::point?

我想继承bg::model::point用自己的功能扩展它。*point*s应存储在rtree中.以下最小示例无法编译我的派生点(boost1.54,gcc4.7.2)的用法:#include#include#include#include#include#includenamespacebg=boost::geometry;namespacebgi=boost::geometry::index;namespaceboost{namespacegeometry{namespaceindex{//apparentlynecessary:templatestructindexable>{t

c++ - 具有 boost::multiprecision::mpfr_float 的 Eigen3 动态矩阵

我想制作矩阵并使用Eigen3库使用它们,我的数字类型是Boost.Multiprecision的mpfr_float包装器。我可以很好地制作矩阵,但是除了矩阵加法之外,我尝试过的所有操作都失败了。仅将两个单位矩阵相乘会产生垃圾结果!这是一个MWE:#include#include#include#includenamespaceEigen{usingboost::multiprecision::mpfr_float;templatestructNumTraits{typedefboost::multiprecision::mpfr_floatReal;typedefboost::mu

c++ - 将 float 转换为字符串的最快 C++ 方法

我遇到了将float转换为字符串的问题,其中to_string对我来说太慢了,因为我的数据可能涉及几百万个float。我已经在howtowritethosedataoutfast上找到了解决方案.然而,在解决了那个问题之后,我很快意识到,float到string的转换留下了很大的影响。那么,除了使用其他非标准库之外,还有什么想法或解决方案吗? 最佳答案 以下是一些将float转换为十进制字符串表示形式的最快算法:FlorianLoitsch的Grisu:PrintingFloating-PointNumbersQuicklyandA

c++ - 如何重现浮点 cos(x)!=cos(x)

如何重现此行为?https://isocpp.org/wiki/faq/newbie#floating-point-arith2准确的说,在下面的代码中,参数x和y是相等的;它们可以等于1.0或任何其他值。voidfoo(doublex,doubley){doublecos_x=cos(x);doublecos_y=cos(y);//thebehaviormightdependonwhat'sinhereif(cos_x!=cos_y){std::cout一些编译器选项?环形?有什么想法吗? 最佳答案 我会尝试按照链接示例中的方式进

c++ - double float 的显示及其比较

序言我正在研究一个为不懂浮点运算的人开发的系统。出于这个原因,float比较的实现不会暴露给使用该系统的人。目前float的比较是这样发生的(由于遗留原因,这不能改变)://Ifeithernumberisnotfinite,dodefaultcomparisonif(!IsFinite(num1)||!IsFinite(num2)){output=(num1==num2);}else{//Getexponentsofbothnumberstodetermineepsilonforcomparisontmp=(OSINT32*)&num1+1;exp1=(((*tmp)>>20)&0x

c++ - 混合函数 - 增加 float

我正在浏览代码库并找到以下模板函数:templateTmix(constT&a,constT&b,constT2&interp){staticconstexprT2one=((T2)1);return(a*(one-interp))+(b*interp);}和下面的评论//You'dthinkinsteadofdoingthea*(1-t)+b*t,it'dbefaster//andonelessmultiplytodoa+(b-a)*t,right?Bad!Increasesfloating//pointexceptionoccurances.SameasLERP有人可以强调为什么这

c++ - 格式化 float

您好,我想格式化float,使其显示如下:小数.分数其中小数=最多11位数字和小数=最多9位数如果没有小数部分,则不应显示小数部分,小数部分中超过11位的数字将以科学形式表示。谁能帮帮我? 最佳答案 我认为没有这样的内部格式。需要自己格式化(未测试):voidfprintf_float(FILE*f,doublevalue){if(-1e110?"":"-";doubleipart,fpart;charfpartstr[16];intpos;fpart=modf(d,&ipart);snprintf(fpartstr,16,"%.9