有人听说过哈夫曼三进制编码吗

千年冰魂 3个月前 已收到1个回答 举报

绿罗裙底 2星

共回答了221个问题采纳率:99.9% 评论

我最近在学信息论,不知道楼主是否在问哈夫曼3进制编码流程,我目前的理解是这样的: 设信源有Q个符号,m为m进制,这里是三进制的话就取3,还有一个变量k(后面再解释这个变量的意义)

1、对信源符号按概率大小进行排序

2、计算X = m + k(m-1) = 3 + k(3 - 1) = 3 + 2 k (3进制的情况) (这一步的目的是:计算如果每一步都是3个数进行编码,所需要的符号数目) 3、取一个使X>=Q的k,k可以取无数多个,但是我们取其中的最小值。 4、s = X - Q (这一步的目的是:计算我们目前拥有的符号数目与每一步都用3个符号进行编码时所需要的符号数目相差多少个) 5、则m-s的数值就是m进制哈夫曼编码第一部所需要取的符号个数。 (既然我们与理想状况相差s个,那我们第一步就用m-s个进行编码吧) k其实就是信源缩减的次数。 说的有点绕,理一理思路我再回来更口语化地修改答案。 例题: 信源有8个信源符号,所以X = 3 + 2 * 3 = 9 > 8 理想情况下是9个,但是我们只有8个符号,设差距设为s 则 s = 9 - 8 = 1 因此第一步取:m-s = 3 - 1 = 2个符号来编码。

9小时前

41
可能相似的问题
Copyright © 2024 微短问答 All rights reserved. 粤ICP备2021119249号 站务邮箱 service@wdace.com