国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

解決Python中的modf()函數取小數部分不準確問題

瀏覽:25日期:2022-06-18 09:33:39
使用math.modf()對一個浮點數進行拆分時經常會遇到如下情況

如下

import mathprint(math.modf(2.4)) # 輸出 (0.3999999999999999, 2.0)

我們會發現對2.4進行拆分得到的小數并不是0.4,這是因為什么呢?

這是因為計算機采用的是二進制代碼,而二進制代碼由于計算上的誤差無法準確表示某些十進制數的小數部分。

下面我們具體來講一下。

我們知道一個十進制數轉化為二進制數需要分為兩部分進行計算:整數部分和小數部分。

整數部分采用“除二取余法”。將這個整數除以2,得到它的余數,然后將商再除以3,直到商為0為止,并將各個得到的余數按照相反的順序進行排列。

小數部分采用“乘2取整法”,將這個小數乘2,將新得到的數的整數部分取出,再用2乘余下的小數部分,如此往復直到乘積中的小數部分為0或者達到要求的精度為止。并將取出的整數部分按照取出的先后順序從前到后排列。

123/2=61...1 61/2=30...1 30/2=15...0 15/2=7...1 7/2=3...1 3/2=1...1 1/2=0...1 (123)10=(1111011)20.4*2=0.8...00.8*2=1.6...10.6*2=1.2...10.2*2=0.4...00.4*2=0.8...00.8*2=1.6...10.6*2=1.2...1(0.4)10=(0.011001100110011001100110...)2(123.4)2=(1111011.011001100110011...)2

十進制的0.4轉化為二進制時會出現重復循環“0110”的情況,但是目前計算機存儲浮點數是按照電器和電子工程師協會的標準(IEEE754浮點數存儲格式標準)來進行存儲的。

IEEE規定單精度浮點最多存儲32位(4個字節):

31位是符號位。1表示該數為負,0為正

30~23是指數位(-128-127)

22~0是尾數位,尾數的編碼一般是源碼和補碼

IEEE標準從邏輯上用三元組{S,E,M}表示一個數,如圖所示:

解決Python中的modf()函數取小數部分不準確問題

也就是說上面將0.4轉換出的二進制代碼,我們只能存儲23位,即使數據類型為double,也只能存儲52位,這樣大家便能看出問題出現的原因了。23位的數據顯然無法完整表示0.4的二進制數據,于是誤差產生了。

那所有的十進制小數都無法完整表示嗎?不是的,只要小數部分乘上2最終小數部分能夠得到0就不會出現這種問題,比如0.5,0.75。

import mathprint(math.modf(1.5)) # 輸出 (0.5,1.0)

0.5*2=1...1(0.5)10=(0.1)20.75*2=1.5...10.5*2=1...1(0.75)10=(0.11)2

補充:Python中“取整”的各種問題

一、初衷:

有時候我們分頁展示數據的時候,需要計算頁數。一般都是向上取整,例如counts=205 pageCouts=20 ,pages= 11 頁。

一般的除法只是取整數部分,達不到要求。

二、方法:1、通用除法:

UP(A/B) = int((A+B-1)/B)

取臨界值,計算下A+B-1的范圍就OK.

2 、Python除法:

首先要說的是python中的除法運算,

當使用x/y形式進行除法運算時,那么會進行所謂的true除法,比如2.0/3的結果是 0.66666666666666663。

另外一種除法是采用x//y的形式(向下取整),那么這里采用的是所謂floor除法,即得到不大于結果的最大整數值,這個運算時與操作數無關的。比如2//3的結果是0,-2//3的結果是-1,-2.0//3的結果是-1.0。

在python 3.0中,x/y將只執行true除法,而與操作數無關;x//y則執行floor除法。

Python運算向上取整方法:(A+B-1)/B

3、Python match.ceil函數 np.ceil函數

ceil(x)函數是向上取整,即取大于等于x的最接近整數。

import math math.ceil(float(205)/20) import numpy as npnp.ceil(float(205)/20)Python 向上取整的算法1、一般使用floor除法 (np.floor()或者math.floor())

import numpy as np n = np.array([-1.7, -2.5, -0.2, 0.6, 1.2, 2.7, 11]) floor = np.floor(n)print(floor) # [ -2. -3. -1. 0. 1. 2. 11.]2、一般除法/

A=100B=16c=100//16(c=6)3、round()四舍五入函數。

np.around 返回四舍五入后的值,可指定精度。

around(a, decimals=0, out=None)

a 輸入數組

decimals 要舍入的小數位數。 默認值為0。 如果為負,整數將四舍五入到小數點左側的位置

import numpy as np n = np.array([-0.746, 4.6, 9.4, 7.447, 10.455, 11.555]) around1 = np.around(n)print(around1) # [ -1. 5. 9. 7. 10. 12.] around2 = np.around(n, decimals=1)print(around2) # [ -0.7 4.6 9.4 7.4 10.5 11.6] around3 = np.around(n, decimals=-1)print(around3) # [ -0. 0. 10. 10. 10. 10.]Python 分別取整的算法

math模塊中的 modf()方法

將整數部分和小數部分分別取出,可以使用math模塊中的 modf()方法

例如:

>>> math.modf(4.25)(0.25, 4.0)>>> math.modf(4.33)

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 一本色道久久综合亚洲精品高清 | 男女做性免费视频软件 | 奇米网狠狠干 | 亚洲国产精品91 | 久久两性视频 | 成人国产精品高清在线观看 | 伊人色综合久久成人 | 黄网在线观看免费 | 六月丁香婷婷天天在线 | 成年人免费观看的视频 | 国产欧美一区二区另类精品 | 国内xxxx乱子另类 | 日本成人中文字幕 | 国产精品理论片 | 国产精品自拍合集 | chinese耄耋70老太性 | 欧美另类高清xxxxx | 久久ri精品高清一区二区三区 | 久久国产成人精品国产成人亚洲 | 久草免费色站 | 免费观看国产精品 | 欧美精品国产一区二区三区 | 在线欧美成人 | 国产爽的冒白浆的视频高清 | 亚洲欧美日韩另类在线 | 久久99综合国产精品亚洲首页 | 亚洲欧美日韩另类精品一区二区三区 | 97午夜影院 | 欧美成人怡红院在线观看 | 高清精品一区二区三区一区 | 日韩在线观看一区二区三区 | 亚洲国产精品久久综合 | 国产成人久久精品一区二区三区 | 日韩毛片在线免费观看 | 久久老司机波多野结衣 | 国产精品视频免费播放 | 九九视频在线观看视频6偷拍 | 日本成人一级片 | 中国女警察一级毛片视频 | 久爱午夜精品免费视频 | 久久综合狠狠综合久久97色 |