草庐IT

floating-point-conversion

全部标签

c++ - float 组的更快 abs-max

我需要实时绘制音频的峰值表。每秒最少44100个样本乘以最少40个流。每个缓冲区包含64到1024个样本。我需要从每个缓冲区中获取absmax。(然后这些通过一种低通滤波器馈送并以大约20毫秒的间隔绘制。)for(inti=0;i我现在就是这样做的。我想做得更快。缓冲器在-1到1范围内float,因此是晶圆厂。问题,是否有一些棘手的comp-sciquicksort-esque方法可以更快地完成此操作?否则,float的无分支ABS和MAX函数是否存在?编辑:主要平台是Linux/gcc,但计划了一个Windows端口(可能与mingw一起)。编辑,第二个:我接受了onebyone因为

c++ - 三元运算符在 `int` 和 `float` 上的结果

简而言之,我有以下代码:floatx=cond?0:x_option;其中x_option是一个template,它有一个operatorfloat()(并且没有其他自动转换运算符。注意此转换后表达式的类型:bool?int:float;我希望这个表达式的结果是float:C11:Ifboththesecondandthirdoperandshavearithmetictype,theresulttypethatwouldbedeterminedbytheusualarithmeticconversions,weretheyappliedtothosetwooperands,isthe

c++ - 将 3x1 或 1x3 cv::Mat 转换为 cv::Point3d?

我正在处理一些代码,其中执行大量3x3矩阵乘法以及使用旋转矩阵等对3d点进行一些转换。我决定使用OpenCV核心功能进行数学运算。可以使用最近添加到cv::Mat类的构造函数将cv::Point3d直接转换为3x1cv::Mat大大减少和简化了代码。我现在想知道是否有一种简单的方法可以将3x1或1x3cv::Mat转换为cv::Point3d?我总是可以做类似的事情:cv::Matmat(3,1,CV_64FC1);cv::Point3dp(mat.at(0,0),mat.at(1,0),mat.at(2,0));或cv::Matmat(3,1,CV_64FC1);constdoubl

c++ - 错误 83 错误 C2398 : conversion from 'double' to 'float' requires a narrowing conversion

我找到了很多关于这个错误的帖子,但我可以找到克服它的方法。这是触发错误的代码:voidmain(){floatf{1.3};}为什么在初始化列表中没有像其他变量那样发生转换?例如,这工作顺利:floatf=1.3; 最佳答案 您评论说使用1.3会导致您的编译器出错。这意味着您发现了一个编译器错误。标准很清楚这不是缩小转换,因此应该允许。引用N4140(大致为C++14):8.5.4List-initialization[dcl.init.list]7Anarrowingconversionisanimplicitconversion

java - 从 C++ 切换到 Java : What are the key points?

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭7年前。Improvethisquestion我是一位经验丰富的开发人员,但我的大部分OO编程经验都是使用C++(和一点点Delphi)。我正在考虑做一些Android工作,因此是Java。来自C++背景,Java的哪些领域最有可能让我感到惊讶/烦恼/高兴?我确信这已经被问过了,但我的搜索没有出现类似的问题。当然是CW。

c++ - "points to uninitialised byte(s)"Valgrind 错误

我一直在使用Valgrind来查找我的代码中的内存泄漏,虽然没有发现内存泄漏,但报告了一些错误,所有这些错误都源于单个函数/类方法:==17043==ERRORSUMMARY:10100errorsfrom3contexts(suppressed:0from0)==17043====17043==100errorsincontext1of3:==17043==Syscallparamsocketcall.sendto(msg)pointstouninitialisedbyte(s)==17043==at0x5441DA2:send(send.c:28)==17043==by0x404C

c++ - 为什么 float 变量通过以一种奇怪的方式在点后切割数字来保存值?

我有这个简单的代码行:floatval=123456.123456;当我打印此val或查看范围时,它存储值123456.13好吧,没关系,它不能只用4个字节存储点之后的所有数字,但为什么它在点之后是13?不应该是12吗?(在win32上使用vc++2010express) 最佳答案 在二进制中,123456.123456是11110001001000000.000111111001...(无穷大)。它四舍五入为11110001001000000.001,即123456.125。打印时四舍五入为123456.13。

c++ - 如何强制 pow(float, int) 返回 float

重载函数floatpow(floatbase,intiexp)在C++11中被移除,现在pow返回一个double。在我的程序中,我正在计算很多这些(单精度),我对最有效的方法很感兴趣。是否有一些具有上述签名的特殊函数(在标准库或任何其他函数中)?如果不是,在任何其他操作(这将转换所有其他内容)之前将pow的结果显式转换为float是否更好(就单精度性能而言)转换成double)或者将iexp转换成float并使用重载函数floatpow(floatbase,floatexp)?编辑:为什么我需要float而不使用double?主要原因是RAM——我需要数十或数百GB,因此这种减少是巨

c++ - 如何计算 32 位 float epsilon?

GameEngineArchitecture一书中:“...,假设我们使用一个浮点变量来跟踪以秒为单位的绝对游戏时间。在我们的规模达到之前我们可以运行游戏多长时间时钟变量变得如此之大,以致于向它添加1/30秒不再改变它的值?答案大约是12.9天。”为什么是12.9天,如何计算? 最佳答案 当无法精确表示浮点计算的结果时,会将其四舍五入为最接近的值。所以你想找到最小值x使得增量f=1/30小于h之间的宽度的一半x和下一个最大的float,这意味着x+f将舍入到x。因为同一binade中的所有元素的间隙都相同,我们知道x一定是它的二进制

java - 将 float 组划分为相似的段(聚类)

我有一个像这样的float组:[1.91,2.87,3.61,10.91,11.91,12.82,100.73,100.71,101.89,200]现在,我想像这样划分数组:[[1.91,2.87,3.61],[10.91,11.91,12.82],[100.73,100.71,101.89],[200]]//[200]将被视为异常值,因为集群支持较少我必须为多个数组找到这种段,但我不知道分区大小应该是多少。我尝试使用hierarchicalclustering(Agglomerative)来做到这一点它给了我满意的结果。然而,问题是,我被建议不要对一维问题使用聚类算法,因为它们没有理