91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用R語言怎么編寫一個霍夫曼編碼

發布時間:2021-03-18 15:20:54 來源:億速云 閱讀:203 作者:Leah 欄目:開發技術

本篇文章給大家分享的是有關使用R語言怎么編寫一個霍夫曼編碼,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

p=c(0.4,0.2,0.2,0.1,0.1)###輸入形如c(0.4,0.2,0.2,0.1,0.1)的概率向量,即每個待編碼消息的發生概率
p1=p###將概率向量另存,最后計算編碼效率要用
mazijuzhen=matrix(,nrow=length(p),ncol=length(p)-1)###碼字矩陣:第i行對應向量p的第i個分量所對應的那個待編碼消息的編碼后的碼字
group=matrix(c(1:length(p),rep(NA,length(p)*(length(p)-1))),nrow=length(p),ncol=length(p))###初始分組:每一行代表一組,每個行向量的所有分量代表此組的所有元素,初始時,有多少個待編碼消息就分多少個組,每組只有一個待編碼消息,以整數i代表向量p的第i個分量所對應的那個待編碼消息
i=1###開始編碼
for(i in 1:(length(p)-1))
{
 orderp=order(p,decreasing = FALSE)###orderp的分量依次是:p的最小分量的下標,p的第二小分量的下標。。。
 mazijuzhen[group[orderp[1],],i]=0###給概率最小的兩個消息組編上0和1
 mazijuzhen[group[orderp[2],],i]=1
 group[min(c(orderp[1],orderp[2])),]=c(na.omit(group[min(c(orderp[1],orderp[2])),]),na.omit(group[max(c(orderp[1],orderp[2])),]),rep(NA,length(p)-length(c(na.omit(group[min(c(orderp[1],orderp[2])),]),na.omit(group[max(c(orderp[1],orderp[2])),])))))###把此次迭代的兩個消息組中組編號較大的分到組編號較小的組里去。
 group[max(c(orderp[1],orderp[2])),]=NA###刪除組編號較大的組
 p[min(c(orderp[1],orderp[2]))]=p[orderp[1]]+p[orderp[2]]###計算本次迭代得到的新的消息組的發生概率
 p[max(c(orderp[1],orderp[2]))]=NA###由于組編號較大的組被刪除,所以相應刪除它所對應的概率
 print("當前迭代次數")###本次迭代的結果總結
 print(i)
 print("概率向量")
 print(p)
 print("分組矩陣")
 print(group)
 print("碼字矩陣")
 print(mazijuzhen)
}
i=1###由霍夫曼編碼的特性,將所有編碼倒轉得到最終編碼
for (i in 1:length(p)) 
{
 mazijuzhen[i,]=rev(mazijuzhen[i,]) 
}
i=1###構建碼長向量
machang=c()
for (i in 1:length(p))
{
 
 machang=c(machang,length(na.omit(mazijuzhen[i,])))
}
xiaolv=-p1%*%log(p1,2)/mean(machang)###計算編碼效率
print("最終的碼字矩陣和編碼效率")
mazijuzhen
xiaolv

以上就是使用R語言怎么編寫一個霍夫曼編碼,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

湖州市| 广宁县| 五河县| 诸暨市| 潼南县| 和田县| 区。| 广平县| 花莲县| 册亨县| 云霄县| 东港市| 雷波县| 杭州市| 亚东县| 大庆市| 兴仁县| 健康| 宾川县| 恩平市| 马龙县| 鄂托克前旗| 舒城县| 两当县| 额敏县| 江源县| 宜兴市| 平乐县| 河源市| 嘉禾县| 岫岩| 察哈| 岑溪市| 高邮市| 苗栗市| 宁强县| 永城市| 潜山县| 阿图什市| 宁乡县| 神池县|