74汉明码编码原理
汉明码编码电路的工作原理

汉明码编码电路的工作原理
汉明码编码电路是一种通过增加冗余位来检测和纠正数据传输错误的编码器。
其工作原理如下:
1. 数据输入:将需要传输的数据输入到汉明码编码电路的数据输入端。
2. 编码器:编码器根据预定的汉明码编码规则对输入的数据进行编码。
具体编码规则包括确定冗余位的位置和计算校验位的值。
冗余位的个数根据数据的长度和校验位确定。
3. 冗余位计算:编码器通过对数据进行一系列的逻辑运算,计算出冗余位的值。
冗余位的值是根据数据中的每一位进行计算的,它代表了数据的的校验信息。
4. 编码输出:编码器将编码后的数据和计算的冗余位一起输出。
5. 传输过程:编码后的数据和冗余位被传输给解码器。
6. 解码器:解码器根据汉明码编码规则对接收到的数据进行解码,计算出接收到的数据中是否存在错误,并尝试纠正错误。
7. 错误检测和纠正:解码器通过对接收到的数据和冗余位进行逻辑运算,判断是否存在错误。
如果存在错误,解码器会尝试根据冗余位的值来纠正错误的数据。
如果无法纠正错误,解码器会发出错误报警信号。
通过增加冗余位和校验位,汉明码编码电路可以在数据传输过程中检测出错误,并在一定程度上纠正这些错误。
这使得数据传输变得更加可靠,提高了系统的容错性。
matlab(74)汉明码和(74)循环码的编程设计

二、创新实验设计创新实验一:(7,4)汉明码的编码与译码实现1、实验目的实现(7,4)汉明码的编码与译码,通过这次实验不但加深了对汉明码编码和译码原理了解,而且对线性分组码有所了解。
2、实验原理线性分组码的构造方法比较简单、理论较为成熟,应用比较广泛。
汉明码是一种能够纠正一个错码的效率比较高的线性分组码,下面以(7,4)码为例就汉明码的编码与译码分别进行介绍:(1)编码原理一般来说,若汉明码长为n ,信息位数为k ,则监督位数r=n-k 。
若希望用r 个监督位构造出r 个监督关系式来指示一位错码的n 种可能位置,则要求21r n -≥或211rk r -≥++ (1)设汉明码(n,k )中k=4,为了纠正一位错码,由式(1)可知,要求监督位数r ≥3。
若取r=3,则n=k+r=7。
这样就构成了(7,4)码。
用6543210a a a a a a a 来表示这7个码元,用123s s s 的值表示3个监督关系式中的校正子,则123s s s 的值与错误码元位置的对应关系可以规定如表1所列。
表2.1 校正子和错码位置的关系则由表1可得监督关系式:16542s a a a a =⊕⊕⊕()226531s a a a a =⊕⊕⊕()3 36430s a a a a =⊕⊕⊕()4 在发送端编码时,信息位6543a a a a 的值决定于输入信号,因此它们是随机的。
监督位2a 、1a 、0a 应根据信息位的取值按监督关系来确定,为使所编的码中无错码,则123,,S S S 等于0,即65426531643000(5)0a a a a a a a a a a a a ⊕⊕⊕=⎧⎪⊕⊕⊕=⎨⎪⊕⊕⊕=⎩方程组(5)可等效成如下矩阵形式6543210111010001101010010110010a a a a a a a ⎡⎤⎢⎥⎢⎥⎢⎥⎡⎤⎡⎤⎢⎥⎢⎥⎢⎥=⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎣⎦⎣⎦⎢⎥⎢⎥⎢⎥⎣⎦(6)式(6)可简化为0T T HA =,H 为监督矩阵,则由式(6)可得到监督矩阵11101001101010=[P I ] (7)1011001r H ⎡⎤⎢⎥=⎢⎥⎢⎥⎣⎦因为生成矩阵'=[I Q]=[I ]k k G P ,所以由(7)得生成矩阵G 如下:[]k 10001110100110[']00101010001011k G I Q I P ⎡⎤⎢⎥⎢⎥===⎢⎥⎢⎥⎣⎦然后利用信息位和生成矩阵G 相乘产生整个码组,即有[][]65432106543=(8)A a a a a a a a a a a a G=其中A 为整个码组矩阵,6543a a a a 是信息位。
二元(7,4)汉明码的编译码分析与实验研究

设计(论文)题目:二元(7,4)汉明码的编译码分析与实验研究摘要汉明码(Hamming Code)在电信领域内属于线性分组码,或者可以称为线性调试码。
它是以发明者理查德·卫斯里·汉明的名字命名的。
汉明码在传输信息序列时插入校验码,当计算机存储或传输数据时,或者在信道传输的过程中,可能会产生误码,即信息错位,以检测并纠正一个比特错误。
由于汉明编码简单,它们被广泛应用于实际传输中。
本文主要涉及二元(7,4)汉明码的编码、译码及实现,以及信息论与编码的相关知识。
对于二元(7,4)汉明码C,其校验矩阵为H,汉明距离d(C)=3的充要条件是校验矩阵H的任意2个列矢量线性无关,且任意3个列向量是线性相关。
监督矩阵H生成的码是(7,4,3)码。
所以接下来问题是构建监督矩阵H和生成矩阵G,找出编码器和译码器输入和输出对应的逻辑关系,画出汉明码的编码电路图和译码电路图,通过VHDL语言实现汉明码的编码过程和译码过程,观察仿真波形,来观察实验结果。
关键字:二元(7,4)汉明码;生成矩阵;监督矩阵;编码;译码;AbstractHamming code field belongs to the linear block codes in the telecommunications, or you could be called linear debugging code. It is the inventor, Richard Wesley Hamming named after. Hamming code inserted into the check code in information transmission sequence, when the computer refers for data storage,or in the process of channel transmission. it may produce error, namely the informational burst-error, and Hamming Code could detect and correct errors one bit. Due to its simple hamming coding, they are widely used in the actual transmission.This paper mainly relates to binary (7, 4) hamming code about coding, decoding and realization, as well as the related knowledge of Information Theory and Coding. For binary (7, 4) hamming code called C, its supervision matrix of the H, hamming distance d (C) = 3 of any two of the sufficient and necessary condition is checking matrix H column vector linearly independent, and arbitrary three column vector is linearly dependent. Supervision of matrix H generated code is (7, 3) code. So the next problem is to build the generator matrix G and supervision matrix H, generate the encoder and decoder ,inputs and outputs corresponding logical relationship, as well as,draw the circuit diagram of hamming code encoding and decoding circuit diagram, using VHDL language realization of hamming code encoding and decoding process, observing the simulation waveform and the result of the experiment.Keywords:binary (7, 4) hamming code ;generator matrix;supervision matrix;encoding ;decoding ;引言汉明码是最早提出来的用于纠错的编码,它是一类可以纠正一位错误的高效的线性分组码。
汉明码的原理

汉明码的原理汉明码是一种错误检测和纠正的编码方式,它以理论家理查德·汉明的名字命名。
汉明码通过在数据中插入冗余位来检测和纠正错误。
它的原理是在发送数据的时候,根据一定的规则生成一组冗余位,并将其附加到原始数据中。
接收方在接收到数据后,通过对数据进行校验,可以检测出错误的位置,并进行纠正。
汉明码的生成规则如下:假设发送方要发送一个m位的数据,需要生成r位的冗余位。
冗余位的数量r需要满足以下条件:2^r ≥ m + r + 1。
也就是说,冗余位的数量需要满足能够容纳原始数据和冗余位的总长度。
生成冗余位的方法是通过对原始数据进行一系列的异或运算。
首先,确定冗余位的位置,通常是2的幂次方位置,比如第1位、第2位、第4位等。
然后,对于每一个冗余位,计算其值,即将与其相关的原始数据位进行异或运算,并将结果作为冗余位的值。
最后,将生成的冗余位附加到原始数据中,形成最终的发送数据。
接收方在接收到数据后,需要对数据进行校验。
校验的过程是将接收到的数据和冗余位进行一系列的异或运算,然后检查结果。
如果结果为0,则说明数据没有错误;如果结果不为0,则说明数据存在错误,并且错误的位置对应于校验结果中值为1的位。
在纠正错误的时候,可以通过计算错误位置的二进制表示来确定具体是哪一位出现了错误。
例如,如果校验结果中值为1的位的位置是5,则说明第5位出现了错误。
接下来,将错误位的值进行取反操作,即从0变成1,或者从1变成0,然后将纠正后的数据发送给上层应用。
汉明码的好处是能够检测出错误的位置并进行纠正,从而提高数据传输的可靠性。
它广泛应用于通信和存储系统中,特别是在数据传输距离较远或者噪声较大的情况下,汉明码可以有效地保证数据的完整性和准确性。
总结起来,汉明码是一种通过插入冗余位来实现错误检测和纠正的编码方式。
它的原理是在发送数据的时候,根据一定的规则生成一组冗余位,并将其附加到原始数据中。
接收方在接收到数据后,通过对数据进行校验,可以检测出错误的位置,并进行纠正。
74汉明码编码译码函数matlab

74汉明码编码译码函数matlab73汉明码简介73汉明码(Hamming Code),是由理查德·哈明(Richard W. Hamming)于1950年提出的一种能够纠错的编码方式。
在数据的通信和储存中,由于比特位(Bit)的传输或存储可能出错,使用汉明码可以检测和纠正错误,保证数据的可靠性。
而且,它具有编码效率高、纠错能力强等优越性。
74汉明码编码原理74汉明码是由7个数据位加上3个校验位组成的码。
通过在7个数据位中插入3个校验位,使得每个校验位都对特定的数据位进行检验,并在校验位位上调整,使其满足校验规则。
74汉明码编码规则如下:1. 将数据位插入到编码位中:将数据位a1、a2、a3、a4、a5、a6、a7插入到编码位b1、b2、b3、c1、c2、c3、c4中,并按照如下公式进行计算:b1 = a1b2 = a2b3 = a3c1 = a4c2 = a5c3 = a6c4 = a72. 计算每个校验位的值:每个校验位都要对特定的数据位进行检验,并在校验位位上调整,使其满足校验规则。
校验位p1:检验b1、 b2、 c1 是否为1的个数是否为奇数。
校验位p2:检验b1、 b3、 c2 是否为1的个数是否为奇数。
校验位p3:检验b2、 b3、 c3 是否为1的个数是否为奇数。
3. 将所有编码位合并得到74汉明码:将校验位及数据位组成新的编码位,形成74汉明码。
74汉明码译码原理74汉明码译码的规则如下:1. 监测码:检测接受到的数据中是否存在错误。
利用4个校验位检测数据中的错误。
校验位p1:检验b1、 b2、 c1 是否为1的个数是否为奇数。
校验位p2:检验b1、 b3、 c2 是否为1的个数是否为奇数。
校验位p3:检验b2、 b3、 c3 是否为1的个数是否为奇数。
校验位p4:检验数据位a1、 a2、 a3、 a4、 a5、 a6、 a7以及校验位p1、 p2、 p3是否为1的个数是否为奇数。
74汉明码编码原理

74汉明码编码1. 线性分组码是一类重要的纠错码,应用很广泛。
在(n ,k )分组码中,若 冗余位是按线性关系模2相加而得到的,则称其为线性分组码。
现在以(7,4)分组码为例来说明线性分组码的特点。
其主要参数如下:码长:21m n =-信息位:21m k m =--校验位:m n k =-,且3m ≥最小距离:min 03d d ==其生成矩阵G (前四位为信息位,后三位为冗余位)如下:系统码可分为消息部分和冗余部分两部分,根据生成矩阵,输出码字可按下式计算:所以有信息位 冗余位由以上关系可以得到(7,4)汉明码的全部码字如下所示。
1000110010001100101110001101G ⎡⎤⎢⎥⎢⎥=⎢⎥⎢⎥⎣⎦3210321010001100100011(,,,)(,,,)00101110001101b a a a a G a a a a ⎡⎤⎢⎥⎢⎥=•=•⎢⎥⎢⎥⎣⎦63524130b a b a b a b a ====231013210210b a a a b a a a b a a a =⊕⊕=⊕⊕=⊕⊕2.用C++编写(7,4)汉明码的思路如下:16个不同信息序列的产生:调用stidlib包中的rand()产生二进制伪随机序列,为了产生16个不同信息序列,共分两步产生:第一步:先产生一个伪随机序列并保留,将它赋给第一个信息序列V[0];i=0;for(j=0;j<4;j++)v[i][j]=rand()%2;第二步:同样产生一个序列,产生后要与在它以前产生的信息序列相比较,如果产生的信息序列与前面的序列都不同,则保留这个信息序列,并进行产生下一个信息序列;如果产生的信息序列与前面的序列有相同的,则此次产生的序列无效,需从新产生信息序列。
此过程中需定义一个比较函数进行比较,其代码如下:for(i=1;i<16;i++){Lable:for(j=0;j<4;j++)v[i][j]=rand()%2;for(k=0;k<i;k++){ //判断随机产生的信息序列与前面的信息序列是否相同if( vedict( v[i],v[k]))continue; //如果产生的信息序列与前面的序列都不同,则保留这个信息序列,并进行产生下一个信息序列elsegoto lable; //如果产生的信息序列与前面的序列有相同的,则此次产生的序列无效,跳转到标签lable处,从新产生信息序列}}进行判断的函数为:bool vedict(int a[],int b[]){int m;for(m=0;m<4;m++){switch(m){case 0:if(a[m]!=b[m])return true;else continue;break;case 1:if(a[m]!=b[m])return true;elsecontinue;break;case 2:if(a[m]!=b[m])return true;else continue;break;case 3:if(a[m]!=b[m])return true;elsereturn false;}}}74汉明码的生成:利用线性关系式 : 信息位冗余位用两个for 循环,并分两部分求解:前四位用信息位方程,后三位用 冗余位方程(通过异或运算求得);其代码如下:for(i=0;i<16;i++){for(j=0;j<7;j++){if(j<4)u[i][j]= v[i][j];if(j==4)u[i][j]=(v[i][0]^v[i][2])^v[i][3];if(j==5)u[i][j]=(v[i][0]^v[i][1])^v[i][2];if(j==6)u[i][j]=(v[i][1]^v[i][2])^v[i][3];cout << u[i][j] << " ";}cout << endl;}3. 其总代码为:#include<iostream.h>#include<stdlib.h>void main(){int g[4][7]={{1,0,0,0,1,1,0},{0,1,0,0,0,1,1},{0,0,1,0,1,1,1},{0,0,0,1,1,0,1}};//声明生成矩阵63524130b a b a b a b a ====231013210210b a a a b a a a b a a a =⊕⊕=⊕⊕=⊕⊕int v[16][4];//声明信息序列int u[16][7];int i,j,k;cout << "生成矩阵为:" << endl;//输出生成矩阵for(i=0;i<4;i++){for(j=0;j<7;j++)cout << g[i][j] << " ";cout << endl;}bool vedict(int a[],int b[]);//声明判断函数cout << "消息序列:"<< endl;//随机产生信息位序列i=0;for(j=0;j<4;j++)v[i][j]=rand()%2;for(i=1;i<16;i++){lable:for(j=0;j<4;j++)v[i][j]=rand()%2;for(k=0;k<i;k++){ //判断随机产生的信息序列与前面的信息序列是否相同if( vedict( v[i],v[k]))continue; //如果产生的信息序列与前面的序列都不同,则保留这个信息序列,并进行产生下一个信息序列elsegoto lable; //如果产生的信息序列与前面的序列有相同的,则此次产生的序列无效,跳转到标签lable处,从新产生信息序列}}for(i=0;i<16;i++){ //输出信息序列for(j=0;j<4;j++)cout << v[i][j] << " ";cout << endl;}cout << "74汉明码为:" <<endl;for(i=0;i<16;i++){for(j=0;j<7;j++){if(j<4)u[i][j]= v[i][j];if(j==4)u[i][j]=(v[i][0]^v[i][2])^v[i][3];if(j==5)u[i][j]=(v[i][0]^v[i][1])^v[i][2];if(j==6)u[i][j]=(v[i][1]^v[i][2])^v[i][3];cout << u[i][j] << " ";}cout << endl;}}bool vedict(int a[],int b[]){int m;for(m=0;m<4;m++){switch(m){case 0:if(a[m]!=b[m])return true;else continue;break;case 1:if(a[m]!=b[m])return true;elsecontinue;break;case 2:if(a[m]!=b[m])return true;else continue;break;case 3:if(a[m]!=b[m])return true;elsereturn false;}}}编译、运行结果为:。
(7,4)汉明码编译码程序说明讲诉

(7,4)汉明码编译码原理程序说明书1、线性分组码假设信源输出为一系列二进制数字0和1.在分组码中,这些二进制信息序列分成固定长度的消息分组(message blocks )。
每个消息分组记为u ,由k 个信息位组成。
因此共有2k种不同的消息。
编码器按照一定的规则将输入的消息u 转换为二进制n 维向量v ,这里n>k 。
此n 维向量v 就叫做消息u 的码字(codeword )或码向量(code vector )。
因此,对应于2k种不同的消息,也有2k种码字。
这2k个码字的集合就叫一个分组码(block code )。
一个长度为n ,有2k个码字的分组码,当且仅当其2k个码字构成域GF (2)上所有n维向量空间的一个k 维子空间时被称为线性(linear )(n ,k )码。
对于线性分组码,希望它具有相应的系统结构(systematic structure ),其码字可分为消息部分和冗余校验部分两个部分。
消息部分由k 个未经改变的原始信息位构成,冗余校验部分则是n-k 个奇偶校验位(parity-check )位,这些位是信息位的线性和(linear sums )。
具有这样的结构的线性分组码被称为线性系统分组码(linear systematic block code )。
本实验以(7,4)汉明码的编译码来具体说明线性系统分组码的特性。
其主要参数如下:码长:21mn =- 信息位:21m k m =-- 校验位:m n k =-,且3m ≥ 最小距离:min 03d d ==由于一个(n ,k )的线性码C 是所有二进制n 维向量组成的向量空间n V 的一个k 维子空间,则可以找到k 个线性独立的码字,0,1,1k g g g -…… ,使得C 中的每个码字v 都是这k 个码字的一种线性组合。
(7,4)汉明码的生成矩阵如下,前三位为冗余校验部分,后四位为消息部分。
0123 1 1 0 1 0 0 00 1 1 0 1 0 01 1 1 0 0 1 01 0 1 0 0 0 1g g G g g ⎧⎫⎧⎫⎪⎪⎪⎪⎪⎪⎪⎪==⎨⎬⎨⎬⎪⎪⎪⎪⎪⎪⎪⎪⎩⎭⎩⎭如果()0123u u u u u =是待编码的消息序列,则相应的码字可如下给出:()0101230011223323g g v u G u u u u u g u g u g u g g g ⎧⎫⎪⎪⎪⎪===+++⎨⎬⎪⎪⎪⎪⎩⎭编码结构即码字()0123456v v v v v v v v =,对于(7,4)线性分组码汉明码而言,3456,,,v v v v 为所提供的消息序列,而0356v v v v =⊕⊕,1345v v v v =⊕⊕,2456v v v v =⊕⊕。
matlab(74)汉明码和(74)循环码的编程设计

二、创新实验设计创新实验一:(7,4)汉明码的编码与译码实现1、实验目的实现(7,4)汉明码的编码与译码,通过这次实验不但加深了对汉明码编码和译码原理了解,而且对线性分组码有所了解。
2、实验原理线性分组码的构造方法比较简单、理论较为成熟,应用比较广泛。
汉明码是一种能够纠正一个错码的效率比较高的线性分组码,下面以(7,4)码为例就汉明码的编码与译码分别进行介绍:(1)编码原理一般来说,若汉明码长为n ,信息位数为k ,则监督位数r=n-k 。
若希望用r 个监督位构造出r 个监督关系式来指示一位错码的n 种可能位置,则要求21r n -≥或211rk r -≥++ (1)设汉明码(n,k )中k=4,为了纠正一位错码,由式(1)可知,要求监督位数r ≥3。
若取r=3,则n=k+r=7。
这样就构成了(7,4)码。
用6543210a a a a a a a 来表示这7个码元,用123s s s 的值表示3个监督关系式中的校正子,则123s s s 的值与错误码元位置的对应关系可以规定如表1所列。
表2.1 校正子和错码位置的关系则由表1可得监督关系式:16542s a a a a =⊕⊕⊕()226531s a a a a =⊕⊕⊕()3 36430s a a a a =⊕⊕⊕()4 在发送端编码时,信息位6543a a a a 的值决定于输入信号,因此它们是随机的。
监督位2a 、1a 、0a 应根据信息位的取值按监督关系来确定,为使所编的码中无错码,则123,,S S S 等于0,即65426531643000(5)0a a a a a a a a a a a a ⊕⊕⊕=⎧⎪⊕⊕⊕=⎨⎪⊕⊕⊕=⎩方程组(5)可等效成如下矩阵形式6543210111010001101010010110010a a a a a a a ⎡⎤⎢⎥⎢⎥⎢⎥⎡⎤⎡⎤⎢⎥⎢⎥⎢⎥=⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎢⎥⎣⎦⎣⎦⎢⎥⎢⎥⎢⎥⎣⎦(6)式(6)可简化为0T T HA =,H 为监督矩阵,则由式(6)可得到监督矩阵11101001101010=[P I ] (7)1011001r H ⎡⎤⎢⎥=⎢⎥⎢⎥⎣⎦因为生成矩阵'=[I Q]=[I ]k k G P ,所以由(7)得生成矩阵G 如下:[]k 10001110100110[']00101010001011k G I Q I P ⎡⎤⎢⎥⎢⎥===⎢⎥⎢⎥⎣⎦然后利用信息位和生成矩阵G 相乘产生整个码组,即有[][]65432106543=(8)A a a a a a a a a a a a G=其中A 为整个码组矩阵,6543a a a a 是信息位。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
74汉明码编码
1. 线性分组码是一类重要的纠错码,应用很广泛。
在(n ,k )分组码中,若 冗余
位是按线性关系模2相加而得到的,则称其为线性分组码。
现在以(7,4)分组码为例来说明线性分组码的特点。
其主要参数如下:
码长:21m n =-
信息位:21m k m =--
校验位:m n k =-,且3m ≥
最小距离:min 03d d ==
其生成矩阵G (前四位为信息位,后三位为冗余位)如下:
系统码可分为消息部分和冗余部分两部分,根据生成矩阵,输出码字可按下
式计
算:
所以有
信息位 冗余位
由以上关系可以得到(7,4)汉明码的全部码字如下所示。
1000110010001100101110001101G ⎡
⎤
⎢⎥
⎢⎥
=⎢⎥
⎢⎥⎣⎦
3210321010001100100011(,,,)(,,,)00101110001101b a a a a G a a a a ⎡⎤
⎢⎥
⎢⎥=•=•⎢⎥
⎢⎥⎣⎦
635241
30
b a b a b a b a ====2310
1321
0210b a a a b a a a b a a a =⊕
⊕=⊕⊕=⊕⊕
2.用C++编写(7,4)汉明码的思路如下:
16个不同信息序列的产生:调用stidlib包中的rand()产生二进制伪随机序列,为了产生16个不同信息序列,共分两步产生:
第一步:先产生一个伪随机序列并保留,将它赋给第一个信息序列V[0];
i=0;
for(j=0;j<4;j++)
v[i][j]=rand()%2;
第二步:同样产生一个序列,产生后要与在它以前产生的信息序列相比较,如果产生的信息序列与前面的序列都不同,则保留这个信息序列,并进行产生下一个信息序列;如果产生的信息序列与前面的序列有相同的,则此次产生的序列无效,需从新产生信息序列。
此过程中需定义一个比较函数进行比较,其代码如下:
for(i=1;i<16;i++){
Lable:for(j=0;j<4;j++)
v[i][j]=rand()%2;
for(k=0;k<i;k++){ //判断随机产生的信息序列与前面的信息序列是否相同
if( vedict( v[i],v[k]))
continue; //如果产生的信息序列与前面的序列都不同,则保留这个信
息序列,并进行产生下一个信息序列
else
goto lable; //如果产生的信息序列与前面的序列有相同的,则此次产生的
序列无效,跳转到标签lable处,从新产生信息序列}
}
进行判断的函数为:
bool vedict(int a[],int b[]){
int m;
for(m=0;m<4;m++){
switch(m){
case 0:if(a[m]!=b[m])
return true;
else continue;
break;
case 1:if(a[m]!=b[m])
return true;
else
continue;
break;
case 2:if(a[m]!=b[m])
return true;
else continue;
break;
case 3:if(a[m]!=b[m])
return true;
else
return false;
}
}
}
74汉明码的生成:
利用线性关系式 : 信息位
冗余位
用两个for 循环,并分两部分求解:前四位用信息位方程,后三位用 冗余位方程(通过异或运算求得);其代码如下:
for(i=0;i<16;i++){
for(j=0;j<7;j++)
{
if(j<4)
u[i][j]= v[i][j];
if(j==4)
u[i][j]=(v[i][0]^v[i][2])^v[i][3];
if(j==5)
u[i][j]=(v[i][0]^v[i][1])^v[i][2];
if(j==6)
u[i][j]=(v[i][1]^v[i][2])^v[i][3];
cout << u[i][j] << " ";
}
cout << endl;
}
3. 其总代码为:
#include<iostream.h>
#include<stdlib.h>
void main(){
int g[4][7]={{1,0,0,0,1,1,0},{0,1,0,0,0,1,1},{0,0,1,0,1,1,1},{0,0,0,1,1,0,1}};//声明生成矩阵
63
524130b a b a b a b a ====231013210210b a a a b a a a b a a a =⊕⊕=⊕⊕=⊕⊕
int v[16][4];//声明信息序列
int u[16][7];
int i,j,k;
cout << "生成矩阵为:" << endl;//输出生成矩阵
for(i=0;i<4;i++)
{
for(j=0;j<7;j++)
cout << g[i][j] << " ";
cout << endl;
}
bool vedict(int a[],int b[]);//声明判断函数
cout << "消息序列:"<< endl;//随机产生信息位序列
i=0;
for(j=0;j<4;j++)
v[i][j]=rand()%2;
for(i=1;i<16;i++){
lable:for(j=0;j<4;j++)
v[i][j]=rand()%2;
for(k=0;k<i;k++){ //判断随机产生的信息序列与前面的信息序列是否相同if( vedict( v[i],v[k]))
continue; //如果产生的信息序列与前面的序列都不同,则保留这个信
息序列,并进行产生下一个信息序列
else
goto lable; //如果产生的信息序列与前面的序列有相同的,则此次产生的
序列无效,跳转到标签lable处,从新产生信息序列}
}
for(i=0;i<16;i++){ //输出信息序列
for(j=0;j<4;j++)
cout << v[i][j] << " ";
cout << endl;
}
cout << "74汉明码为:" <<endl;
for(i=0;i<16;i++){
for(j=0;j<7;j++)
{
if(j<4)
u[i][j]= v[i][j];
if(j==4)
u[i][j]=(v[i][0]^v[i][2])^v[i][3];
if(j==5)
u[i][j]=(v[i][0]^v[i][1])^v[i][2];
if(j==6)
u[i][j]=(v[i][1]^v[i][2])^v[i][3];
cout << u[i][j] << " ";
}
cout << endl;
}
}
bool vedict(int a[],int b[]){
int m;
for(m=0;m<4;m++){
switch(m){
case 0:if(a[m]!=b[m])
return true;
else continue;
break;
case 1:if(a[m]!=b[m])
return true;
else
continue;
break;
case 2:if(a[m]!=b[m])
return true;
else continue;
break;
case 3:if(a[m]!=b[m])
return true;
else
return false;
}
}
}
编译、运行结果为:。