草庐IT

USE_DOUBLE

全部标签

c++ - 将 float 转换为 double 并返回 float 在 C++ 中给出相同的值吗

假设在下面的代码中floatf1=...;doubled1=static_cast(f1);floatf2=static_cast(d1);ASSERT(f1==f2);变量f1被初始化为非NaN的值。那么断言是否保证符合C++标准? 最佳答案 这里有一些线索,但不是答案:4.6Aprvalueoftypefloatcanbeconvertedtoaprvalueoftypedouble.Thevalueisunchanged.Thisconversioniscalledfloatingpointpromotion....4.8Ap

c++ - float、double 和 long double 是否有保证的最小精度?

从我之前的问题“Isfloatingpointprecisionmutableorinvariant?”我收到了一个response其中说,CprovidesDBL_DIG,DBL_DECIMAL_DIG,andtheirfloatandlongdoublecounterparts.DBL_DIGindicatestheminimumrelativedecimalprecision.DBL_DECIMAL_DIGcanbethoughtofasthemaximumrelativedecimalprecision.我查看了这些宏。它们位于标题中。.来自cplusplusreference

c++ - 比较一个 32 位 float 和一个 32 位整数而不转换为 double 值,当任一值可能太大而无法完全适合另一种类型时

我有一个32位floatf我需要转换为32位无符号整数的数字(已知为正数)。它的大小可能太大而不适合。此外,下游计算需要一些净空。我可以计算最大可接受值m作为32位整数。如果f,我如何在受约束的32位机器(ARMM4F)上有效地确定C++11数学上。请注意,这两个值的类型不匹配。以下三种方法各有其问题:static_cast(f):我认为这会触发未定义的行为,如果f不适合32位整数f(m):如果m太大而无法准确转换,转换后的值可能大于m使得后续比较在某些边缘情况下会产生错误的结果static_cast(f)(m):在数学上是正确的,但需要强制转换为double并使用double,出于效

c++ - 预处理器 "invalid integer constant expression"比较 int 和 double

在我的代码中的某处,我有预处理器定义#defineZOOM_FACTOR1我在另一个地方#ifdefZOOM_FACTOR#if(ZOOM_FACTOR==1)#defineFONT_SIZE8#else#defineFONT_SIZE12#endif#else#defineFONT_SIZE8#endif问题是当我将ZOOM_FACTOR值更改为float值时,例如1.5,出现编译错误C1017:无效的整数常量表达式。有谁知道我为什么会收到这个错误,有没有办法在预处理器指令中比较integer和floatingpointnumber? 最佳答案

c++ - 错误 : invalid use of member in static member function

我有两个类,这是其中一个的标题:#ifndefWRAPPER_HPP#defineWRAPPER_HPP#includeusingnamespacestd;classWrapper{private://SDL_Surface*screen;public:staticSDL_Surface*screen;staticvoidset_screen(SDL_Surface*_screen);staticvoidset_pixel(intx,inty,Uint8color);staticvoidclear_screen(intr,intg,intb);staticSDL_Surface*loa

c++ - 现代 C 和 C++ : it is possible to use one defined structure for other declared structure?

假设我想制作某种支持加载图形Image的引擎,所以我有structImage;Image*load_image_from_file(...);我不想让外部世界知道Image到底是什么,他们只会处理指向它的指针。但是在engine内部我想使用特定的类型,例如SDL_Surface在SDL中完全定义。我能否以某种方式重新定义此文件的图像,以便编译器在每次看到Image*(宏除外)时都假定为SDL_Surface*?即我想要像typedefstructSDL_SurfaceImage;这样的东西所有的尝试都像usingImage=SDL_Surface;typedefSDL_SurfaceI

c++ - 将 double 组转换为仅具有 double 成员的结构数组而不复制数据

我正在使用第三方C++库在Julia中完成一些繁重的工作。在Julia方面,数据存储在Array{Float64,2}类型的对象中(这大致类似于double的二维数组)。我可以使用指向double的指针将它传递给C++。然而,在C++端,数据存储在名为vector3的结构中:typedefstruct_vector3{doublex,y,z;}vector3;我的快速而肮脏的方法是一个五步过程:在C++端动态分配结构数组将输入数据从double*复制到vector3*做繁重的工作将输出数据从vector3*复制到double*删除动态分配的数组复制大量数据是非常低效的。我可以使用一些神

c++ - 求以 10 为底的 double 的指数和尾数

我需要将double类型的数值分解为:指数和尾数。我发现我可以使用math.h中的frexp()函数来做到这一点。但是,此函数假定基数为2。有什么方法可以让我找到以10为底的指数和尾数——这样返回的尾数和指数都是整数类型。#include#includeintmain(){inte;constdoublex=1024;constdoublefraction=frexp(x,&e);std::printf("x=%.2lf=%.2lf*2^%d\n",x,fraction,e);}我的编译器是:gcc(Ubuntu/Linaro4.6.4-6ubuntu2)4.6.4

c++ - 如何仅使用 math.h 将字符串转换为 double

我正在尝试将字符串转换为double字符串,但由于我正在处理Windowsnative应用程序(如仅链接到ntdll.dll),所以我没有大部分可用的标准库。我可以在math.h中使用基本的FP支持,但基本上就是这样。如何将字符串转换为最接近该字符串中表示的有理数的double? 最佳答案 如果你真的想得到最近的,这个问题就很难了,你需要任意精度的算法来实现这个结果。参见ftp://ftp.ccs.neu.edu/pub/people/will/howtoread.ps例如。 关于c++

c++ - 用迭代器计算矩阵 vector<vector<double>> 的列和?

在之前的帖子中columnvectorwithrowmeans--withstd::accumulate?我问是否有可能使用STL功能来计算矩阵的行均值vector>data(rows,vector(columns));@benjaminlindley的最佳答案不仅是我一直在寻找的,而且是一件美丽的事情。永远充满希望我认为计算列均值会很容易,所以STL等价于vectorcolmeans(data[0].size());for(inti=0;i在每个vector中不计算平均值,但跨所有vector中的相同索引:colmeans[0]==(data[0][0]+data[1][0]+...