信息论仙农编码实验报告new_第1页
信息论仙农编码实验报告new_第2页
信息论仙农编码实验报告new_第3页
信息论仙农编码实验报告new_第4页
信息论仙农编码实验报告new_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

仙农编码实验报告姓名:资雁兵学号:20091616310029班级:信息安全一班题目:仙农编码实验要求用仙农编码实现对信源的编码实验步骤将信源符号按概率从大到小的排列,为方便起见,令P(s1)≥p(s2)≥…≥p(sn)令p(s0)=0,用pa(sj)表示第i个码字的累加概率,其中j=i+1,则:pa(sj)=p(s0)+…+p(sj-1)确定满足下列不等式的整数li,并令li为第i个码字的长度为-logp(si)≤li<1-logp(si)将pa(si)和j=i+1用二进制表示,并取小数点后li位作为符号si的编码设计函数voidGetOrder(shannongsn[50],intn)//从大到小排序voidGetCode(shannongsn[50],intn)//获得编码程序使用方法运行程序,先输入所要编码的个数,然后一次输入一个字符作为信源名,以及一个信源的概率,即可得编码源程序#include<stdio.h>#include<math.h>#defineMAX100typedefstruct{ floata;//概率 floatb;//码长intcode[MAX];//编码数组}xiannong;//结构体voidScanfNode(xiannongxiannode[MAX],intn){inti;//输入各个概率 for(i=0;i<n;i++){ printf("请输入编码的概率\n"); scanf("%f",&xiannode[i].a);printf("\n"); }}voidGetNode(xiannongxiannode[MAX],intn){ inti;//从大到小排序 intj; floatk=1.0; for(i=0;i<n;i++){ for(j=i;j<n;j++) if(xiannode[j].a>xiannode[i].a){ k=xiannode[j].a; xiannode[j].a=xiannode[i].a; xiannode[i].a=k; } }}voidAddOrder(xiannongxiannode[MAX],intn,floatpa[MAX]){//累加到pa[]数组intj;pa[1]=0;for(j=1;j<=n;j++){pa[j+1]=pa[j]+xiannode[j-1].a; printf("%f",pa[j]);}}voidGetOrder(xiannongxiannode[MAX],intn,floatpa[MAX]){inti,k,m;//把小数转换到二进制 floatj; for(i=0;i<n;i++){//得到编码的码长 j=-log(xiannode[i].a)/log(2.0); xiannode[i].b=j; //printf("%f\n",xiannode[i].b);m=j; if(m==j) xiannode[i].b=m; else xiannode[i].b=m+1; }// for(i=1;i<=n;i++){//生成二进制 for(k=0;k<xiannode[i-1].b;k++){ pa[i]=pa[i]*2; if(pa[i]<1) xiannode[i-1].code[k]=0; else{xiannode[i-1].code[k]=1; pa[i]=pa[i]-1;} } }}/***************主函数****************/voidmain(){xiannongxiannode[MAX];floatpa[MAX];intn,i,j;printf("请输入编码的个数\n");scanf("%d",&n);ScanfNode(xiannode,n);GetNode(xiannode,n);AddOrder(xiannode,n,pa);GetOrder(xiannode,n,pa);/*for(i=0;i<n;i++){printf("%3f",xiannode[i].a);}printf("\n");for(i=0;i<n;i++){printf("%f",xiannode[i].b);}for(i=1;i<=n;i++){printf("%f",pa[i]);}测试专用*/printf("\n");for(i=0;i<n;i++){ printf("第%d个仙农编码",i+1); for(j=0;j<xiannode[i

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论