草庐IT

GL_FLOAT

全部标签

c++ - GNU C++ 中程序的奇怪行为,使用 float

看看这个程序:#include#includeusingnamespacestd;typedefpaircoords;doubledist(coordsa,coordsb){returnsqrt((a.first-b.first)*(a.first-b.first)+(a.second-b.second)*(a.second-b.second));}intmain(){coordsA=make_pair(1,0);coordsB=make_pair(0,1);coordsC=make_pair(-1,0);coordsD=make_pair(0,-1);cerr.precision(2

c++ - 强制转换和赋值真的会剥夺 float 的额外精度吗?

我正在通读newC++FAQ我看到即使x==y为doublex,y;也有可能:std::cos(x)==std::cos(y)评估为false。这是因为机器可以有一个支持扩展精度的处理器,例如==的一部分是64位数字,而另一部分是80位数字。但是,下一个例子似乎不正确:voidfoo(doublex,doubley){doublecos_x=cos(x);doublecos_y=cos(y);//thebehaviormightdependonwhat'sinhereif(cos_x!=cos_y){std::cout据我readonen.cppreference.comhere:Ca

c++ - 为什么这种访问冲突会发生在/Og 和/GL 标志上,并带有传递引用?

当(且仅当)我使用WindowsServer2003使用/Og和/GL标志编译我的程序时DDKC++编译器(它在WDK7.1和VisualStudio2010上很好!),我在运行时遇到访问冲突:#include#includetemplateboolless(Ta,Tb){returnas;for(inti=0;i);}当我将最后一行更改为时,访问冲突消失std::stable_sort(s.begin(),s.end(),&less);--换句话说,当我让我的项目被复制而不是仅仅被引用时,它就会消失。(我没有进行任何类型的多线程。)为什么会发生这样的事情?我是否通过const&调用了

c++ - Visual Studio 调试与发布版本 : comparing int and float missmatch

看看这个例子:#includeintmain(){inti=16777217;floatf=16777216.0;floatg=i;if(i==f)printf("eq\n");elseprintf("neq\n");if(g==f)printf("eq\n");elseprintf("neq\n");return0;}在Release模式、gcc或g++(4.9.2)中使用VisualStudio2010C++(VS),具有输出eqeq这对我来说是合理的:在第一次比较期间,i被隐式转换为float,其中尾数中的有效位被截断。因此,i和f都具有相同的位模式,相当于相等性。在第二个if中

c++ - float 类型的默认参数 = 乱码

我在使用float类型的默认参数时遇到了一些问题:#include#includetemplatevoidfun(Tt=1e-05);templateinlinevoidfun(Tt){std::cout();_getwch();return0;}它打印-1.36867e-033而不是1e-05的等价物。这是怎么回事?我正在使用VC++10。编辑1:谢谢大家的回复。但转换默认参数在以下情况下不起作用:templatevoidfun(Tt=static_cast(1e-05));templateinlinevoidfun(Tt){std::wcout();fun();_getwch();

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++ - 如何在QT中实时更新GL()

我想知道以固定的计时器间隔调用updateGL()是否会减慢渲染过程。所以,我想尝试实时渲染。我没有让它自动执行的功能。有人知道吗?其次,我在我的程序中注释了updateGL(),CPU使用率降低到1%和0%。现在,当我点击显示小部件时,它会跳到14%,为什么?GPU不是在做所有的渲染工作吗?如果是,为什么CPU跳到14?我该如何解决这个问题? 最佳答案 是的,你可以做到实时,没有撕裂(例如,以恰好60fps的速度重新绘制,显示器的刷新率)。为此,您必须启用V_sync,并使用间隔为0的QTimer计时器;。启用V_sync将使自动

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

c++ - Qt creator 添加外部库(还是: Cannot open include file: 'GL/glew.h' )

我按照说明操作:在“项目”Pane中,打开项目文件(.pro)。在代码编辑器中右键单击以打开上下文菜单并选择“添加库...”。然后将以下行添加到pro文件中:win32:CONFIG(release,debug|release):LIBS+=-L$$PWD/D:/OpenGL/glew-1.5.4/lib/-lglew32else:win32:CONFIG(debug,debug|release):LIBS+=-L$$PWD/D:/OpenGL/glew-1.5.4/lib/-lglew32dINCLUDEPATH+=$$PWD/D:/OpenGL/glew-1.5.4/include