香农编码c++实现_香农费诺编码例子

香农编码c++实现_香农费诺编码例子实验三香农编码信息论与编码实验报告院系:哈尔滨理工大学荣成校区专业:电子信息工程学号:姓名:日期:2015年6月16日香农编码信息论与编码第三次实验报告一、实验目的和任务?1、?理解信源编码的意义;?2、?熟悉?MATLAB程序设计;??3、?掌握香农编码的方法及计算机实现;??4、?对给定信源进行香农编码,并计算编码效率;?二、实验原理介绍?给定某个信源符号的概率分布,通过以下的步骤进行香…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

实验三香农编码

信息论与编码实验报告

院系: 哈尔滨理工大学荣成校区

专业: 电子信息工程

学号:

姓名:

日期: 2015年6月16日

香农编码

信息论与编码第三次实验报告

一、实验目的和任务?

1、?理解信源编码的意义;?

2、?熟悉?MATLAB程序设计;??

3、?掌握香农编码的方法及计算机实现;??

4、?对给定信源进行香农编码,并计算编码效率;?

二、实验原理介绍?

给定某个信源符号的概率分布,通过以下的步骤进行香农编码

?1、信源符号按概率从大到小排列;?

???

2、确定满足下列不等式的整数码长为?

????

3、为了编成唯一可译码,计算第i个消息的累加概率:?

?

?4、将累加概率变换成二进制数;?

取二进制数的小数点后位即为该消息符号的二进制码字。

三、实验设备

计算机

Matlab2014

四、编码程序

N=input(‘N=’); %输入信源符号的个数

s=0; %对行的概率进行初始化

l=0; %对列的概率初始化

H=0; %对信息熵初始化

for i=1:N

p(i)=input(‘p=’);%输入信源符号概率分布矢量

p(i)<1; %输入概率小于1

s=s+p(i); %行概率求和

H=H+(-p(i)*log2(p(i)));%计算信源信息熵

end

if abs(s-1)>0 %若行概率和>1则报错

error(‘不符合概率分布’)

end

for i=1:N-1 %for循环按概率分布大小对信源排序

for j=i+1:N

if p(i)

m=p(j);

p(j)=p(i);

p(i)=m;

end

end

end

for i=1:N

a=-log2(p(i)); %确定满足不等式的整数a,并领a为第i个码字的长度

if mod(a,1)==0 %a对1取余后赋值给a

w=a;

else

w=fix(a+1); %计算各信源符号的码长

end

l=l+p(i)*w; %计算平均码长

end

r=l; %香农编码的信息率(这里L=1,m=2)

n=H/r; %计算编码效率

P(1)=0; %初始1列为0;

for i=2:N

P(i)=0; %初始1列为0;累加

for j=1:i-1

P(i)=P(i)+p(j); %从2列开始累加

end

end

%计算累加概率

for i=1:N

for j=1:w

W(i,j)=fix(P(i)*2); %对每次的P(i)取码字,长度与a相同

P(i)=P(i)*2-fix(P(i)*2); %将累加概率转化为L(i)位二进制码字

end

end

W %显示码字

r %显示平均码长

n %显示编码效率

H %显示信息熵H

实验结果

>> xiangnong

N=6

p=0.25

p=0.25

p=0.20

p=0.15

p=0.10

p=0.05

W =

0 0 0 0 0

0 1 0 0 0

1 0 0 0 0

1 0 1 1 0

1 1 0 1 1

1 1 1 1 0

r =

2.7000

n =

0.8975

H =

2.4232

六、实验心得

此次实验让我明白了做程序需要先进行需求分析,然后画出流程图,根据流程图把每部分模块完成,然后再进行调试和编辑,提高了我做

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195272.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 通达OA 工作流执行出现的异常现象处理(图文)

    通达OA 工作流执行出现的异常现象处理(图文)一个朋友用的工作流,突然说这里面多了很多人不应该看到这个流程的,就是在查询工作时,最上面多了一个“查阅信息”项,然后最下面多了很多人查询的记录。这个项目是从哪里来的呢?普通的流程倒也无所谓了,而有些流程如发文、任职等还是需要保密的,这样让大家查阅肯定是不行的。一开始以为是使用了工作流的转存文件柜的功能,实验了一下,这样转存后并不会在流程里关联查看到查阅信息。又实验了一下转发布公告,同样不是。最后咨

    2022年6月23日
    38
  • 通俗理解逻辑删除和物理删除的区别「建议收藏」

    通俗理解逻辑删除和物理删除的区别「建议收藏」一:逻辑删除逻辑删除的本质是修改操作,所谓的逻辑删除其实并不是真正的删除,而是在表中将对应的是否删除标识(is_delete)或者说是状态字段(status)做修改操作。比如0是未删除,1是删除。在逻辑上数据是被删除的,但数据本身依然存在库中。对应的SQL语句:update表名setis_delete=1whereid=1;语句表示,在该表中将id为1的信息进行逻…

    2022年6月2日
    130
  • WEB/HTTP服务器搭建[通俗易懂]

    WEB/HTTP服务器搭建[通俗易懂]HTTP对于软件都有服务和客户,有服务端和客户端服务就是在操作系统运行一个或者多个程序,并为客户端提供相应所需的服务协议就是计算机网络中进行数据交换而建立的规则、标准或约定的集合。只有遵守这个约定,计算机之间才能相互通信交流。它的三要素是:语法、语义、时序。1.WEB服务器web服务器一般指网站服务器,他是一个驻留于Internet的一个计算机程序,用于向浏览器提供文档…

    2022年5月28日
    184
  • 大学学姐给学弟学妹们的寄语_怎么去大厂工作

    大学学姐给学弟学妹们的寄语_怎么去大厂工作很多小伙伴问我进大厂到底需要怎样的技术能力,经过几天的思考和总结,终于梳理出一份相对比较完整的技能清单,太顶了,建议收藏!!

    2022年8月23日
    6
  • js 填充数组长度

    js 填充数组长度js 填充的方法有以下三种 constarray newArray 100 fill Array from newArray 100 keys letarr Array from length 100 v k gt k 如果下面有这么一个场景 你在接口中获取了一个数组对象 如下 id 1 id 2 id 3 id 4 你需要把这个数组变成一个以 100 位的数组对象 我们可以用循坏的方式往数组中 p

    2025年9月25日
    2
  • 外贸英文外链代发布

    外贸英文外链代发布  能进来看到这篇文章,就说明大家都是有发布英文seo外链需求的人,平时比较忙,一个人忙不过来,没有时间发外链,或者自己外链资源太少,外链质量不高,网站总是没人气,没订单怎么办,这时候我们出现了,mmoboy专业团队,提供优质的英文外链服务:  通过人工注册博客、论坛、新闻等站点回复留言,把网站推广出去,制造手工的回复式外部链接。提高你的网站客户IP流量,增加网站的反向链接和google的收录…

    2022年5月17日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号