OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 28885|回复: 8

有关STM32浮点数运算的问题

[复制链接]

5

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
60
金钱
60
注册时间
2011-10-18
在线时间
4 小时
发表于 2011-10-18 16:05:54 | 显示全部楼层 |阅读模式
我在keil C编写这样的测试程序
float a;
u8 b;
a=10.08;
b=(int)a;
a=a-b;

理论上a=0.08,在调试中变量查看为0,我把这个a值扩大100倍,用开发板液晶显示出来为7。
为什么调试中变量查看不了小数点后的数?
还有,为什么液晶显示出7来,我怀疑a=a-b,浮点减整形后的值不对。网上查了查,ARM不支持浮点数运算

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

19

主题

121

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
218
金钱
218
注册时间
2011-8-8
在线时间
0 小时
发表于 2011-10-18 17:02:04 | 显示全部楼层
原子的程序里,也这样写。说明还是可以获取小数后的部分的。至于你的为什么变成了“7”那就神奇了。
void uart_init(u32 pclk2,u32 bound)
{    
float temp;
u16 mantissa;
u16 fraction;    
temp=(float)(pclk2*1000000)/(bound*16);//得到USARTDIV
mantissa=temp;  //得到整数部分
fraction=(temp-mantissa)*16; //得到小数部分  
    mantissa<<=4;
mantissa+=fraction; 
RCC->APB2ENR|=1<<2;   //使能PORTA口时钟  
RCC->APB2ENR|=1<<14;  //使能串口时钟 
GPIOA->CRH=0X444444B4;//IO状态设置
  
RCC->APB2RSTR|=1<<14;   //复位串口1
RCC->APB2RSTR&=~(1<<14);//停止复位        
//波特率设置
  USART1->BRR=mantissa; // 波特率设置  
USART1->CR1|=0X200C;  //1位停止,无校验位.
#ifdef EN_USART1_RX   //如果使能了接收
//使能接收中断
USART1->CR1|=1<<8;    //PE中断使能
USART1->CR1|=1<<5;    //接收缓冲区非空中断使能     
MY_NVIC_Init(3,3,USART1_IRQChannel,2);//组2,最低优先级 
#endif
}
世界上有10种人,一种是懂二进制的,另一种是不懂二进制的。。。
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2011-10-18 23:56:09 | 显示全部楼层
回复【楼主位】anstxfw:
---------------------------------
经过我的仿真,当执行过a=a-b;这一句后,a的值变为0.07999992.
就是由于这个原因导致显示为7吧。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

5

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
60
金钱
60
注册时间
2011-10-18
在线时间
4 小时
 楼主| 发表于 2011-10-19 09:10:24 | 显示全部楼层
谢谢原子,那我还敢让这芯片做浮点数运算嘛!我的项目需要精确到小数点后4位呢~
回复 支持 反对

使用道具 举报

0

主题

19

帖子

0

精华

新手上路

积分
46
金钱
46
注册时间
2015-5-13
在线时间
1 小时
发表于 2015-5-20 15:57:08 | 显示全部楼层
回复【4楼】anstxfw:
---------------------------------
别害怕!你只要精度取小数点后5位计算就可以。
回复 支持 反对

使用道具 举报

11

主题

92

帖子

0

精华

初级会员

Rank: 2

积分
131
金钱
131
注册时间
2016-3-27
在线时间
83 小时
发表于 2016-9-6 15:56:58 | 显示全部楼层
anstxfw 发表于 2011-10-19 09:10
谢谢原子,那我还敢让这芯片做浮点数运算嘛!我的项目需要精确到小数点后4位呢~

挖坟挖到了。。我也遇到这个问题了,就是这个原因。。最后怎么解决的
回复 支持 反对

使用道具 举报

1

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
101
金钱
101
注册时间
2013-8-8
在线时间
11 小时
发表于 2017-1-9 11:13:30 | 显示全部楼层
我也遇到过这样的问题,你现在找到原因了?
回复 支持 反对

使用道具 举报

84

主题

766

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2775
金钱
2775
注册时间
2015-6-1
在线时间
394 小时
发表于 2017-1-9 16:44:07 | 显示全部楼层
LTY 发表于 2017-1-9 11:13
我也遇到过这样的问题,你现在找到原因了?

浮点运算可以,但是不能整形和浮点混在一起算,float型运算会保留7位有效数字,double会保留15位有效数字。其它位数全是错的。
自在随心
回复 支持 反对

使用道具 举报

1

主题

4

帖子

0

精华

新手入门

积分
6
金钱
6
注册时间
2017-10-19
在线时间
0 小时
发表于 2017-10-19 23:27:36 | 显示全部楼层
  //#if (__FPU_PRESENT == 1) && (__FPU_USED == 1)
    SCB->CPACR |= ((3UL << 10*2)|(3UL << 11*2));  /* set CP10 and CP11 Full Access */
  //#endif  这个也设置了。

我快被浮点搞疯了    exp(2.0) 这个怎么也不对。   最简单的 0.1 + 100.1 如果是double precison,结果也不对。非要float才行。
但是mdk已经设置了double precison
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-9 01:02

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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