下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
仙农编码实验报告姓名:资雁兵学号: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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 先进技术制造
- 2024人教版八年级英语上册 Unit 6 Plan for Yourself 单元测试题
- 侦察监视技术
- 企鹅英文介绍课件
- 法警面试题及答案
- (中级)收银员职业技能鉴定理论考试浓缩题库(附答案)
- 小学五年级语文上册第一单元单元预习单设计课件
- 小学五年级语文上册第八单元读书方法总结指导课件
- 2026年赤峰市教育局直属学校第二批次通过“绿色通道”引进高层次教师备考题库有完整答案详解
- 2026年北京市平谷区政务服务中心综合工作人员招聘备考题库及答案详解(夺冠系列)
- DRBFM的展开详细解读2
- 四环素的发酵工艺课件
- 中山大学研究生因公临时出国境申报表
- 泥浆护壁钻孔灌注桩的施工
- 征信调研报告3篇
- YY/T 0127.18-2016口腔医疗器械生物学评价第18部分:牙本质屏障细胞毒性试验
- LY/T 2677-2016油茶整形修剪技术规程
- GB/T 8924-2005纤维增强塑料燃烧性能试验方法氧指数法
- GB/T 20969.2-2021特殊环境条件高原机械第2部分:高原对工程机械的要求
- 马克思主义经典著作导读课后练习试题答案与解析搜集
- 快速记忆法训练课程速读课件
评论
0/150
提交评论