浮点数的各种最值推算以及对python sys.float_info的解释

2024-03-09 15:18

本文主要是介绍浮点数的各种最值推算以及对python sys.float_info的解释,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

最大和最小的正规约数取值

最小和最大的正非规约数取值

浮点数能在该范围内精确表示的最大十进制整数

大于1的最小规约数和1之间的距离epsilon

对python sys.float_info的解释


       本文将以64位浮点数为例,对64位浮点数的取值范围进行推算,并通过python的sys.float_info的信息,对其逐一解释,以对浮点数有一个更好的理解。本文需要笔者的这篇文章作为预备知识。

最大和最小的正规约数取值

       对于64位整数来说,由于规约数的移码后的指数取值范围为(1~2046)-1023=(-1022~1023),所以移码后的指数最小值为-1022,最大值为1023,对应着最小正规约数和最大正规约数的指数取值情形;对于尾数来说,自然就是当尾数小数部分全部为0和全部为1时,分别取到最小值和最大值,因此根据分析,我们可以通过如下代码进行二进制到十进制的最小最大值的推算。

s = '1'*53+'0'*(1023-52)
f_max = float(int(s,2))
[out]:
1.7976931348623157e+308f_min = float(1/int('1'*1022,2))
[out]:
2.2250738585072014e-308

 

如上代码所示,最大规约数的二进制表示就是隐藏的首位1加52位尾数的1=53个1,然后剩下1023-52位的0,最后通过int函数将该二进制数转为十进制,就可以得到十进制的最大的规约数。同理,对于最小正规约数,就是当尾数全部为0,首位为1,指数为-1022时的二进制数,同样经过int函数转为十进制数,得到十进制的最小正规约数。

最小和最大的正非规约数取值

       根据非规约数的定义,即指数为0,尾数小数不全为0的数,这时首位的隐藏为也变成了0,不再是1,而且移码后的指数保持-1022不变。所以,最小的非规约数就是当尾数的小数部分最后一位为1,其他位全部为0的时候;由于这时移码后的指数依然为-1022,所以可由如下代码推算得到。同理,最大的非规约数就是当尾数首位隐藏位为0,其他52位小数全部为1时的数,注意这时的指数为-1022。如下所示。

f_subnormal_min = float(1/(2**(1022+52)))
f_subnormal_min
[out]:
5e-324f_subnormal_max = float(int('1'*52,2)/(2**(1022+52)))
f_subnormal_max
[out]:
2.225073858507201e-308f_min - f_subnormal_max #注意f_subnormal_min + f_subnormal_max刚好等于f_min
[out]:
5e-324

浮点数能在该范围内精确表示的最大十进制整数

       由于64位浮点数的尾数只有53位(52位加上一位隐藏位),所以如果某个十进制整数转为64位浮点数后,其二进制的位数超过了53位,那么这个整数的精度就会丢失,所以知道浮点数可以精确表示最大的十进制整数是很重要的,可以避免因为精度问题造成数据的错误。自然地,该十进制整数只需要通过53位全为1的二进制数反推回去就可以得到,如下所示。

max_int = int('1'*53,2)
print(max_int)
[out]:
9007199254740991 #该数就是64位浮点数可以精确表示的最大十进制整数

       所以,只要一个整数小于等于这个数,那么一定可以保证,当一个整数转为64位浮点数时,该整数还是原来那个数,精度不会丢失,但是如果大于这个数,那么精度就无法保证了。

大于1的最小规约数和1之间的距离epsilon

       这个数很简单,即第52位为1,其他全为0,且移码后的指数为0,注意不要忽略了隐藏的首位1。所以其和1之间的就是二进制下的0.000....0001,其中小数点后面的0共有51个,由此可以计算得到其和1之间的差epsilon,如下所示。

epsilon = float(1/int('1'*52,2))
print(epsilon)
[out]:
2.2204460492503136e-16

对python sys.float_info的解释

print(sys.float_info)
[out]:
sys.float_info(max=1.7976931348623157e+308, max_exp=1024, max_10_exp=308, min=2.2250738585072014e-308, min_exp=-1021, min_10_exp=-307, dig=15, mant_dig=53, epsilon=2.220446049250313e-16, radix=2, rounds=1)

       其中max表示的就是最大的规约数,上面已经进行了推算;radix表示的是在电脑中储存的基数,即进制数,这里表明的是二进制(很显然);max_exp表示的是使得radix**(e-1)为可表示的有限浮点数最大指数,根据上述,由于移码后的规约数的指数范围为-1022~1023,即最大为1023,所以最大的e自然就是1024;max_10_exp表示的是让10**e为一个可表示的浮点数最大的指数,同样的,根据上面对最大规约数的推导,计算得到的结果为1.7976931348623157e+308,所以max_10_exp自然就是308;min表示最小的正规约数,这个和上面的推导结果也是一致的;min_exp表示的是使得radix**(e-1)为可表示的有限浮点数最小指数,因为移码后的最小指数为-1022(尽管指数为0时,我们设定此时偏移量为1022,所以移码后的指数依然为-1022),因此最小的e为-1021;min_10_exp表示的是让10**e为一个可表示的规约浮点数最小的指数,由于计算得到的最小规约数为2.2250738585072014e-308,所以这时最小的e为-307(要注意不是-308,因为10**(-308)比最小正规约数2.2250738585072014e-308还小,这是不符合要求的,所以应该是-307);dig表示可以保证被精确的转为浮点数的整数的数字个数,因为我们上面计算得到的可以保证被精确的转为浮点数的整数应该小于等于9007199254740991,该数有16位数字,但是大于该数的16位数字的整数是无法被精确的转为浮点数的,所以能够被保证可以精确表示成64位浮点数的整数的最大位数应该为15;mant_dig就是mantissa digits,即尾数位数,由于我们知道尾数的首位1是被隐藏的,所以真正的尾数位数共有52位小数位数加上首位的隐藏1,共有53位;这里的epsilon和我们上面说的epsilon意义一样,就是最小的大于1的浮点数和1之间的差值;radix表示基数,也就是进制数,这里指的是二进制;最后rounds表示的是当一个整数转成浮点数,对无法精确表示的整数的近似模式,这里为1表示的是取里原值最近的浮点表示,如果存在两种不同的表示距离一样近,那么去最后一位(即第52位bit)为0的情形,对rounds的说明可以具体看笔者的下一篇文章。

这篇关于浮点数的各种最值推算以及对python sys.float_info的解释的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/791075

相关文章

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统