生成单比特纠错海明码


  • 海明码校验位长度应如是:

设一个 K 比特的信息串的单比特纠错海明码需要的校验比特位数为 r ,则他们有如下关系:(除了考试,不用记公式)

原理:求海明码时的一项基本考虑是确定所需最少的校验位数 r 。考虑长度为 k 位的信息,若附加了 r 个校验位,则所发送的总长度为 k+r 。在接收端中要进行 r 个奇偶检查,每个检查结果或是真或是伪。这个奇偶检查的结果可以表示成一个 r 位的二进制数,它可以确定最多  种不同状态。 这些状态中必有一个其所有奇偶测试都是真的,它便是判定信息正确的条件。于是剩下的(-1)种状态,可以用来判定误码的位置。

  • 确定校验比特和信息比特的位置:

首先我们把原来的二进制信息串当成一个常规的二进制数,比如 1001011 ,右边是低位,左边是高位,那么:

理论上校验比特可以放在任何位置,但习惯都是将校验比特  放在 (1、2、4、8、16……)位置上 ( k0 ) ,其余位置依次放原来二进制串中的信息比特  ( i  1)。

方便关注原理,我们把位置转化成对应的二进制数(右边是低位,左边是高位):

位置 1011 1010 1001 1000 0111 0110 0101 0100 0011 0010 0001
信息比特及校验比特

原信息比特 1 0 0   1 0 1   1    

那么接下来我们直接开始了:

 :其对应的位置是 (即0001),那我们把位置第一位为1对应的信息比特拿出来求异或,结果即为 :

 =          = 0

 :其对应的位置是(即0010),那我们把位置第二位为1对应的信息比特拿出来求异或,结果即为 :

 =          = 1

 :其对应的位置是(即0100),那我们把位置第三位为1对应的信息比特拿出来求异或,结果即为 :

 =      = 0

 :其对应的位置是(即1000),那我们把位置第四位为1对应的信息比特拿出来求异或,结果即为 :

 =      = 1

假如还有更多,以此类推……

于是将这些校验比特放入对应位置,得到:信息序列1001011 对应的单比特纠错海明码为:10011010110

skr  ~

  • 那么这些位置的计算原理是什么呢?接收方如何校验?

将每个信息比特的位置写成2的次幂之和的形式有:(这里的信息比特不是上面的例子,但以此类推)

校验位与通过异或生成它的那些信息位构成偶校验关系,则接收方利用相应的偶校验来验证:

  • 海明码计算小结:

以上是我上计算机网络专业课后对单比特纠错海明码的个人总结,图片素材来源于老师上课的PPT。

这是我第一次写博客……这将是很好的学习笔记,我也在这里分享见解。

Skr ~

单比特纠错海明码校验位的计算过程相关推荐

  1. EAN码校验位的计算方法

    /**    EAN码校验位的计算方法    从代码位置序号2开始,所有偶数位的数字代码求和为a.    将上步中的a乘以3为a.    从代码位置序号3开始,所有奇数位的数字代码求和为b.    将 ...

  2. 海明码java编程,海明码校验程序设计

    海明码校验程序设计 1. 需求分析 (1)海明码编码: 输入:一串二进制数据串 输出:插入海明码后的二进制数据串 (2)海明码纠错: 输入:一串含海明码的二进制数据串 输出:通过海明码校验,检查该二进 ...

  3. 海明校验码的计算及检验

    海明校验码的计算及检验 目录 海明校验码的计算及检验 知识背景 计算海明校验码 步骤一:计算校验码位数 步骤二:确定校验组 步骤三:计算校验码的值得出海明校验码 利用海明校验码校验数据 其他 总结 最 ...

  4. java中单,单|的意思,按位操作符详述

    从事java多年,日常多用&&,||这类逻辑操作符进行业务的编码使用,也是孤陋寡闻,偶然发现还有单&,单|等操作符的使用.查阅资料后得知其就是按位操作符,下面就是Java设计思 ...

  5. 哈佛大学联合团队新突破:在计算过程中实现量子纠错

    实验室成员:左起依次为Dolev Bluvstein.Harry Levine(视频成员).Sepehr Ebadi.Mikhail Lukin (图片来源:哈佛大学) 试想一下,一边飞行一边制造飞机 ...

  6. 【Verilog 语法】~ if-else、case、for、generate、函数 function、任务 task、过程块、位宽计算、阻塞/非阻塞、时间尺度、存储器设计、

    文章目录 1. if-else 1.1 设计要点 2. case 2.1 概述 2.2 语法 2.3 注意事项 3. for 3.1 区别与其它语言的for循环 3.2 注意事项 4. generat ...

  7. (混沌序列统计特性)单比特频率测试---matlab

    单比特频率测试(The Frequency (Monobit)Test) : 计算序列中比特1出现的频率,这个值越接近1/2,则说明序列的随机性越好. 实现: clc;clear; h=0.002;t ...

  8. python计算小数点后有几位_数学提高小数除法竖式计算过程

    除数是小数时:先把除数变成整数,除数扩大到原来的多少倍,被除数也要扩大到原来的多少倍(即小数点也向右移动几位,位数不够的用0补),然后按照除数是整数的除法进行计算.计算小数除法,除到被除数的末尾仍有余 ...

  9. FPGA逻辑设计回顾(8)单比特信号的CDC处理方式之Toggle同步器

    文章目录 前言 脉冲反馈展宽同步器技术补充说明 RTL代码 行为仿真 低电平脉冲的展宽处理 切换同步器的原理与实现 RTL实现 前言 本文首发自:FPGA逻辑设计回顾(8)单比特信号的CDC处理方式之 ...

最新文章

  1. 新技术“红”不过十年,半监督学习为什么是个例外?
  2. 客户端JavaScript加密数据,服务端Java解密数据
  3. Java的List排序
  4. java json开发包 fastjson 简介
  5. pyhton中的魔术方法
  6. c语言课本第八章答案,c语言第八章字符串编程答案
  7. socket技术难点
  8. ffmpeg解码流程 turorial5详解
  9. python快速入门课堂笔记_Python 快速入门笔记(9):模块和包
  10. html 显示原始文本,Json显示为HTML文本 - 不是原始格式
  11. java runnable 异常_Java实现多线程异常捕获Runnable的案例
  12. delphi语言转为汇编语言_计算机语言
  13. CSS3和jQuery实现的自定义美化Checkbox和Radiobox
  14. POJ 1873 The Fortified Forest(凸包)题解
  15. 基于php网上零食商店管理系统获取(php毕业设计)
  16. 4芯网线和8芯网线的网速有什么区别
  17. php5.6安装php-gd,centos73下php5.6安装GD库
  18. 访问chm文件出现 已取消到该网页的导航的解决方法
  19. 这2个在线资源网千万别错过,老司机人手一份,一年省下好几千
  20. 点赞功能模块-文章点赞功能实现

热门文章

  1. 安装和配置Tripwire 加强你的Linux系统安全
  2. 请输入6~16位密码
  3. 【分布式】怎么保证一致性
  4. Java的新项目学成在线笔记-day9(十二)
  5. multism中ui和uo应该怎么表示_南昌大学仿真实验(multism) -
  6. 关于斯坦福句法剖析器 -- 答网友
  7. 微信小程序——列表遍历排序方法
  8. 如何从身份证号中提取年月日
  9. 通过微信扫码登录网站流程
  10. 自然人股权转让需要评估吗