一 汉明码的编解码说明
(一)编码
  Hamming(12,8)
  N=12,表示编码后的比特长度
  K=8,待编码数据的比特长度
  R=N-K=4,校验位的比特长度
  D=3 汉明距离:相邻行之间不同比特数据的最小值
  (D-1)/2=1 纠错能力

  表格1:
  ----------------------------------------------------------------------------------------------------
          单位矩阵(I)                                       生成校验位的矩阵(P)
  ----------------------------------------------------------------------------------------------------
  标号   11      10       9       8       7      6      5     4           3         2     1      0
  编号     x^7     x^6    x^5   x^4   x^3   x^2   x^1   1           c3      c2    c1    c0
  7       1        0       0       0       0      0       0     0           1        1      1      0
  6            0        1       0       0       0      0       0     0           0        1      1      1
  5            0        0       1       0       0      0       0     0           1        0      1      0
  4            0        0       0       1       0      0       0     0           0        1      0      1
  3            0        0       0       0       1      0       0     0           1        0      1      1
  2            0        0       0       0       0      1       0     0           1        1      0      0
  1            0        0       0       0       0      0       1     0           0        1      1      0
  0            0        0       0       0       0      0       0     1           0        0      1      1
  ---------------------------------------------------------------------------------------------------

  G是生成矩阵见表格1
  A[7:0]
  CODE=G x A
  CODE[11]=A[7]
  CODE[10]=A[6]
    ...
  CODE[4]=A[0]
  CODE[3]=A[7]^A[5]^A[3]^A[2] (^为异或)
  CODE[2]=A[7]^A[6]^A[4]^A[2]^A[1]
  CODE[1]=A[7]^A[6]^A[5]^A[3]^A[1]^A[0]
  CODE[0]=A[6]^A[4]^A[3]^A[0]

  (二)解码
    1.求校验矩阵H
      H = {P^T,I(N-K)} (^T表示转置; I(N-K)=I(4)表示4x4单位矩阵)
      H为4x11矩阵

      表2:
      ----------------------------------------------------------------------------------------------------------
        11    10   9   8   7   6   5   4   3   2   1   0
      -----------------------------------------------------------------------------------------------------------
         p7   p6   p5 p4     p3  p2  p1   P0   I3    I2   I1   I0
      -----------------------------------------------------------------------------------------------------------
      3      1      0     1   0   1     1   0   0   1   0   0   0
      2      1      1     0   1   0     1   1   0   0   1   0   0
      1      1      1     1   0   1     0   1   1   0   0   1   0
      0      0      1     0   1   1     0      0   1   0   0   0   1
      ----------------------------------------------------------------------------------------------------------
    2.求校正子S
        S = H^T * U (U为待解码的数据)
        S[3] = U[11]^U[9]^U[7]^U[6]^U[3]
        S[2] = U[11]^U[10]^U[8]^U[6]^U[5]^U[2]
        S[1] = U[11]^U[10]^U[9]^U[7]^U[5]^U[4]^U[1]
        S[0] = U[10]^U[8]^U[7]^U[4]^U[0]
    3.根据假设错误模式定位错误比特
      通过错误模式推导校正子Si,i是index指的是错误模式的种类,因为我们汉明码解码数据有12bit,
    所以错误模式有12种,还包括一种全部正确的模式。
      Si = H^T * Ei

      表3:
      -----------------------------------------------------------------------------
      Ei              H^T       Si      编号
      ----------------------------------------------------------------------------
      12'b0000_0000_0000   1110     0000
      12'b0000_0000_0001   0111     0001    0
      12'b0000_0000_0010   1010       0010    1
      12'b0000_0000_0100   0101     0100    2
      12'b0000_0000_1000   1011     1000    3
      12'b0000_0001_0000   1100     0011    4
      12'b0000_0010_0000   0110     0110    5
      12'b0000_0100_0000   0011     1100    6
      12'b0000_1000_0000   1000     1011    7
      12'b0001_0000_0000   0100     0101    8
      12'b0010_0000_0000   0010     1010    9
      12'b0100_0000_0000   0001     0111    10
      12'b1000_0000_0000           1110    11
      ----------------------------------------------------------------------------
    4.优化数据修正方法
      C[11] = U[11]^(S[3]&S[2]&S[1]&(~S[0]))
      C[10] = U[10]^(~S[3]&S[2]&S[1]&S[0])
      C[9] = U[9]^(S[3]&(~S[2])&S[1]&(~S[0]))
      C[8] = U[8]^(S[3]&(~S[2])&S[1]&S[0])
      C[7] = U[7]^(S[3]&(~S[2])&S[1]&S[0])
      C[6] = U[6]^(S[3]&S[2]&(~S[1])&(~S[0]))
      C[5] = U[5]^((~S[3])&S[2]&S[1]&(~S[0]))
      C[4] = U[4]^((~S[3])&(~S[2])&S[1]&S[0])
      C[3] = U[3]^(S[3]&(~S[2])&(~S[1])&(~S[0]))
      C[2] = U[2]^((~S[3])&S[2]&(~S[1])&(~S[0]))
      C[1] = U[1]^((~S[3])&(~S[2])&S[1]&(~S[0]))
      C[0] = U[0]^((~S[3])&(~S[2])&(~S[1])&S[0])

      例如:
        待编码数据:8'b0011_0101
        编码后数据:CODE[11:4] = 0011_0101
              CODE[3:0] = 0000
              CODE[11:0] = 12'b0011_0101_0000
        经过信道,假设接收到的数据:
              U[11:0] = 12'b0011_0101_0001
        校正子:
            S[3] = 0
            S[2] = 0
            S[1] = 0
            S[0] = 1
            S[3:0] = 4'b0001
        根据表3,可知是在接收数据的最低位发生错误

汉明码(Hamming)编码与纠错原理的更多相关文章

  1. Atitit 视频编码与动画原理attilax总结

    Atitit 视频编码与动画原理attilax总结 1.1. 第一步:实现有损图像压缩和解压1 1.2. 接着将其量化,所谓量化,就是信号采样的步长,1 1.3. 第二步:实现宏块误差计算2 1.4. ...

  2. 【转】Unicode utf8等编码类型的原理

    原文地址http://www.cnblogs.com/daxiong2014/p/4768681.html Unicode utf8等编码类型的原理 1.ASCII码  我们知道,在计算机内部,所有的 ...

  3. Java-IO流之转换流的使用和编码与解码原理

    一.理论: 1.字符流和字节流区别是什么? 字符流=字节流+编码集,在实际读取的时候其实字符流还是按照字节来读取,但是会更具编码集进行查找编码集字典解析相应的字节,使得一次读取出一个字符: 2.什么是 ...

  4. Spring第七弹—依赖注入之注解方式注入及编码解析@Resource原理

        注入依赖对象可以采用手工装配或自动装配,在实际应用中建议使用手工装配,因为自动装配会产生未知情况,开发人员无法预见最终的装配结果. 手工装配依赖对象  手工装配依赖对象,在这种方式中又有两种编 ...

  5. 汉明码(hamming code)

    hamming code用于磁盘RAID 2中, 关于汉明码的讲解可以看这篇博文,介绍的很详细.最重要是最后的结论: 汉明码属于分组奇偶校验,P4P2P1=000,说明接收方生成的校验位和收到的校验位 ...

  6. Base64编码与解码原理

    Base64编码是使用64个可打印ASCII字符(A-Z.a-z.0-9.+./)将任意字节序列数据编码成ASCII字符串,另有“=”符号用作后缀用途. base64索引表 base64编码与解码的基 ...

  7. [转]Unicode utf8等编码类型的原理

    FROM:http://www.cnblogs.com/daxiong2014/p/4768681.html 1.ASCII码          我们知道,在计算机内部,所有的信息最终都表示为一个二进 ...

  8. Nand ECC校验和纠错原理及2.6.27内核ECC代码分析

    ECC的全称是Error Checking and Correction,是一种用于Nand的差错检测和修正算法.如果操作时序和电路稳定性不存在问题的话,NAND Flash出错的时候一般不会造成整个 ...

  9. Unicode utf8等编码类型的原理

    1.ASCII码  我们知道,在计算机内部,所有的信息最终都表示为一个二进制的字符串.每一个二进制位(bit)有0和1两种状态,因此八个二进制位就可以组合出256种状态,这被称为一个字节(byte). ...

随机推荐

  1. Python装饰器的另类用法

    之前有比较系统介绍过Python的装饰器(请查阅<详解Python装饰器>),本文算是一个补充.今天我们一起探讨一下装饰器的另类用法. 语法回顾 开始之前我们再将Python装饰器的语法回 ...

  2. 20165306 Exp6 信息搜集与漏洞扫描

    Exp6 信息搜集与漏洞扫描 一.实践内容概述 1.实践目标 掌握信息搜集的最基础技能与常用工具的使用方法. 2.实践内容 (1)各种搜索技巧的应用 搜索网址目录结构 搜索特定类型的文件 搜索E-Ma ...

  3. Go-延时函数defer

    关于延时调用函数(Deferred Function Calls)      延时调用函数基本语法如下: defer func_name(param-list) {} 当一个函数前有关键字 defer ...

  4. Tensorflow训练和预测中的BN层的坑

    以前使用Caffe的时候没注意这个,现在使用预训练模型来动手做时遇到了.在slim中的自带模型中inception, resnet, mobilenet等都自带BN层,这个坑在<实战Google ...

  5. Vue-admin工作整理(十五):Ajax-跨域问题

    跨域的定义: 解决方法: 1.前端通过配置来解决跨域问题:自定义的vue.config.js配置文件来进行跨域处理:就是只要存在跨域现象 都会代理到一个指定的地址上 devServer: { prox ...

  6. vuex的学习和理解

    初识Vuex: vuex是 vue官方推荐的一个状态管理器,也是vue专用的一个插件.当我们遇到很多状态改变时,组件之间的通信就会变得复杂,这时候vuex的强大就体现出来了. Vuex 应用的核心就是 ...

  7. 文献导读 | Single-Cell Sequencing of iPSC-Dopamine Neurons Reconstructs Disease Progression and Identifies HDAC4 as a Regulator of Parkinson Cell Phenotypes

    文献编号:19Mar - 11 2019年04月23日三读,会其精髓: 相信这种方法的话,那么它的精髓是什么,如何整合出这个core gene set. 首先要考虑样本的选择,样本里是否存在明显的分层 ...

  8. 解密:Amazon亚马逊产品Listing关键词刷单排名原理

    第一:基本概念   在阅读正文之前,请先理解下面的几个基本概念.   核心词[高频词.热词.大词.主词]:长度大约1~2个单词构成,指每天搜索量比较多的词,每个行业对高频词的划分不一样,这个主要看自己 ...

  9. git add * 提示warning: LF will be replaced by CRLF in 解决办法

    在使用git的时候,每次执行 $ git add * 都会提示这样一个警告消息: 虽然说没有什么影响吧. 不过就是觉得太碍眼了, 按照这样设置就没有问题了: git config core.autoc ...

  10. mac电脑上不能用移动硬盘的原因和方法

    原因: 一般性是因为这个移动硬盘的格式是 NTFS 格式的,对于这种格式的磁盘格式,在苹果系统中却是不支持往硬盘里写入数据的 解决方法: 方法一: ntfs的格式分区,这种格式分区与我们的苹果电脑自身 ...