草庐IT

Double-precision_floating-point_f

全部标签

c++ - 将 int32 重新解释为 float

我需要保存一个浮点值,它是一个整数值的复制内存。在reinterpretedFloat函数中,我制作了一个样本整数并将内存复制到一个浮点变量。问题是当memcpy-edfloat返回时值会改变。这是示例代码。#include#includevoidprintHex(constunsignedchar*buff,intcount){printf("0X");for(inti=0;i(&tmp),4);//memcpyreturntmp;}intmain(){floatnewFloat=reinterpretedFloat();printHex(reinterpret_cast(&newF

c++ - 从重载函数 std::real<float> 解析地址

std::vector>c;std::vectord;std::transform(c.begin(),c.end(),d.begin(),std::real);为什么编译器无法解析来自重载函数的地址real?编译器指的是哪些重载函数? 最佳答案 您的库实现为std::real提供了额外的重载.为什么会重载?26.4.9Additionaloverloads[cmplx.over]1Thefollowingfunctiontemplatesshallhaveadditionaloverloads:argnormconjprojima

c++ - 从 long long 到 float 的隐式转换会产生意外结果

试图验证(使用VS2012)一本书的声明(第二句)Whenweassignanintegralvaluetoanobjectoffloating-pointtype,thefractionalpartiszero.Precisionmaybelostiftheintegerhasmorebitsthanthefloating-pointobjectcanaccommodate.我写了下面的小程序:#include#includeusingstd::cout;usingstd::setprecision;intmain(){longlongi=4611686018427387905;//

c# - P/Invoke with arrays of double - 在 C# 和 C++ 之间编码数据

我已经阅读了关于C++InteropwithP/Invoke的各种MSDN页面here和here但我仍然很困惑。我有一些大型double组需要进入native代码,还有一些结果数组需要返回。我事先不知道输出数组的大小。为简单起见,我将在示例中仅使用一个数组。平台是x64;我读到32位和64位环境之间的内部编码非常不同,因此这可能很重要。C#[DllImport("NativeLib.dll")]publicstaticexternvoidComputeSomething(double[]inputs,intinlen,[Out]outIntPtroutputs,[Out]outinto

c++ - Objective-C 中的非规范化 float ?

StackOverflow问题/答案的相关性是什么Whydoeschanging0.1fto0slowdownperformanceby10x?用于Objective-C?如果有任何相关性,这应该如何改变我的编码习惯?有什么方法可以关闭MacOSX上的非规范化float吗?这似乎与iOS完全无关。对吗? 最佳答案 正如我在回复您的评论时所说:itismoreofaCPUthanalanguageissue,soitprobablyhasrelevanceforObjective-Conx86.(iPhone'sARMv7doesn'

C++ 函数在 double 组中查找最大值?

我经常发现自己编写最大值函数来搜索double组,我使用这些函数在图形显示之前对数据进行标准化。有没有更好的方法来找到double组的最大值?是否有标准函数来查找数组中的最大值?这个操作有什么内在的吗?我记得DSP芯片中存在专门的ASM指令。 最佳答案 是的!有一个函数叫做std::max_element:doublearr[LENGTH]=/*...*/doublemax=*std::max_element(arr,arr+LENGTH);您需要#include去做这个。该header中有一大堆好东西,值得花时间了解更多有关STL

c++ - 快速将 2 个 double 数组交织成具有 2 个 float 和 1 个 int(循环不变)成员的结构数组,并使用 SIMD double->float 转换?

我有一段代码是在x86处理器上运行的C++应用程序的瓶颈,我们从两个数组中获取double值,转换为float并存储在结构数组中。这是一个瓶颈的原因是它被调用时有非常大的循环,或者被调用了数千次。是否有使用SIMDIntrinsics执行此复制和强制转换操作的更快方法?我看过thisansweronfastermemcpy但没有解决类型转换问题。简单的C++循环情况如下所示int_iNum;constunsignedint_uiDefaultOffset;//aconstantdouble*pInputValues1;//arrayofdoublevalues,count=_iNum;

c++ - void*字面意思是float,怎么投?

所以我在我的C++应用程序中使用这个C库,其中一个函数返回void*。现在我不是纯C语言最敏锐的人,但听说void*可以转换为几乎任何其他*类型。我也知道我希望在这个函数的末尾某处有一个float。所以我将void*转换为float*并取消引用float*,崩溃。该死的!我调试了代码,并在gdb中让它评估(float)voidPtr和low并且看到这个值是我期望和需要的!但是等一下,在编译期间是不可能的。如果我写floatnumber=(float)voidPtr;它不会编译,这是可以理解的。那么现在的问题是,我如何让我的漂浮物脱离这个该死的空洞*?编辑:多亏了H2CO3,这个问题已经

c++ - 如何检查存储为字符串的数字( double 类型)是否是 C++ 中的有效 double ?

我在使用C++编写的程序时遇到问题。我要求用户输入一个有效数字。我把它当作一个字符串,因为我正在做的特定任务,从长远来看会让它变得更容易。对于基本错误检查,我想检查输入的数字是否是有效数字。示例:Enternumber:3.14ThiswouldbevalidEnternumber:3.1456.365.12Thisshouldn'tbevalid 最佳答案 使用strtod,它将字符串转换为double并返回它无法解释为double的一部分的任何字符。doublestrtod(constchar*nptr,char**endptr

【json异常】json.decoder.JSONDecodeError: Expecting property name enclosed in double quotes

异常介绍异常内容json.decoder.JSONDecodeError:Expectingpropertynameenclosedindoublequotes出现原因这个错误一般是由于在解析json的字符串的时候,提供的字符串不符合规范而导致的。根据json的格式要求,其属性名必须使用双引号("),不可以使用单引号(')这里有的使用者可能非常困惑,凭什么json不允许使用单引号呢?这不合理,应该允许使用单引号才对!但是,json的规范就是这样规定的,这可能是考虑到一致性,可移植,或者单纯就是历史原因(最早json源自于javascript的对象字面量,实际上javascript最初就是规定应