博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
浮点运算的优化
阅读量:6548 次
发布时间:2019-06-24

本文共 603 字,大约阅读时间需要 2 分钟。

转自:

比如对于代码

int x,y;
...
y=(x+1)+(2*x-2);
那么我们很清楚,编译器可以将上面的代码优化为
y=3*x-1;//实际上还会优化为y=(x<<1)+x-1
可是如果换成浮点类型呢?比如
double x,y;
...
y=(x+1)+(2*x-2);
呢?这时候,标准编译选项下面,编译器不会做任何优化。
这个是因为,对于浮点数做的任何优化都是不安全的。
比如一个程序中可能会使用
while(err+1.0!=1.0){
   ....
   err=...;
}
来判断err是不是相对于1.0很小,
但是如果编译器将两边的1.0都优化了,变成
while(err!=0.0){
   ....
   err=...;
}
那么代码语义就发生变化了。
所以现在的编译器一般来说,对于浮点数相关的运算都是基本不做优化的,唯一可以做的优化就是除上一个常数可以优化为乘上一个常数。
比如x/2.0可以优化为x*0.5
 

当然,很多编译器会提供一些特殊的编译选项,使得用户可以利用这个选项对于某些浮点运算进行强制优化,当然这样的优化就不一定安全了,比如gcc中可以使用

  -ffast-math

编译选项强制对浮点运算使用不符合IEEE浮点标准的优化(比如上面的交换律等)

转载于:https://www.cnblogs.com/CYP01/archive/2012/10/27/2742989.html

你可能感兴趣的文章
AD的备份与还原
查看>>
我的友情链接
查看>>
和第三代动词算子式代码生成器光配合的前后端分离示例代码
查看>>
502 Bad Gateway 错误的解决办法
查看>>
StringIO和cStringIO模块
查看>>
微信开发
查看>>
get语句
查看>>
JSP的6种基本动作介绍
查看>>
基于xterm.js的webssh实现
查看>>
rspec的一些基本
查看>>
convirt(二)—— 创建第一台虚机
查看>>
足球——2011-2012意甲球队队标
查看>>
mysql性能优化
查看>>
网站出现安全证书过期的原因
查看>>
我的友情链接
查看>>
wordpress 登录实例(一)
查看>>
内网IT风险管控解决方案
查看>>
卡巴斯基端点安全10.0针对ESET5.x主要竞争优势
查看>>
Java基础学习总结(7)——Object类
查看>>
Vim编辑器的使用
查看>>