草庐IT

BINARY_DOUBLE

全部标签

c++ - std::binary_function - 调用不匹配?

包括#includeusingnamespacestd;intmain(){binary_functionoperations[]={plus(),minus(),multiplies(),divides()};doublea,b;intchoice;cout>a>>b;cout>choice;cout我得到的错误是:Calcy.cpp:Infunction‘intmain()’:Calcy.cpp:17:error:nomatchforcallto‘(std::binary_function)(double&,double&)’谁能解释为什么我会收到此错误以及如何消除它?

c++ - 以二进制形式打印 double

在BruceEckel的“ThinkinginC++”中,给出了一个打印double值的程序以二进制形式。(第3章,第189页)intmain(intargc,char*argv[]){if(argc!=2){cout(&d);for(inti=sizeof(double);i>0;i-=2){printBinary(cp[i-1]);printBinary(cp[i]);}}这里当i=8时打印cp[i](假设double是8个字节),这不是未定义的行为吗?我的意思是这段代码不起作用,因为它不打印cp[0]。 最佳答案 A1:是的,

c++ - 将位设置为 double 并使用 g++ 的优化标志进行编译

我正在尝试将位设置为double(IEEE标准754)。说我想“构建”一个3,我会设置双浮点表示的第51位和第62位,这样我得到二进制1.1*2,十进制为3。我写了这个简单的main:intmain(){doublet;uint64_t*i=reinterpret_cast(&t);uint64_tone=1;*i=((one这个的输出将是88883当使用g++4.3编译并且没有优化时。但是,如果我添加-O2或-O3优化标志,我会得到一个奇怪的行为。也就是说,如果我让main保持原样,我会得到相同的输出。但是,如果我删除输出4sizeof的行,那么我将得到输出0没有sizeof输出的未

c++ - C中double **和double (*)[2]的区别

double**和double(*)[2]有什么区别。如果我理解得很好,double**是指向double指针的指针,因此它可以是任意大小的二维数组,而double(*)[2]是指向double[2]数组的指针.那么如果是对的,如何才能成功传递给函数。例如:voidpcmTocomplex(short*data,double*outm[2])如果我传递double(*)[2]作为参数,我会收到以下警告:warning:passingargument2of‘pcmTocomplex’fromincompatiblepointertypenote:expected‘double**’but

c++ - 具有 double 、 float 和整数数据类型的英特尔 MKL 矩阵产品性能

我正在试验英特尔MKL库,使用它们提供的Boost::uBLAS接口(interface)(包括mkl_boost_ublas_matrix_prod.hpp)执行矩阵乘法。我的数据只是整数,所以我尝试将我的矩阵模板类型更改为int并且性能下降,这似乎主要是由于代码仅使用单个CPU内核而不是我可用的12个。我在MKL文档中找不到任何内容来解释为什么整数没有使用MKL的OpenMP多线程功能(我猜他们根本没有使用MKL?)。此外,与float相比,我发现double的性能下降了50%。问题:为什么float和double之间存在差异?为什么我不能使用整数?这是我从下面的代码中得到的结果:

c++ - C++ 中 double 和 DOUBLE 的区别

我想知道double之间有什么区别?和DOUBLE(来自#include)在C++中。在Java中有很多关于它的问题,但那是一种完全不同的语言。是DOUBLE只是double的Windows包装类,或者是其他东西?它们有什么不同的优势吗? 最佳答案 double是C++关键字,而DOUBLE是实现定义的typedef。例如,如果我将包含在MSVC++的项目中,IDE显示DOUBLE在WTypesbase.h中定义喜欢:typedefdoubleDOUBLE; 关于c++-C++中doub

c++ 将带有 ":"的十六进制字符串转换为原始 "binary"字符串

我有以下代码将加密的密文转换为可读的十六进制格式:std::stringconvertToReadable(std::stringciphertext){std::stringstreamoutText;for(unsignedinti=0;i(ciphertext[i]))这个函数的可读结果是这样的:56:5e:8b:a8:04:93:e2:f1:5c:20:8b:fd:f5:b7:22:0b:82:42:46:58:9b:d4:c1:8e:ac:62:85:04:ff:7f:c6:d3:现在我需要返回,将可读格式转换为原始的密文以便对其进行解密:std::stringconvert

c++ - 模板代码中的 float 或 double

下面的例子可能看起来很荒谬,但它是一个更大的高性能代码的一部分,在这个代码中所介绍的技术是有意义的。我提到这一点是为了防止有人怀疑XY问题——很可能不是。我有一个带有模板化/编译时操作数的函数:templateintmul(intx){returnM*x;}现在我想对double做同样的事情,这是-当然-不允许的:template//youcan'tdothat!intmul(doublex){returnM*x;}所以为了在编译时仍然放入double,我只看到以下解决方案://createmyconstantsstructSevenPointFive{staticconstexprd

c++ - 初始化 std::pair<double, std::array<std::pair<double, double>, 3>>

谁能建议以下代码中std::vector::push_back调用中std::make_pair调用的正确语法:#include#include#includeintmain(){typedefstd::pairPairType;std::vector>>myVector;doubleKey=0.0;PairTypePair1=std::make_pair(1.0,2.0);PairTypePair2=std::make_pair(3.0,4.0);PairTypePair3=std::make_pair(5.0,6.0);myVector.push_back(std::make_pa

c++ - 在不丢失信息的情况下将 double 转换为 int64_t 并返回

这个问题可能有人问过,但我搜索过,找不到答案。我正在实现一个玩具虚拟机,其中OpCodes采用以下形式:std::tuple//instructionop1,op2我正在尝试将一个double值打包到其中一个操作数中,并在处理它时再次读回它。这不能可靠地工作。doubled=...autoa=static_cast(d);autob=static_cast(a)//sometimes,b!=d有没有办法将double的位表示打包成int64_t,然后读回该位模式以获得与以前完全相同的double? 最佳答案 static_cast执