0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

浮点数基础知识科普

汽车玩家 来源: FPGA开源工作室 作者:lee 2020-03-08 17:26 次阅读

浮点数,是属于有理数中某特定子集的数的数字表示,在计算机中用以近似表示任意某个实数。具体的说,这个实数由一个整数或定点数(即尾数)乘以某个基数(计算机中通常是2)的整数次幂得到,这种表示方法类似于基数为10的科学计数法。

1 、浮点数基础知识

浮点数基础知识科普

浮点数由四部分构成:符号位(Sign Bit)、尾数(Mantissa)、基数(Radix)和指数(Exponent)。根据《IEEE Standard 754 for Binary Floating-Point Arithmetic》的定义–二进制标准浮点数,基数为2。s、m、e分别为符号数、尾数和指数,n为相应的浮点数值。

IEEE-754规定了三种浮点数:单精度(float)、双精度(double)和扩展精度。

其中单精度为32bit,其中包含1位符号位S,8位指数位E和23位尾数位M。S、E、M为相应的二进制序列。

浮点数基础知识科普

S:

正数 0.1xxxxxx

负数 1.1xxxxxx

M:

表示小数点之后的二进制尾数。

M为0110表示:二进制.0110

E:

规格化(normalized)

非规格化(denormalized)

2 、规格化浮点数

E表示的二进制不全为0也不全为1时该浮点数为规格化浮点数。

e表示偏置(Biased)

|E|表示E的二进制整数

bias表示偏置

k为指数位宽

对于单精度浮点数来说k为8,所以bias为127。E=“10001000”为例,|E|=136,故e为9。

对于规格化浮点数,标准规定尾数位小数点左侧的隐含位为1,所以:

m = |1.M|

例如M=“10010…0”则1.M=“1.10010…0”所以m=1.5625

浮点数基础知识科普

s=0

m = 1.5625

e =9

n =55.5112

单精度浮点数的公式可表示为:

浮点数基础知识科普

3、非规格化浮点数

E的二进制位全为0时该浮点数为非规格化浮点数。

bias=127

单精度非规格化浮点数公式:

-0.0 符号位为1,其余位为0.

+0.0全部为0.

4、特殊数值

E的二进制位全为1时为特殊数值。

M全0,n无穷大

M全1,S为1,n负无穷大

M全1,S为0,n正无穷大

M不全为0和1,n NaN(Not a Number)

浮点数基础知识科普

5 、双精度浮点数

IEEE-754定义双精度浮点数共64bit 。1位符号位S,11位指数位E和52位尾数位M。同样可以划分为规格化、非规格化和特殊数值。

浮点数基础知识科普

浮点数基础知识科普

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 计算机
    +关注

    关注

    19

    文章

    6652

    浏览量

    84563
  • 浮点数
    +关注

    关注

    0

    文章

    58

    浏览量

    15793
收藏 人收藏

    评论

    相关推荐

    一文带你秒懂IEEE 754浮点数

    一、简介1、常见的浮点数表示方式是IEEE754标准,它规定了浮点数的存储格式和运算规则,这个标准定义了两种浮点数表示:单精度和双精度。2、任何一个浮点数的二进制数可以写为:NUM
    的头像 发表于 03-18 08:09 917次阅读
    一文带你秒懂IEEE 754<b class='flag-5'>浮点数</b>

    modbus浮点数怎么读取

    Modbus是一种通信协议,常用于工业自动化系统中的设备之间的通信。它支持多种数据类型,包括整数、浮点数、字符串等。浮点数在工业领域中广泛应用,因此了解如何读取和处理Modbus浮点数是非
    的头像 发表于 12-28 14:38 1701次阅读

    单精度和双精度浮点数的区别

    单精度和双精度是计算机中表示浮点数的两种不同的精度。在计算机中,浮点数用来表示带有小数部分的实数,而单精度和双精度用来表示浮点数的精确程度不同。在以下文章中,我将详细介绍单精度和双精度浮点数
    的头像 发表于 12-15 10:25 2604次阅读

    单精度和双精度浮点数的区别

    在计算机科学和数值计算中,浮点数是一种用于表示实数的数据类型。浮点数有两种精度级别:单精度和双精度。这两种精度级别在表示范围、精度和存储空间等方面都有所不同。本文将详细介绍单精度和双精度浮点数的区别
    的头像 发表于 12-13 10:55 1509次阅读

    缝缝补补的浮点数进制转换器

    [浮点数]()在计算机科学中是一种重要的数据类型,用于表示实数。其中,FP32和FP16是两种常见的浮点数格式,分别占用32位和16位。
    的头像 发表于 12-04 14:00 444次阅读
    缝缝补补的<b class='flag-5'>浮点数</b>进制转换器

    西门子PLC浮点数程序案例分享

    64位浮点数保存于VB0开始的存储区中,转换得出的32位浮点数保存于VD100中。
    发表于 10-27 17:07 1439次阅读
    西门子PLC<b class='flag-5'>浮点数</b>程序案例分享

    怎么提高单片机的浮点数运算速度?

    有什么比较好的方法可以提高浮点数运算速度
    发表于 10-15 11:07

    为什么MCU不建议用浮点数运算?

    为什么大部分变量都是整数型,而很少用浮点数运算
    发表于 10-13 08:27

    浮点数的运算怎么转换成整数运算?

    浮点数的运算怎么转换成整数运算
    发表于 10-12 06:31

    MCU中双精度浮点数是用什么格式存储的?

    MCU中双精度浮点数是用什么格式存储的
    发表于 10-11 06:24

    点数浮点数的概念 浮点数二进制序列与指数表达式之间的转化

    的缺点:由于小数点位置固定不变,定点数所表示的数的范围非常有限,不能同时表达特别大或特别小的数,所以才出现了浮点数,以此来扩充数的范围,同时浮点数也广泛应用于精度要求高的场合。简单的理解浮点数
    的头像 发表于 08-22 16:06 3182次阅读
    定<b class='flag-5'>点数</b>和<b class='flag-5'>浮点数</b>的概念 <b class='flag-5'>浮点数</b>二进制序列与指数表达式之间的转化

    C浮点数与字符转换工具

    C浮点数与字符转换工具免费下载。
    发表于 06-19 18:17 0次下载

    FPGA浮点数表示及计算机数值表示规则

    点数硬件实现简单,但表示的范围有限,且部分的小数运算IP核只支持浮点数运算,因此这里还需要提到浮点数的相关内容。
    发表于 06-16 15:41 992次阅读
    FPGA<b class='flag-5'>浮点数</b>表示及计算机数值表示规则

    西门子PLC读取的仪表数据(浮点数)如何转换为整数

    看到一个网友的问题,西门子200PLC采用MODBUS RTU协议采集多功能仪表的数据,接收的数据均是32位的单精度浮点数,我怎么在PLC程序里面实现单精度浮点数与十进制之间的转换?且问题的配图如下。
    的头像 发表于 06-01 10:18 3330次阅读
    西门子PLC读取的仪表数据(<b class='flag-5'>浮点数</b>)如何转换为整数

    在SCL中使用浮点数REAL和LREAL进行计算

    例如,数据类型 REAL 在程序中以 6 位小数的精度进行指定和计算。在计算浮点数(REAL和 LREAL)时,请注意此精度通常应用于每个计算步骤。
    的头像 发表于 05-30 09:40 963次阅读
    在SCL中使用<b class='flag-5'>浮点数</b>REAL和LREAL进行计算