草庐IT

表示法

全部标签

c++ - 获取 boost::gregorian::date 的整数表示

来自关于boost::gregorian::date类的boost文档here:"Internallyboost::gregorian::dateisstoredasa32bitintegertype"现在这将是一个很好的、紧凑的方式,比如说,将这个日期存储在一个文件中。但是文档没有指定从对象中提取它的任何方法。问题是:有没有办法获得这个整数表示,以便稍后构造同一类的另一个相等的对象? 最佳答案 day_number()成员函数返回这个。boost::gregorian::dated(2014,10,18);uint32_tnumb

c++ - 有没有办法将表示为字符串的数字转换为其二进制等价物?

所需代码的外壳:#include#includestd::stringstr_to_bin(conststd::string&str){//...}intmain(){std::stringstr="123";std::cout问题标题说明了一切。我已经坚持了一段时间。在STL中有解决方案吗?还是我缺少的简单东西?如果没有,我将如何去做呢?也许你可以指出我的方向?另外,速度也很重要。编辑:数字可以是任意大小(也可以大于longlong),所以std::stoi和std::bitset不在讨论范围内。 最佳答案 您可以使用GMP(GN

c++ - C++ 中的有符号类型表示

在我正在阅读的书中说:Thestandarddoesnotdefinehowsignedtypesarerepresented,butdoesspecifythatrangeshouldbeevenlydividedbetweenpositiveandnegativevalues.Hence,an8-bitsignedcharisguaranteedtobeabletoholdvaluesfrom-127through127;mostmodernmachinesuserepresentationsthatallowvaluesfrom-128through127.我假设[-128;12

c++ - 编译器使用的 double 表示的显式规范

最近遇到visual-c++好像不是IEEE754的问题兼容,而是使用subnormalrepresentation.也就是说,其中的doublefloat没有通常表示的1个符号位、11个指数位和52个显式存储的有效小数位,见下文。由于gcc和clang是兼容的,因此非常需要一致的跨平台行为我想知道是否可以强制visual-c++使用正常表示。或者让gcc和clang使用次正规表示当然也可以解决问题。不同双重表示的问题可以在visual-c++中重现,gcc和clang使用以下代码:#include#includeintmain(){try{std::stod("8.097571188

C++:以十六进制打印 double 的表示形式

是否有一种简单的方法来操作std::cout以便它以十六进制表示形式打印double值?换句话说,相当于:printf("%"PRIx64,*reinterpret_cast(&my_double));为了提供一些背景信息,我有一个程序可以打印数百个浮点结果,我想知道是否有神奇的一行代码可以以十六进制打印所有这些结果。 最佳答案 看看std::hexfloat如果你可以使用C++11示例:doublek=3.14;std::cout打印:0x1.91eb85p+1 关于C++:以十六进制

python - 如何将 3D .obj 对象表示为 3D 数组?

有什么方法可以将3D模型表示为3D数组?是否有任何库将.obj或.blend文件作为输入并给出相同的数组表示?我想我会切片对象并将切片导出为图像。然后我会在opencv中使用这些图像为每个切片构建数组。最后,我将组合所有切片的所有数组,最终得到我的.obj文件的3D数组表示。但我中途放弃了,因为让图像切片彼此对齐是一个痛苦而漫长的过程。是否有任何其他基于索引的表示我可以用来在代码中表示3D模型?3D阵列对我的目的来说非常方便。 最佳答案 Binvox可用于从.obj文件生成3D模型的体素表示。Binvox-rw-py可用于读取和解析

c++ - 能否从指向子对象的指针获得指向完整对象表示元素的指针?

让我们考虑这段代码:inti;intis[10]{};unsignedchar*p=reinterpret_cast(&i);//pdefinedtopointtotheobject-representationofthefirstelementofarrayintsunsignedchar*ps=reinterpret_cast(&is[0]);p+=sizeof(int);ps+=sizeof(int);//nowpspointstotheendofints[0]andppointtotheendofi;p+=sizeof(int);//Undefinedbehavioraccor

c++ - decltype-specifier 表示的类型是什么类型,其表达式是类类型的临时对象的成员?

假设我们有以下声明:structS{inta;};以下简单类型说明符表示的类型是什么?是int还是int&&?decltype(S{}.a)(这个问题旨在解决C++17,但也感谢解决其他版本标准的答案。) 最佳答案 它是int。每[dcl.type.simple]/4:Foranexpressione,thetypedenotedbydecltype(e)isdefinedasfollows:[...]otherwise,ifeisanunparenthesizedid-expressionoranunparenthesizedcl

c++ - 内存中的Opencv Mat表示

我知道在内存中opencv将Mat对象表示为一个大数组。因此,如果我有3个尺寸为200x200的channel垫,那么在内存中它将把这个垫存储在一个大小为3x200x200的数组中。或者更一般地,内存中的任何Mat都将存储为channels*rows*cols。我们可以得到这样的数组double*array=(double)mat.data;假设矩阵是double类型现在我的问题是索引这个数组的方法是什么,例如如果我想访问channelch中的元素,行r和列c是有效的索引array[ch*rows*cols+c*rows+r]或array[ch*rows*cols+r*cols+c]问

c++ - C++ 中最有效的矩阵表示是什么?

希望这道题不是OT。我正在实现VLAD使用VLFeatimplementation的编码器和SIFT来自不同实现的描述符来比较它们(OpenCV,VLFeat,OpenSIFT)。这应该是C++中的高性能应用程序(我知道SIFT效率很低,我正在实现它的并行版本)。现在,VLAD想要将指向一组连续描述符(数学vector)的指针作为输入。关键是通常这个SIFT描述符表示为矩阵,因此更容易管理它们。所以假设我们有一个3个维度的3个描述符矩阵(为了简单起见,我使用这些数字,实际上它是128个维度的数千个描述符):123456789我需要做feedvl_vlad_encode指针指向:1234