单比特纠错海明码校验位的计算过程
生成单比特纠错海明码
海明码校验位长度应如是:
设一个 K 比特的信息串的单比特纠错海明码需要的校验比特位数为 r ,则他们有如下关系:(除了考试,不用记公式)
原理:求海明码时的一项基本考虑是确定所需最少的校验位数 r 。考虑长度为 k 位的信息,若附加了 r 个校验位,则所发送的总长度为 k+r 。在接收端中要进行 r 个奇偶检查,每个检查结果或是真或是伪。这个奇偶检查的结果可以表示成一个 r 位的二进制数,它可以确定最多 种不同状态。 这些状态中必有一个其所有奇偶测试都是真的,它便是判定信息正确的条件。于是剩下的(
-1)种状态,可以用来判定误码的位置。
确定校验比特和信息比特的位置:
首先我们把原来的二进制信息串当成一个常规的二进制数,比如 1001011 ,右边是低位,左边是高位,那么:
理论上校验比特可以放在任何位置,但习惯都是将校验比特 放在
(1、2、4、8、16……)位置上 ( k
0 ) ,其余位置依次放原来二进制串中的信息比特
( 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 ~
单比特纠错海明码校验位的计算过程相关推荐
- EAN码校验位的计算方法
/** EAN码校验位的计算方法 从代码位置序号2开始,所有偶数位的数字代码求和为a. 将上步中的a乘以3为a. 从代码位置序号3开始,所有奇数位的数字代码求和为b. 将 ...
- 海明码java编程,海明码校验程序设计
海明码校验程序设计 1. 需求分析 (1)海明码编码: 输入:一串二进制数据串 输出:插入海明码后的二进制数据串 (2)海明码纠错: 输入:一串含海明码的二进制数据串 输出:通过海明码校验,检查该二进 ...
- 海明校验码的计算及检验
海明校验码的计算及检验 目录 海明校验码的计算及检验 知识背景 计算海明校验码 步骤一:计算校验码位数 步骤二:确定校验组 步骤三:计算校验码的值得出海明校验码 利用海明校验码校验数据 其他 总结 最 ...
- java中单,单|的意思,按位操作符详述
从事java多年,日常多用&&,||这类逻辑操作符进行业务的编码使用,也是孤陋寡闻,偶然发现还有单&,单|等操作符的使用.查阅资料后得知其就是按位操作符,下面就是Java设计思 ...
- 哈佛大学联合团队新突破:在计算过程中实现量子纠错
实验室成员:左起依次为Dolev Bluvstein.Harry Levine(视频成员).Sepehr Ebadi.Mikhail Lukin (图片来源:哈佛大学) 试想一下,一边飞行一边制造飞机 ...
- 【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 ...
- (混沌序列统计特性)单比特频率测试---matlab
单比特频率测试(The Frequency (Monobit)Test) : 计算序列中比特1出现的频率,这个值越接近1/2,则说明序列的随机性越好. 实现: clc;clear; h=0.002;t ...
- python计算小数点后有几位_数学提高小数除法竖式计算过程
除数是小数时:先把除数变成整数,除数扩大到原来的多少倍,被除数也要扩大到原来的多少倍(即小数点也向右移动几位,位数不够的用0补),然后按照除数是整数的除法进行计算.计算小数除法,除到被除数的末尾仍有余 ...
- FPGA逻辑设计回顾(8)单比特信号的CDC处理方式之Toggle同步器
文章目录 前言 脉冲反馈展宽同步器技术补充说明 RTL代码 行为仿真 低电平脉冲的展宽处理 切换同步器的原理与实现 RTL实现 前言 本文首发自:FPGA逻辑设计回顾(8)单比特信号的CDC处理方式之 ...
最新文章
- 新技术“红”不过十年,半监督学习为什么是个例外?
- 客户端JavaScript加密数据,服务端Java解密数据
- Java的List排序
- java json开发包 fastjson 简介
- pyhton中的魔术方法
- c语言课本第八章答案,c语言第八章字符串编程答案
- socket技术难点
- ffmpeg解码流程 turorial5详解
- python快速入门课堂笔记_Python 快速入门笔记(9):模块和包
- html 显示原始文本,Json显示为HTML文本 - 不是原始格式
- java runnable 异常_Java实现多线程异常捕获Runnable的案例
- delphi语言转为汇编语言_计算机语言
- CSS3和jQuery实现的自定义美化Checkbox和Radiobox
- POJ 1873 The Fortified Forest(凸包)题解
- 基于php网上零食商店管理系统获取(php毕业设计)
- 4芯网线和8芯网线的网速有什么区别
- php5.6安装php-gd,centos73下php5.6安装GD库
- 访问chm文件出现 已取消到该网页的导航的解决方法
- 这2个在线资源网千万别错过,老司机人手一份,一年省下好几千
- 点赞功能模块-文章点赞功能实现