目录
使用的方法
Example
输出
方法一:使用decimal模块的Decimal()函数
将精度值增加到'60'以获得更高的准确性
方法2:使用math模块的fsum()函数
语法
结论
首页 后端开发 Python教程 如何使用Python进行准确的小数计算?

如何使用Python进行准确的小数计算?

Aug 23, 2023 pm 03:53 PM
python 准确 小数计算

如何使用Python进行准确的小数计算?

在本文中,我们将学习如何在Python中进行准确的十进制计算。

使用的方法

  • Using the Decimal() function of the decimal Module

  • 使用math模块的fsum()函数

浮点数无法准确表示所有十进制数是众所周知的缺点。此外,即使是简单的数学计算也会产生一些错误。例如 −

Example

以下程序展示了浮点整数无法准确表示所有十进制数的能力-

x = 4.2
y = 3.1
 
# printing the sum of both the variables
print("x + y =", x + y)
 
# checking if the sum is both the variables is equal to 7.3
print((x + y) == 7.3)
登录后复制

输出

在执行时,上述程序将生成以下输出 -

x + y = 7.300000000000001
False
登录后复制

这些错误是系统底层的CPU和其浮点数单元所使用的IEEE 754算术标准的“特性”。如果您使用float实例编写代码,那么无论如何都无法防止此类错误,因为Python的float数据类型使用本机表示来保存数据。

Using the decimal module will give you greater accuracy at the cost of some performance. Let us see it below.

方法一:使用decimal模块的Decimal()函数

Example

以下程序展示了使用Decimal()函数进行精确的十进制计算的示例:

# importing Decimal from decimal module
from decimal import Decimal
x = Decimal('4.2')
y = Decimal('3.1')
# printing the sum of both the variables
print("x + y =", x + y)
# checking if the sum is both the variables is equal to 7.3 using by passing the sum to the Decimal Function
print((x + y) == Decimal('7.3'))
登录后复制

输出

在执行时,上述程序将生成以下输出 -

x + y = 7.3
True
登录后复制

在上述代码中,一开始可能会感觉有点奇怪,即将数字指定为字符串。然而,十进制对象的工作方式与您希望的完全相同(支持所有常见的数学运算等)。当您打印它们或在字符串格式化函数中使用它们时,它们看起来就像普通的数字。

控制计算的多个方面,如数字的位数和舍入方式,是decimal的关键特性。

Example

要执行此操作,请创建一个本地上下文并修改其设置。

# importing localcontext from decimal module
from decimal import localcontext
x = Decimal('2.3')
y = Decimal('2.7')
# dividing x by y(returns as a floating-point number)
print(x / y)
with localcontext() as context:
   # rounding the number upto 3 digits i.e, precision 3
   context.prec = 3
   # Dividing x by y with precision set to 3
   print(x / y)
登录后复制

输出

在执行时,上述程序将生成以下输出 -

0.8518518518518518518518518519
0.852
登录后复制

将精度值增加到'60'以获得更高的准确性

Example

# importing localcontext from decimal module
import decimal
from decimal import localcontext
x = decimal.Decimal('2.3')
y = decimal.Decimal('2.7')
# dividing x by y(returns as a floating-point number)
print(x / y)
with localcontext() as context:
   # Rounding the number upto 60 digits i.e, precision 60
   context.prec = 60
   # Dividing x by y with precision set to 3
   print(x / y)
登录后复制

输出

在执行时,上述程序将生成以下输出 -

0.8518518518518518518518518519
0.851851851851851851851851851851851851851851851851851851851852
登录后复制

方法2:使用math模块的fsum()函数

十进制模块实现了IBM的“通用十进制算术规范”。

不用说,有很多超出本文范围的自定义选择。

Python初学者可能会被诱导使用decimal模块来解决浮点数据类型的精度问题。但也需要了解你的应用领域。在处理科学或工程问题、计算机图形或其他科学性质的事物时,通常更常用普通浮点数类型。

例如,实际世界中很少有元素能够以浮点数提供的17位精度进行测量。因此,即使是微小的计算误差也没有影响。而且,原生浮点数的速度也明显更快,这对于需要运行大量计算的情况至关重要。

Example

然而,你无法完全避免错误。许多算法已经被数学家广泛研究,其中一些在处理错误方面比其他算法更好。此外,由于减法抵消和加法大数和小数的做法可能导致一些后果,需要一些谨慎。

inputList = [1.23e+18, 1, -1.23e+18]

# observe how the 1 disappears here if we perform sum() on the list
print(sum(inputList)) 
登录后复制

输出

在执行时,上述程序将生成以下输出−

0.0
登录后复制

fsum()函数用于在给定范围或可迭代对象之间找到总和。它需要导入math库。它在数学计算中被广泛使用。

语法

下面是函数的语法。

maths.fsum( iterable )
登录后复制

可迭代对象可以是范围、数组或列表。

返回类型 -

它返回一个浮点数。

Example

下面的示例可以用于在 math.fsum() 中进行更准确的实现 -

# importing math module 
import math
# input list
inputList = [1.23e+18, 1, -1.23e+18]
# adding the sum of elements of the list using the fsum() function
print(math.fsum(inputList))
登录后复制

输出

在执行时,上述程序将生成以下输出 -

1.0
登录后复制

相比之下,你实际上需要研究和理解其他算法的误差传播特性。

尽管如此,处理金融等主题的程序是最常使用十进制模块的地方。当这些系统的计算中出现微小的不准确性时,这是非常令人不愉快的。

因此,decimal模块提供了一种避免这种情况的方法。当Python与数据库进行交互时,经常会再次遇到Decimal对象,特别是在访问金融数据时。

结论

我们在本文中了解到,在特定情况下,常规计算会失败,所以我们需要正确的小数计算。我们学习了如何使用两个独立的函数decimal()和fsum()进行准确的小数计算。我们还学习了如何使用localcontext()函数来设置结果的精度。

以上是如何使用Python进行准确的小数计算?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP和Python:代码示例和比较 PHP和Python:代码示例和比较 Apr 15, 2025 am 12:07 AM

PHP和Python各有优劣,选择取决于项目需求和个人偏好。1.PHP适合快速开发和维护大型Web应用。2.Python在数据科学和机器学习领域占据主导地位。

CentOS上如何进行PyTorch模型训练 CentOS上如何进行PyTorch模型训练 Apr 14, 2025 pm 03:03 PM

在CentOS系统上高效训练PyTorch模型,需要分步骤进行,本文将提供详细指南。一、环境准备:Python及依赖项安装:CentOS系统通常预装Python,但版本可能较旧。建议使用yum或dnf安装Python3并升级pip:sudoyumupdatepython3(或sudodnfupdatepython3),pip3install--upgradepip。CUDA与cuDNN(GPU加速):如果使用NVIDIAGPU,需安装CUDATool

docker原理详解 docker原理详解 Apr 14, 2025 pm 11:57 PM

Docker利用Linux内核特性,提供高效、隔离的应用运行环境。其工作原理如下:1. 镜像作为只读模板,包含运行应用所需的一切;2. 联合文件系统(UnionFS)层叠多个文件系统,只存储差异部分,节省空间并加快速度;3. 守护进程管理镜像和容器,客户端用于交互;4. Namespaces和cgroups实现容器隔离和资源限制;5. 多种网络模式支持容器互联。理解这些核心概念,才能更好地利用Docker。

CentOS上PyTorch的GPU支持情况如何 CentOS上PyTorch的GPU支持情况如何 Apr 14, 2025 pm 06:48 PM

在CentOS系统上启用PyTorchGPU加速,需要安装CUDA、cuDNN以及PyTorch的GPU版本。以下步骤将引导您完成这一过程:CUDA和cuDNN安装确定CUDA版本兼容性:使用nvidia-smi命令查看您的NVIDIA显卡支持的CUDA版本。例如,您的MX450显卡可能支持CUDA11.1或更高版本。下载并安装CUDAToolkit:访问NVIDIACUDAToolkit官网,根据您显卡支持的最高CUDA版本下载并安装相应的版本。安装cuDNN库:前

Python vs. JavaScript:社区,图书馆和资源 Python vs. JavaScript:社区,图书馆和资源 Apr 15, 2025 am 12:16 AM

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

CentOS下PyTorch版本怎么选 CentOS下PyTorch版本怎么选 Apr 14, 2025 pm 02:51 PM

在CentOS下选择PyTorch版本时,需要考虑以下几个关键因素:1.CUDA版本兼容性GPU支持:如果你有NVIDIAGPU并且希望利用GPU加速,需要选择支持相应CUDA版本的PyTorch。可以通过运行nvidia-smi命令查看你的显卡支持的CUDA版本。CPU版本:如果没有GPU或不想使用GPU,可以选择CPU版本的PyTorch。2.Python版本PyTorch

minio安装centos兼容性 minio安装centos兼容性 Apr 14, 2025 pm 05:45 PM

MinIO对象存储:CentOS系统下的高性能部署MinIO是一款基于Go语言开发的高性能、分布式对象存储系统,与AmazonS3兼容。它支持多种客户端语言,包括Java、Python、JavaScript和Go。本文将简要介绍MinIO在CentOS系统上的安装和兼容性。CentOS版本兼容性MinIO已在多个CentOS版本上得到验证,包括但不限于:CentOS7.9:提供完整的安装指南,涵盖集群配置、环境准备、配置文件设置、磁盘分区以及MinI

centos如何安装nginx centos如何安装nginx Apr 14, 2025 pm 08:06 PM

CentOS 安装 Nginx 需要遵循以下步骤:安装依赖包,如开发工具、pcre-devel 和 openssl-devel。下载 Nginx 源码包,解压后编译安装,并指定安装路径为 /usr/local/nginx。创建 Nginx 用户和用户组,并设置权限。修改配置文件 nginx.conf,配置监听端口和域名/IP 地址。启动 Nginx 服务。需要注意常见的错误,如依赖问题、端口冲突和配置文件错误。性能优化需要根据具体情况调整,如开启缓存和调整 worker 进程数量。

See all articles