汉明码实现

汉明码实现汉明码实现 可以利用 matlab 中的 encode 和 decode 实现 但是 下面是自己实现的 m 文件程序功能 1 nbsp HanMingH 生成监督矩阵 nbsp nbsp nbsp nbsp nbsp nbsp 2 HanMingG 生成系统生成矩阵 nbsp nbsp nbsp nbsp nbsp nbsp 3 FindR 计算监督位的数目 nbsp nbsp nbsp nbsp nbsp nbsp 4 FindError 生成错误校正图样 用于纠正错误编码 Main nbsp clc

汉明码实现:可以利用matlab中的encode 和decode实现,但是,下面是自己实现的m文件程序

功能:(1) HanMingH 生成监督矩阵

            (2)HanMingG 生成系统生成矩阵

            (3)FindR 计算监督位的数目

           (4)FindError生成错误校正图样,用于纠正错误编码

% Main 

clc; 

clear all; 

close all; 

k = 4; %信息位数 
r = 3; %监督位数
% 生成汉明码对应的监督矩阵H
H = HanMingH(k,r);
% 生成汉明码对应的系统生成矩阵G 
G = HanMingG(H);
%(k+r,k)汉明码的可纠正错误图样
E = FindError(G);
% E = E(:,end:-1:1); 

MaxNum = 1000; 

for ii = 1:MaxNum

        u = randn(1,k) < 0.5;
        c = rem(u*G,2);
%         e = randn(1,k+r) < p(ii); %BSC信道的错误图样
        errpos = randperm(k+r); 
        e = zeros(1,k+r); 
        e(errpos(1)) = 1; % 产生一位错误,完全可以纠正
        
        y = rem(c+e,2);
        s = rem(y*H’,2);%伴随式
        jj = bi2de(s)+1; 
        e2 = E(jj,:); %查出可纠正错误图样
        c2 = rem(y+e2,2); %译码结果
        uu = rem(c2(1:k),2); %译码得到的信息比特
        
end %for 




































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

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

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


相关推荐

  • 搭建scrapy框架[通俗易懂]

    搭建scrapy框架[通俗易懂]搭建scrapy

    2022年9月25日
    3
  • laravel 常用文档

    laravel 常用文档

    2021年10月22日
    43
  • python mechanize使用

    python mechanize使用遇到了一些坑 这个 mechanize 不支持 js 代码 如果遇到了 lt buttonid submit type button onclick sign this signin class btnbtn bannermt10 gt 提交 lt button gt 这样的 js 代码怎么都通不过 要是有人知道怎么弄欢迎告诉我 起因是要褥 packethub 上的羊毛 然后查

    2025年10月16日
    3
  • Android 新特性_Android10使用

    Android 新特性_Android10使用2016年5月19日,谷歌在美国加州的山景城举办了GoogleI/O开发者大会中发布。2016年6月,AndroidN正式命名为“牛轧糖”本届I/O开发者大会上,Google重点介绍了Android系统三个维度:分别是性能、安全和生产力。其中性能主要新增了VulkanAPI与JIT编译器(前者优化图形性能、或者加快软件安装速度);安全性包括新的数据加密方式、恶意网站识别、系统的实时更新;

    2025年9月21日
    5
  • 下标越界的解决方法「建议收藏」

    下标越界的解决方法「建议收藏」如果使用数组时,数组的下标超出数组的可取值范围就会出现这个错误,这个数组可以是自定义的也可以是系统自带的。1.自定义数组:dimarr1(1to5)arr1(10)=555因为arr1数组为1到5,这里却是10,所以就会报下标越界错误。2.系统自带的数组:一个excel工作表表有3张SheetSub下标越界() MsgBoxSheets(4).N

    2022年9月1日
    3
  • shell 获取系统时间_shell脚本打印当前时间

    shell 获取系统时间_shell脚本打印当前时间在shell脚本里常常需要获取系统时间来处理某项操作,今天系统的学习了一下如何获取系统时间。记录如下:linux的系统时间在shell里是可以直接调用系统变量的如:获取今天时期:`date+%Y%m%d`或`date+%F`或$(date+%y%m%d)命令输出结果如下:[root@centi-C sh]# date +%Y%m%d 20120727 [root@c

    2022年10月10日
    2

发表回复

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

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