搜索
bottom↓
回复: 12

IAR的浮点运算和强制转换为什么会这样?

[复制链接]

出0入0汤圆

发表于 2011-8-17 21:59:04 | 显示全部楼层 |阅读模式
程序挺简单,通过按键每次增加/减少0.1,控制D/A的输出,并在12864上显示当前D/A输出,下面是main函数里的while循环部分。通过仿真我发现,这每次加/减0.1,实现上每次加上或减去的是一个比0.1要稍大的浮点数,当增加到2然后过渡到0,再从0回到2,一直往下减的时候,我就哭爹了,每次减到1.7时液晶就直接跳到1.5,没有1.6,而D/A输出的却是1.6,我把鼠标放到“i”上观察到的是1.5999几,具体记不清了,然后放到“V_Temp”上观察到的是15,按理说强制转换后这正常,可为什么在1.7之前它们又是一样呢?困惑啊!!!
程序如下:
while(1)   
    {   
  
     //   DA_IN(Volt_Data(IN_2048,i));    //选用内部基准2.048V

       DA_IN(Volt_Data(IN_1024,i));    //选用内部基准1.024V
       V_Temp=(int)(i*10);
       Vout[0]=V_Temp/10+'0';
       Vout[1]='.';
       Vout[2]=V_Temp%10+'0';
       Disp_HZ(0x80,Vout,2);
       switch(P1IN&0x0f)
       {
          case 0x0e:
                     do
                     {
                     }while((P1IN&0x0f)!=0x0f);
                     if(i<2)
                      i+=0.1;
                     else
                       i=0;
                     break;
            
                     
          case 0x0d:
                      do
                      {
                      }while((P1IN&0x0f)!=0x0f);
                      if(i>0)
                        i-=0.1;
                      else
                        i=2;
                      break;
       }

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2011-8-17 23:05:57 | 显示全部楼层
别用浮点数不就完了吗?

出0入0汤圆

 楼主| 发表于 2011-8-18 00:11:29 | 显示全部楼层
回复【1楼】i55x
-----------------------------------------------------------------------

不用浮点的话,程序与界面显示就没办法达到直观了,有没有其他解决方法啊

出0入0汤圆

发表于 2011-8-18 06:59:48 | 显示全部楼层
无语,放大10倍,用整数。显示的时候分别取出个十百千位,自己定好哪一位是小数位

出0入0汤圆

发表于 2011-8-18 07:01:16 | 显示全部楼层
"困惑啊"

you never took numerical analysis in college.

or your programming teacher sucks.

出0入0汤圆

 楼主| 发表于 2011-8-18 07:55:57 | 显示全部楼层
回复【3楼】yangsen
-----------------------------------------------------------------------
不知你注意到没,在送到液晶显示时,我已经放大了十倍

回复【4楼】millwood0
-----------------------------------------------------------------------

昨晚和同学讨论下,发现自己写程序时走入了误区,根本就不应该用浮点型变量i,也不该通过强制转换将浮点型转成整型,这个思路就有问题,就像2楼说的,尽量别用浮点数,我这块完全可以通过暂时的整型转浮点型来实现。这个也不能说老师差劲,自己当时就不怎么听课,快考试才拿本书看看,嘿嘿

出0入0汤圆

发表于 2011-8-18 08:10:13 | 显示全部楼层
浮点数也有精度啊,怎么不四舍五入?V_Temp=(int)((i+0.5)*10);

出0入0汤圆

 楼主| 发表于 2011-8-18 08:27:00 | 显示全部楼层
回复【6楼】ioro55555
-----------------------------------------------------------------------

嗯,这样也不错,当时就关注1.799几扩大10倍强制转换后是18,1.599几扩大十倍强制转换后却是15去了,其实换一个思路就好了

出0入0汤圆

发表于 2011-8-18 08:41:26 | 显示全部楼层
楼主去了解下浮点数到底是怎么存储的就会很明白

出0入0汤圆

发表于 2011-8-18 09:17:38 | 显示全部楼层
问题能解决,不用浮点数即可。,
但是我也不懂为什么1.799扩大10倍强制转换后是18,1.599扩大十倍强制转换后却是15了???

出0入0汤圆

发表于 2011-8-18 09:46:21 | 显示全部楼层
同意LS,浮点数是有精度限制的。

LZ运行下:for(f=1.0999999; f<2.0; f+=0.1);
就会发现f值每次自增 0.10000002 ~ 0.10000003

出0入0汤圆

 楼主| 发表于 2011-8-18 09:51:03 | 显示全部楼层
回复【8楼】again
-----------------------------------------------------------------------

刚稍微看了一下,明白了为什么加/减0.1,加/减的是一个比0.1稍大的数,可是却依然不懂“1.799几扩大10倍强制转换后是18,1.599几扩大十倍强制转换后却是15”,大虾能否再给我讲讲?

出0入0汤圆

发表于 2011-8-18 10:20:41 | 显示全部楼层
D/A = 1.599x时,i = 1.5999999x;截尾取整后显示 1.5
D/A = 1.799x时,i = 1.8000000x;截尾取整后显示 1.8
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-5-19 00:31

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表