浮点数 C语言 IEEE754
创始人
2024-01-25 01:39:09
0

知识内化:用自己的语言讲述一遍,把复杂的东西解释得简单透彻

计算机表示浮点数的问题:(自己分析一下这个问题)

输入是:任意一个浮点数,正无穷到负无穷,包括整数部分和小数部分 22222.99999999

限制是:计算机只有32bit来表示一个浮点数

输出是:如何利用这32bit来表示浮点数,尽可能范围大,精度高

方案探索

像科学计数法一样,10^20 =1e10不用自己用20个十进制的位来写,而是写成1.0*10^20

也就是科学计数法可以只写小数部分指数部分,来表示一个范围更大的数,原来的计数方法是通过乘法和加法来表示一个数,现在是通过指数来表示,因此更少的bit可以表示更大的数

原来的方案:4bit   x = [1,2,3,4],  y = [power(2,i) for i in x]=[2,4,8,16],最多表示到16= 2^4

科学计数法的方案: 4bit r= [2,4,8,16] , y = [power(2,i) for i in r]=[4,16, 256, 65536], 最多可以表示 2^16

用画图就可以很快看到两者的区别

 方案细化

接下来的问题是,我们讨论,多少bit给指数,多少bit给小数,精度和范围是多少

本质通用的二进制小数的表示位:类比十进制

 因为编码长度有限,就像十进制不能精确表示1/3,只能表示有限位的十为基底的数,那么二进制小数也只能精确表示以2为底的数,1/5 = 0.2 只能近似表示为 0.125+ 0.0xxxx + xxx+xxx

小数部分(有效数字):23 位给小数,精度可以是 2^{23} \rightarrow (2^{10})^{2.3} \rightarrow ~ (10^3)^{2.3} \rightarrow 10^{6.9}

2^{-23}\rightarrow 10^{-6.9} 大概是1e-6, 1e-7的精度

指数部分(阶码):8位, 带符号的 2^{-128} \rightarrow 2^{127}     ,大概范围是 2^{128}\rightarrow (2^{10})^{12.8}\rightarrow (10^{3})^{12.8}\rightarrow 10^{ 38.4}  大概是 10的正负38次方

符号位:1位

一般表示:1.001101 *2^n 

问题:

  • 0怎么表示
  • 正负无穷怎么表示
  • 一般数字怎么表示
  • NaN 怎么表示(无效数字,不合法,比如除以0)

针对这个问题提出的解决方案,根据exp分成3中情况,全0,全1,非0非1

再分别看三种情况

1.第一种情况,本来8bit可以表示0~255,扣除全零全一,剩下1~254,我们默认偏移127, 得到-126~+127。 小数部分 M=1+f, 隐藏1开头的

 2. 第二种情况,指数为0,小数部分M=f  可以表示0,要意识到一个问题就是,ieee754的浮点数有两个0的表示,+0,-0

3.第三种情况:特殊值:正负无穷,NaN

下面的图是float8 e4m3

但有时候要跳出来,比如ieee754为什么NaN不定义为全为1,这样还可以释放exp=1111的情况、我在fp8的定义中就看到这个这个释放

float8 in DL

最近一个同事问我,为什么浮点计算遇到reduction不能自动向量化,提升unsfe,会改变计算顺序,我写出了下面这个demo. 本质是unroll 4就改变了计算顺序,和zhi'l

#include int main()
{float f1 = -1e10f;float f2 = 1e-3f;float s = 1e10f;s = s + f1;s = s + f2;float p = 1e10f;float temp = (f1 + f2);p = p + temp;printf("s=%f, p = %f\n", s, p); // 0.001    p = 0return 0;
}

 最后再 v[0]+=v[1]  

            v[0]+=v[2]

           v[0]+=v[3]

s就是v[0]

mitchell近似乘法计算

expbias= 127 = 0 0111 1111 +0*23

               = 0011 1111 1000 0000 0000 0000 0000

              = 0x3f80000

    float a = 12.3f;float b = 4.56f;int c = *(int*)&a + *(int*)&b - 0x3f800000;printf("近似结果:%f\n", *(float*)&c);printf("精确结果:%f\n", a * b);return 0;

如何操作浮点数的bit, 这里有一个链接:https://github.com/myisabella/datalab/blob/master/bits.c#L350

example

​​​​​​​

 

有效数字

#include 
int main()
{float a = 1e8;float b = a + 1.0;float c = b - a;printf("%f %f %f\n", a, b, c); // 1e8 结果为0,1e7,结果为1,有效数字
}

相关内容

热门资讯

从输钱到包赢!经典联盟金花想要... 您好:经典联盟金花可以开挂,确实是有挂的,很多玩家在经典联盟金花中打牌都会发现很多用户的牌特别好,总...
给大家一一科普欢乐龙城3辅助插... 欢乐龙城3神器是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,欢乐龙城3可以一键让你轻...
绝对包赢!!同城游麻将开挂原理... 绝对包赢!!同城游麻将开挂原理特点-)辅助插件设置牌型插件核心提示:1.通过添加客服微信需要了解加薇...
40 岁做什么工作好?这三大行... 40 岁,一个承载着人生厚重阅历的年纪。在这个阶段,很多人开始思考自己的职业规划,寻求一个稳定且有发...
农村乡镇开店做什么生意好?三大... 随着我国经济的快速发展,农村乡镇地区的消费水平和需求也在不断提高。很多有创业梦想的朋友可能都在思考:...
三个月宝宝的宝妈吃什么对宝宝好... 随着宝宝的出生,每个妈妈都希望给他们提供最好的营养,尤其是在三个月这个关键时期。那么,三个月宝宝的宝...
2022 年实体店做什么项目好... 随着 2022 年的到来,很多实体店经营者都在思考:今年做什么项目好?如何才能在竞争激烈的市场中脱颖...
优秀创业团队的共同特点的是:揭... 一、引言在创业的道路上,有些人孤军奋战,有些人抱团取暖。而那些最终走向成功的创业团队,身上似乎都散发...
个人创业贷款三年贴息:助力实现... 在当今社会,个人创业已经成为很多人实现财富自由和实现自我价值的重要途径。然而,启动资金往往是横亘在创...
五行属木的人,适合做什么生意?... 首段: 五行属木的人,性格如同绿树般生机勃勃,他们善良、有耐心,具有极强的生命力。那么,这样的人适...