您好,登錄后才能下訂單哦!
這篇文章主要介紹“Python中Elias Delta編碼案例分析”,在日常操作中,相信很多人在Python中Elias Delta編碼案例分析問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Python中Elias Delta編碼案例分析”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
語法:
Elias Delta Encoding(X)= Elias Gamma encoding (1+floor(log2(X)) + Binary representation of X without MSB.
首先,在為 Elias Delta
編碼編寫代碼之前,我們將實現 Elias delta
編碼。
從數學庫導入 log
、floor
函數以執行對數運算。
從用戶獲取輸入 k 以在 Elias Gamma
中進行編碼。
使用數學模塊中的 floor
和 log
函數,找到 1+floor(log2(X)
并將其存儲在變量 N 中。
使用 (N-1)*'0'+'1'
找到 N 的一元編碼,它為我們提供了一個二進制字符串,其中最低有效位為 '1',其余最高有效位為 N-1 個'0'。
示例: 某些值的 Elias Gamma
編碼
def EliasGammaEncode(k): if (k == 0): return '0' N = 1 + floor(log(k, 2)) Unary = (N-1)*'0'+'1' return Unary + Binary_Representation_Without_MSB(k)
創建一個函數,該函數接受輸入 X 并給出結果作為 X 的二進制表示,沒有 MSB
。
使用“{0:b}”.format(k)
找到 k 的二進制等效項并將其存儲在名為 binary
的變量中。
前綴零僅指定應使用 format()
的哪個參數來填充 {}。
b 指定參數應轉換為二進制形式。
返回字符串 binary[1:]
,它是 X 的二進制表示,沒有 MSB
。
示例: 不帶 MSB
的二進制表示
def Binary_Representation_Without_MSB(x): binary = "{0:b}".format(int(x)) binary_without_MSB = binary[1:] return binary_without_MSB
現在我們要為 Elias Delta Encoding
編寫代碼
從用戶獲取輸入 k 以在 Elias Delta
中進行編碼。
使用數學模塊中的 floor
和 log
函數,找到 1+floor(log2(k)
。
將 1+floor(log2(k)
的結果傳遞給 Elias Gamma
編碼函數。
示例:某些值的 Elias Delta
編碼
def EliasDeltaEncode(x): Gamma = EliasGammaEncode(1 + floor(log(k, 2))) binary_without_MSB = Binary_Representation_Without_MSB(k) return Gamma+binary_without_MSB k = int(input('Enter a number to encode in Elias Delta: ')) print(EliasDeltaEncode(k))
得到不帶 MSB
的 k 的 Elias Gamma
編碼和二進制表示的結果
連接兩個結果并在控制臺上打印它們
為某些整數值生成 Elias Delta
編碼的完整代碼
from math import log from math import floor def Binary_Representation_Without_MSB(x): binary = "{0:b}".format(int(x)) binary_without_MSB = binary[1:] return binary_without_MSB def EliasGammaEncode(k): if (k == 0): return '0' N = 1 + floor(log(k, 2)) Unary = (N-1)*'0'+'1' return Unary + Binary_Representation_Without_MSB(k) def EliasDeltaEncode(x): Gamma = EliasGammaEncode(1 + floor(log(k, 2))) binary_without_MSB = Binary_Representation_Without_MSB(k) return Gamma+binary_without_MSB k = 14 print(EliasDeltaEncode(k))
輸出:
00100110
到此,關于“Python中Elias Delta編碼案例分析”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。