zhechong 发表于 2011-8-17 21:59:04

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

程序挺简单,通过按键每次增加/减少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=V_Temp/10+'0';
       Vout='.';
       Vout=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;
       }

i55x 发表于 2011-8-17 23:05:57

别用浮点数不就完了吗?

zhechong 发表于 2011-8-18 00:11:29

回复【1楼】i55x
-----------------------------------------------------------------------

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

yangsen 发表于 2011-8-18 06:59:48

无语,放大10倍,用整数。显示的时候分别取出个十百千位,自己定好哪一位是小数位

millwood0 发表于 2011-8-18 07:01:16

"困惑啊"

you never took numerical analysis in college.

or your programming teacher sucks.

zhechong 发表于 2011-8-18 07:55:57

回复【3楼】yangsen
-----------------------------------------------------------------------
不知你注意到没,在送到液晶显示时,我已经放大了十倍

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

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

ioro55555 发表于 2011-8-18 08:10:13

浮点数也有精度啊,怎么不四舍五入?V_Temp=(int)((i+0.5)*10);

zhechong 发表于 2011-8-18 08:27:00

回复【6楼】ioro55555
-----------------------------------------------------------------------

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

again 发表于 2011-8-18 08:41:26

楼主去了解下浮点数到底是怎么存储的就会很明白

yylooker 发表于 2011-8-18 09:17:38

问题能解决,不用浮点数即可。,
但是我也不懂为什么1.799扩大10倍强制转换后是18,1.599扩大十倍强制转换后却是15了???

lxx_sea_sky 发表于 2011-8-18 09:46:21

同意LS,浮点数是有精度限制的。

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

zhechong 发表于 2011-8-18 09:51:03

回复【8楼】again
-----------------------------------------------------------------------

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

lxx_sea_sky 发表于 2011-8-18 10:20:41

D/A = 1.599x时,i = 1.5999999x;截尾取整后显示 1.5
D/A = 1.799x时,i = 1.8000000x;截尾取整后显示 1.8
页: [1]
查看完整版本: IAR的浮点运算和强制转换为什么会这样?