草庐IT

double_it

全部标签

c++ - 带有 C++ 模板的 SWIG : undefined symbol

C++模板和SWIG不能很好地结合在一起。当我尝试导入我的模块时出现错误ImportError:./_simple.so:undefinedsymbol:_Z9double_itIiET_S0_我正在使用SWIG1.3。这是一个简单的例子来说明问题://file:simple.htemplateTdouble_it(Ta);//file:simple.cctemplateTdouble_it(Ta){return(2*a);}//file:simple.i%module"simple"%{#include"simple.h"%}%include"simple.h"%template(i

c++ - 当我什至无法进入代码时如何调试 "This application has requested the Runtime to terminate it in an unusual way."?

我有一个C++程序,它在进程启动后立即给出此错误-显然是在任何用户代码执行之前。它仅在启用内联时发生。即使内置了调试符号,我也无法进入代码。当我在VisualStudio中按下F10时,我收到了错误并且程序停止了。我在“调试/异常”中检查了所有异常/检查,但仍然没有休息。通常我会认为这样的事情是由于缺少运行时依赖项造成的,但我很肯定这不是这里的情况(已通过DependencyWalker验证)。编辑:我使用了SteveTownsend对CDB的推荐,现在我能够单步执行程序的预用户代码部分。最终的堆栈跟踪是:Child-SPRetAddrCallSite00000000`0008e308

c++ - 在不同机器之间使用 float / double 时我应该知道什么?

我听说不同CPU上的float/double存在很多问题。如果我想制作一款对所有内容都使用float的游戏,我如何才能确保每台机器上的float计算完全相同,以便我的模拟在每台机器上看起来完全一样?我还担心写入/读取文件或将浮点值发送/接收到不同的计算机。必须进行哪些转换(如果有)?我需要100%确定我的浮点值的计算结果完全相同,因为即使计算结果稍有不同,也会导致完全不同的future。这甚至可能吗? 最佳答案 除了范围限制之外,标准C++没有规定任何关于浮点类型的细节,并且可能某些数学函数(如正弦函数和指数函数)必须正确到一定的精

c++ - 将 vector<int> 分配给 vector<double> 安全吗?

这个问题在这里已经有了答案:C++convertvectortovector(2个答案)关闭去年。要为某个计算初始化变量,我必须从整数数组中为它们赋值。所以我这样做:vectorvd;intai[N];//Filledsomewhereelsevd.assign(ai,ai+N);这适用于gcc4.6.1Linux。但它总是正确的吗?或者我应该回到常青树:vd.resize(N);for(inti=0;i感谢您的澄清!

c++ - 在 C++ 中转换大整数 <-> double

为了好玩,我正在用C++编写自己的长算术库,它已经完成了,我什至用那个库实现了几个Cryptogrphic算法,但仍然缺少一件重要的事情:我想转换double(和float/长double)到我的号码,反之亦然。我的数字表示为一个可变大小的无符号长整型数组加上一个符号位。我试图用谷歌找到答案,但问题是人们很少自己实现这些东西,所以我只找到关于如何使用JavaBigInteger等的东西。从概念上讲,这相当简单:我取尾数,将其移动指数指定的位数并设置符号。在另一个方向上,我截断它以使其适合尾数并根据我的log2函数设置指数。但我很难弄清楚细节,我可以尝试一些位模式并将其转换为double

C++ 编译器错误 "cannot be thread-local because it has non-POD type”“

这个声明:___threadAa;生成此错误:cannotbethread-localbecauseithasnon-PODtypeA在哪里classA{public://functiondeclarationprivate://datamembers};我正在尝试使用命令ogsincludes&ogsmk在Linux上进行编译。我们有静态线程,即在我们的应用程序进入之前,我们知道线程的数量,因此目前的工作是通过声明A的数组来完成的,即Aa[Numberofthreads].我该如何解决这个问题? 最佳答案 假设您使用gcc,线程本

c++ - 模棱两可的调用 : int to double or bool

我有一个参数类,我重载了构造函数以接受bool值或double值。当你给它一个int时,它无法构建:errorC2668:'Parameter::Parameter':ambiguouscalltooverloadedfunctioncouldbe'Parameter::Parameter(std::string,std::string,double)'or'Parameter::Parameter(std::string,std::string,bool)'我相信我有两个选择:使用int默认值重载将我的变量显式转换为double我有很多参数,其中一些是无符号长整型、float等(在多

c++ - Boost 的属性树 : deleting a child knowing its path

是否可以轻松地从通过其路径已知的属性树中删除子项(及其最终的子项)?以下内容autochild=ptree.get_child(path);child.clear();实际上并没有删除子项,只是删除了它的内容。erase成员函数接受一个迭代器或一个键。我不知道有什么简单的方法可以找到与路径对应的迭代器,而无需遍历树。可以通过在点字符处拆分路径并删除剩余部分来找到“根”子级。然而,有没有更容易/更短的方式到达那里? 最佳答案 你可以这样做:ptree.get_child("path.to").erase("child");请注意,这会

c++ - double float 的显示及其比较

序言我正在研究一个为不懂浮点运算的人开发的系统。出于这个原因,float比较的实现不会暴露给使用该系统的人。目前float的比较是这样发生的(由于遗留原因,这不能改变)://Ifeithernumberisnotfinite,dodefaultcomparisonif(!IsFinite(num1)||!IsFinite(num2)){output=(num1==num2);}else{//Getexponentsofbothnumberstodetermineepsilonforcomparisontmp=(OSINT32*)&num1+1;exp1=(((*tmp)>>20)&0x

c++ - 为什么我的 double 可以包含低于机器 epsilon 的值?

我正在使用double求解一个方程,我得到的是-7.07649e-17而不是0。我同意它非常接近,我可以说它是相等的,但是I'vereadthatthemachineepsilonfortheC++doubletypeis2^-52这比我得到的值大。那么为什么我的值比机器epsilon低?为什么该值不四舍五入为零?这没什么大不了的,但是当我进行逻辑测试时,我的值似乎不为零... 最佳答案 这个故事中有两个不同的常量。一个是epsilon,它是一个最小值,当添加到1.0时会产生不同于1.0的值。如果将较小的值添加到1.0,您将再次得到