信息论与编码课程设计报告,统计信源熵与香农编码

信息论与编码课程设计报告,统计信源熵与香农编码

ID:18815850

大小:139.22 KB

页数:14页

时间:2018-09-23

信息论与编码课程设计报告,统计信源熵与香农编码_第1页
信息论与编码课程设计报告,统计信源熵与香农编码_第2页
信息论与编码课程设计报告,统计信源熵与香农编码_第3页
信息论与编码课程设计报告,统计信源熵与香农编码_第4页
信息论与编码课程设计报告,统计信源熵与香农编码_第5页
资源描述:

《信息论与编码课程设计报告,统计信源熵与香农编码》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、河南理工大学课程设计报告信息论与编码课程设计报告设计题目:统计信源熵与香农编码专业班级电信12-06学号学生姓名指导教师教师评分 2015年3月30日河南理工大学课程设计报告目录一、设计任务与要求2二、设计思路2三、设计流程图3四、程序运行及结果4五、心得体会6参考文献7附录:源程序8-12-河南理工大学课程设计报告一、设计任务与要求1.统计信源熵要求:统计任意文本文件中各字符(不区分大小写)数量,计算字符概率,并计算信源熵。2.香农编码要求:任意输入消息概率,利用香农编码方法进行编码,并计算信源熵和编码效率。二、设计思路本次课程设计中主要运用C语言编程以实现

2、任务要求,分析所需要的统计量以及相关变量,依据具体公式和计算步骤编写语句,组成完整C程序。1、信源熵定义:信源各个离散消息的自信息量的数学期望为信源的平均信息量,一般称为信源的信息熵,也叫信源熵或香农熵,有时称为无条件熵或熵函数,简称熵,记为H()。计算公式:2、香农编码过程:(1)将信源消息符号按其出现的概率大小依次排列为(2)确定满足下列不等式的整数码长为(3)为了编成唯一可译码,计算第i个消息的累加概率(4)将累计概率变换成二进制数。(5)取二进制数的小数点后位即为该消息符号的二进制码字。-12-河南理工大学课程设计报告三、设计流程图1、统计信源熵开始读

3、取给定文件判断文件是否打开否并且不为空是统计文本字符,直关闭文件至文本字符读完。统计同一字符(不分大小写)出现的次数计算字符概率计算信源熵输出结束-12-河南理工大学课程设计报告2、香农编码开始输入概率计算累加概率计算码字计算码长计算平均码长计算信源熵计算编码效率输出结束四、程序运行及结果1、统计信源熵-12-河南理工大学课程设计报告2、香农编码-12-河南理工大学课程设计报告五、心得体会通过这次课程设计明显的体会到知识匮乏所带来的种种问题,首先是对C语言编程的不熟练,课程知识在与C语言的结合中没有清晰的思路,具体实现程序语言的编写较为困难。在程序的调试中出现

4、的问题无法及时快速的解决,有些错误甚至无法找到合适的解决方法,以至于不断的修改程序,浪费了大量的时间。在设计期间出现的问题还是非常多的,要求熟悉相关软件的操作使用,需要不断的搜集所需的各种资料,及时解决遇到的问题。课程设计很是考察个人能力和团队合作协调能力,在面对自己所不熟悉甚至不了解的问题时,是怎样一步步的设计完成给定的任务,及时有成效的解决面临的问题的。从整体的分析设计到后面语句变量的敲定最终完成课题是对自己极其有益的锻炼,从中收获的不仅是知识上的,也是学习经验的积累和思维能力的提升,虽然一次课程设计任务不是那么繁重,可是认真去完成其中的一个个细节也是一种

5、难得的体验。-12-河南理工大学课程设计报告参考文献[1]曹雪虹,张宗橙.《信息论与编码》清华大学出版社.2009.[2]贾宗璞,许合利.《C语言程序设计》人民邮电出版社.2010.[3]盛骤,谢式千,潘承毅.《概率论与数理统计》[M].高等教育出版.1989.-12-河南理工大学课程设计报告附录:源程序1、统计信源熵#include#include#include/*memcpy所需头文件*/#include#defineN1000/*宏定义N,此处N代表读取文本文件最大字符数为100

6、0*/intmain(void){chars[N],M[N];inti=0,j=0,n=0,L=0;intlen,num[27]={0};doubleresult=0,p[27]={0};FILE*f;chartemp[N];/********打开'文件.txt'*******/if(!(f=fopen("D:\VC++6.0\text518.txt","rb"))){printf("文件打开失败!");return0;}while(!feof(f))/*feof检查文件是否结束。如结束,否则返回0.*/{len=fread(temp,1,1000,f

7、);/*fread返回读取的字符个数。从f锁指定的文件中读取长度为1的1000个数据项,存到temp所指向的内存区。返回所读取的数据个数。*/}fclose(f);/*关闭f所指向的文件*/temp[len]='';/*将temp数组元素清空(''空字符)*/memcpy(s,temp,sizeof(temp));/*从temp中拷贝sizeof个字节到目标s中。sizeof返回一个对象或者类型所占的内存字节数*//*****计算各个字母、空格出现数目*****/for(i=0;i

8、+;elseif(s[i]>='a'&

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。