草庐IT

Double-precision_floating-point_f

全部标签

c++ - 从 QByteArray 转换为 double 组

我有一个double的数组:QVectorY(count);我需要打包到QByteArray通过以太网发送。所以我做到了。这并不难:QByteArrayline;line.clear();line.append(QByteArray::fromRawData(reinterpret_cast(Y.data()),count*sizeof(double)));我尝试使用此代码解压来自QByteArrayrecv的数据:QVectordata((line.size())/sizeof(double));QByteArraydou(sizeof(double),0x0);for(inti=0

c++ - 随机 double 总是无限的

我有以下内容:std::random_devicerd;std::mt19937_64randEng(rd());std::uniform_real_distributionrg(std::numeric_limits::lowest(),std::numeric_limits::max());for(size_ti=0;i其中nums是一个vector,预大小为numToGenerate尽管打印出的每个数字都显示inf,但我的理解是,我已将其设置为在这种情况下获取-1.79769e+308和1.79769e+308因为它恰好在我的机器上。我在这个随机数生成器的设置中做错了什么

c++ - 运算符 + 和 float 参数

我对模板有一个奇怪的问题,我正在尝试在两者之间进行基本添加一个模板类和“float/double/int”类型。这是非常基本的,但如果我这样做:templateclasstoto{Ta;};templatetotooperator+(totoconst&,T&){std::coutt;totod=t+2.3;}它不会编译,因为2.3被认为是double的,它与签名不匹配。我可以为我的operator+使用第二个模板参数作为templatetotooperator+(totoconst&,D&){std::cout它编译、执行正确但太危险D可以是一切。另一种方法是使用float、doub

c++ - SSE 内在函数 : masking a float and using bitwise and?

基本上这个问题与x86汇编器有关,您有一个数字,您希望使用and将其设置为零或数字本身。.如果你andnumber为负数你会得到number本身,但如果你and它与零你得到零。现在我在使用SSEinstrinsics时遇到的问题是float在二进制中与double不同(或者我弄错了)。无论如何,这是代码,我尝试使用各种float来掩盖第二个和第三个数字(分别为127.0f和99.0f),但没有成功。#include#includevoidprint_4_bit_num(constchar*label,__m128var){float*val=(float*)&var;printf("%

c++ - 确保 float 小于精确值

我想在C++中计算以下形式的总和floatresult=float(x1)/y1+float(x2)/y2+....+float(xn)/ynxi,yi都是整数。结果将是实际值的近似值。这个近似值小于或等于实际值是至关重要的。我可以假设我所有的值(value)观都是有限的和积极的。我试过在这个代码片段中使用nextf(,0)。cout.precision(15);floata=1.0f/3.0f*10;//31/3floatb=2.0f/3.0f*10;//62/3floataf=nextafterf(a,0);floatbf=nextafterf(b,0);cout如您所见,正确的解

C++ - float 组 vector

我目前正在尝试创建一个包含float组的vector。我过得很艰难。我有以下代码:floattestArray[4]={20,-3.14/2,5,-3.14/2};std::vectorinputVector;std::vector::iteratorit=inputVector.begin();inputVector.insert(it,testArray);我一直收到错误提示“数组必须用大括号括起来的初始化器初始化”和“无效的数组赋值”。我用一个整数vector(而不是一个数组vector)尝试了同样的代码,但没有任何问题。我认为存在一个我不理解的潜在问题。感谢任何帮助!

c++ - 为什么 cout.setf(ios::fixed) 将我的 float 更改为十六进制?

我最近遇到了这个与cout.setf(ios::fixed)有关的奇怪问题。我花了很长时间才找到原因,我想我会在这里询问以了解更多信息。问题在于-使用cout.setf(ios::fixed)时,所有float都打印为十六进制数。为什么会这样?ios::base的文档似乎并不暗示这会发生(至少对我而言)。我使用的是g++5.3.0,下面粘贴的是一个最小示例和输出。#include#includeusingnamespacestd;intmain(intargc,charconst*argv[]){complexI(0.0,1.0);doublepi=M_PI;cout.setf(ios

c++ - 提升精神 x3 int32 | double_ 无法解析 double

我正在尝试编写一个解析器,它解析int32_t或double.作为第一次尝试,我编写了这个解析器:constautoint_or_double=boost::spirit::x3::int32|boost::spirit::x3::double_;我希望得到一个boost::variant解析器成功解析了类似12,100,-42,7的整数但它无法解析像13.243,42.7,12.0-10000.3这样的double这是一个直播demo为什么这个解析器在double上失败? 最佳答案 您的问题与thisquestion非常相似.当整

c++ - 使用与 double 数组的内存匹配的 std::vector

我正在尝试连接两个现有代码库——一个使用C,另一个使用C++。C++代码使用std::vector而另一个基于double组。我想从C代码传递double组,在C++代码中对std::vectors执行操作,并最终将这些操作反射(reflect)在double组中。是否可以创建一个std::vector来匹配double数组占用的内存?我尝试了几种选择,但它们都涉及创建一个新vector和将double数组的拷贝复制到该vector中。例如:voidfcn(double*a,intsizeofa){std::vectorvect_a;vect_a.assign(a,a+sizeofa)

c++ - 将 float 转换为 bigint(也称为获取二进制指数和尾数的可移植方式)

在C++中,我有一个bigint类,它可以容纳任意大小的整数。我想将大float或double转换为bigint。我有一个工作方法,但有点hack。我使用IEEE754数字规范来获取输入数字的二进制符号、尾数和指数。代码如下(这里忽略符号,不重要):floatinput=77e12;bigintresult;//extractsign,exponentandmantissa,//accordingtoIEEE754singleprecisionnumberformatunsignedint*raw=reinterpret_cast(&input);unsignedintsign=*ra