草庐IT

Double-precision_floating-point_f

全部标签

c++ - vector<double> 比 double* : why? 快

这是我用std::vector试过的一个循环和普通的旧double*.对于1000万个元素,vector版本的运行时间是double*的大约80%。版本需要;对于N的几乎任何值,vector明显更快。查看GCCSTL源代码,我没有看到std::vector正在做任何比double*本质上更有趣的事情习语正在做(即,使用普通旧new[]分配,operator[]取消引用偏移量)。Thisquestion也是这么说的。知道为什么vector版本更快吗?Compiler:GCC4.6.1Examplecompileline:g++-Ofast-march=native-DNDEBUG\-ft

c++ - 在C++中将int转换为16位 float (半精度 float )

我如何将一个整数转换为一个半精度float(它被存储到一个数组unsignedchar[2]中).输入int的范围是1-65535。精度真的不是问题。我正在做类似的事情,将16bitint转换为unsignedchar[2],但我知道没有halfprecisionfloatC++数据类型。以下示例:int16_tposition16int=(int16_t)data;memcpy(&dataArray,&position16int,2); 最佳答案 这是一件非常简单的事情,您需要的所有信息都在Wikipedia中。.示例实现:#in

python - 将 C++ double 返回给 Python?

所以我使用python调用共享C++库中的方法。我在将double从C++返回到python时遇到问题。我创建了一个展示问题的玩具示例。请随意编译并试用。这是python代码(soexample.py):#PythonimportsfromctypesimportCDLLimportnumpyasnp#OpensharedCPPlibrary:cpplib=CDLL('./libsoexample.so')cppobj=cpplib.CPPClass_py()#Stuckonconvertingtoshort**?x=cpplib.func_py(cppobj)print'x=',x这

c++ - 将 int 值添加到 double 时是否有性能优势/惩罚?

给定vector加法:NPNumberNPNumber::plus(constdoubleo)const{vectorc;for(doublea:values)c.push_back(a+o);returnNPNumber(width,c);}如果NPNumber包含一个doublevector(字段值),当我只添加一个整数而不是另一个NPNumber时,与转换该整数并使用上面的函数相比,是否有性能优势或损失?也就是说,这在任何架构上是更快还是更慢:NPNumberNPNumber::plus(constinti)const{vectorc;for(doublea:values)c.p

c++ - 此函数如何通过 NOT 和 AND 运算计算 float 的绝对值?

我试图了解以下代码片段的工作原理。该程序使用SIMDvector指令(IntelSSE)计算4个float的绝对值(因此,基本上是一个向量化的“fabs()”函数)。这是片段:#include#include"xmmintrin.h"templatestructalignas(16)sse_t{Tdata[16/sizeof(T)];};intmain(){sse_tx;x.data[0]=-4.;x.data[1]=-20.;x.data[2]=15.;x.data[3]=-143.;__m128a=_mm_set_ps1(-0.0);//???__m128xv=_mm_load_p

c++ - mfc中将CString转为float

如何将CString变量转换为float?(我正在使用visualc++6.0和MFC)我正在尝试使用编辑框返回一个值,我将其放入一个float组中。我正在使用GetWindowText方法获取返回CString的值。所以我需要转换为float。(或者我只是以完全错误的方式做事?)。我想在MFC中已经有这样做的方法。(已经使用Format方法转换为CString,在编辑框中显示数组中的值)谢谢。 最佳答案 你可以这样做CStringpi="3.14";returnatof(pi);编辑同样使用这个函数:CStringpi="3.14

c++ - 我可以写 const expression double 是两个 ulp 小于 -0.5

我有一组基于通过json数据包接收到的数字的浮点计算。在计算结束时,我要求其中一个数字>=-0.5。我发现有时我有一个未通过测试的值,因为它是一个ULP低于阈值。无论如何要写一个constexpression,意思是像constexprautothreshold=-0.5-2*ULP;还是我必须求助于类似的东西autothreshold=-0.5;threshold=std::nexttoward(threshold,-2.0);threshold=std::nexttoward(threshold,-2.0); 最佳答案 您应该能

c++ - 如何从命令行 (unix) 打印二进制 double 组

我得到了二进制文件,其中包含double。我如何将其打印到终端。我试过octaldump'od'但无法弄清楚我试过类似的语法head-c80|od-f但这不起作用,od的手册页非常糟糕。我已经编写了一个可以执行我想要的操作的c程序,类似于假设10doubleblock。doubletmp[10];while(fread(tmp,sizeof(double),10,stdin))for(inti=0;i谢谢。 最佳答案 你试过了吗hexdump效用?hexdump-e'[iterations]/[byte_count]"[format

c++ - Qt - 序列化 "double"时出现问题

我序列化“double”数据类型并得到一个错误QDataStream&operator运算符已定义。这是错误消息:error:conversionfrom'double'to'constQChar'isambiguous您遇到过这种情况,或者理解为什么会变成这样吗? 最佳答案 听起来它看不到double的运算符,因此它试图从double隐式创建一个QChar以发送到流,但是QChar有可能匹配的多个构造函数。确保您的header包含的内容都是正确的。你能告诉我们你试图序列化替身的代码吗?

c++ - 如何在 C++ 中精确显示 double 的小数位?

ProblemGiventwointegersa,b,aSampleInput3734580011299053122SampleOutput.428751Thelast6digitsrepeatforever..43125Thisexpansionterminates..113Thelast2digitsrepeatforever..4344262295081967213114754098360655737704918032786885245901639Thelast60digitsrepeatforever.注意:此问题源自ProgFest编程竞赛。如果我们应用这三个定理,这个问题的