python执行精确的小数计算方法


Posted in Python onJanuary 21, 2019

在进行浮点数计算时它们无法精确表达出所有的十进制小数位。

a = 4.1
b = 5.329
print(a+b)
 
9.428999999999998

这些误差实际上是底层CPU的浮点运算单元和IEEE754浮点数算数标准的一种“特性”。python的浮点数类型保存的数据采用的是原始表示形式,因此使用float实例时就不能避免这样的误差。

我们可以使用decimal模块避免这种操作(如果不介意牺牲下性能):

from decimal import Decimal
a = Decimal('4.1')
b = Decimal('5.329')
print(a+b)
 
9.429

注意Decimal的参数必须是字符串,不能是浮点型,否则误差依旧存在。

decimal模块的主要功能是允许控制计算过程中的各个方面,包括数字的尾数和四舍五入。

from decimal import Decimal
from decimal import localcontext
a = Decimal(4.1)
b = Decimal(5.329)
print(a/b)
print('================')
with localcontext() as ctx:
  ctx.prec = 3
  print(a/b)
 
0.7693751172827922400071261708
================
0.769

getcontext也可以实现和localcontext一样的功能

from decimal import Decimal, getcontext
a = Decimal(4.1)
b = Decimal(5.329)
getcontext().prec = 3
print(a/b)
 
0.769

误差我们不能完全消除,我们只能尽力优化算法,使得误差尽可能小。在大数和小数相加时要格外注意。

nums = [3.21e+18, 1, -3.21e+18]
print(sum(nums))
print('=========================')
import math
res = math.fsum(nums)
print(res)
 
0.0
=========================
1.0

以上这篇python执行精确的小数计算方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python字符串连接的N种方式总结
Sep 17 Python
利用Python抓取行政区划码的方法
Nov 28 Python
pandas系列之DataFrame 行列数据筛选实例
Apr 12 Python
Python PyAutoGUI模块控制鼠标和键盘实现自动化任务详解
Sep 04 Python
Python实现微信机器人的方法
Sep 06 Python
基于Python实现扑克牌面试题
Dec 11 Python
tensorflow 实现自定义梯度反向传播代码
Feb 10 Python
python集成开发环境配置(pycharm)
Feb 14 Python
python实现PCA降维的示例详解
Feb 24 Python
django 装饰器 检测登录状态操作
Jul 02 Python
PyTorch: Softmax多分类实战操作
Jul 07 Python
如何用python爬取微博热搜数据并保存
Feb 20 Python
详解安装mitmproxy以及遇到的坑和简单用法
Jan 21 #Python
python dict 相同key 合并value的实例
Jan 21 #Python
关于python之字典的嵌套,递归调用方法
Jan 21 #Python
对python 合并 累加两个dict的实例详解
Jan 21 #Python
python去重,一个由dict组成的list的去重示例
Jan 21 #Python
Python实现计算字符串中出现次数最多的字符示例
Jan 21 #Python
python3.6数独问题的解决
Jan 21 #Python
You might like
FCKeditor的安装(PHP)
2007/01/13 PHP
关于php中一些字符串总结
2016/05/05 PHP
php变量与数组相互转换的方法(extract与compact)
2016/12/02 PHP
PHP4和PHP5版本下解析XML文档的操作方法实例分析
2017/05/20 PHP
jquery 弹出登录窗口实现代码
2009/12/24 Javascript
php读取sqlite数据库入门实例代码
2014/06/25 Javascript
jQuery中:only-child选择器用法实例
2015/01/03 Javascript
JS实现的4种数字千位符格式化方法分享
2015/03/02 Javascript
jQuery使用hide方法隐藏指定元素class样式用法实例
2015/03/30 Javascript
JQuery select(下拉框)操作方法汇总
2015/04/15 Javascript
jquery表单对象属性过滤选择器实例分析
2015/05/18 Javascript
js简单实现调整网页字体大小的方法
2016/07/23 Javascript
Vue.js每天必学之数据双向绑定
2016/09/05 Javascript
js判断浏览器是否支持严格模式的方法
2016/10/04 Javascript
angularJs关于指令的一些冷门属性详解
2016/10/24 Javascript
vue.js利用Object.defineProperty实现双向绑定
2017/03/09 Javascript
Vue动态实现评分效果
2017/05/24 Javascript
微信小程序模板(template)使用详解
2018/01/31 Javascript
Vue实现底部侧边工具栏的实例代码
2018/09/03 Javascript
详解Vue调用手机相机和相册以及上传
2019/05/05 Javascript
公众号SVG动画交互实战代码
2020/05/31 Javascript
在vue中通过render函数给子组件设置ref操作
2020/11/17 Vue.js
python实现ipsec开权限实例
2014/11/11 Python
python添加模块搜索路径和包的导入方法
2019/01/19 Python
Python 3 判断2个字典相同
2019/08/06 Python
python——全排列数的生成方式
2020/02/26 Python
全网最细 Python 格式化输出用法讲解(推荐)
2021/01/18 Python
德国购买健身器材:AsVIVA
2017/08/09 全球购物
墨西哥网上超市:Superama
2018/07/10 全球购物
会计毕业生自我鉴定
2013/11/04 职场文书
学习党课思想汇报
2013/12/29 职场文书
社区庆八一活动方案
2014/02/02 职场文书
前厅收银主管岗位职责
2014/02/04 职场文书
2014年社区居委会主任重阳节讲话稿
2014/09/25 职场文书
2015年度残疾人工作总结
2015/05/14 职场文书
CSS3鼠标悬浮过渡缩放效果
2021/04/17 HTML / CSS