【笔记整理】通信原理第九章复习——线性分组码

本文深入探讨线性分组码,重点讲解汉明码的基本概念、纠错原理及其应用。介绍了监督矩阵、生成矩阵、错误图样和纠错能力。汉明码作为能纠正1位错的线性分组码,其(7,4)码具有最小码距d0=3,能检测2个错码或纠正1个错码。此外,还讨论了扩展汉明码,增加了额外监督位,提升纠错能力。" 130156100,12542646,创建可编辑ALV并实现数据保存功能,"['数据库', 'SAP ABAP']

9.4 线性分组码

9.4.1 基本概念

  • 代数码:利用代数关系式产生监督位的编码
  • 线性分组码:代数码的一种,其监督位和信息位的关系由线性代数方程决定
  • 汉明码:一种能够纠正一个错码的线性分组码(纠1位错,至少3个码元)
  • 校正子:在偶数监督码中,计算an−1⊕an−2⊕...⊕a0=0a_{n-1} \oplus a_{n-2} \oplus ... \oplus a_0=0an1an2...a0=0,实际上就是计算S=an−1⊕an−2⊕...⊕a0S=a_{n-1} \oplus a_{n-2} \oplus ... \oplus a_0S=an1an2...a0,并检验SSS是否等于0。SSS称为校正子
  • 监督关系式:S=an−1⊕an−2⊕...⊕a0S=a_{n-1} \oplus a_{n-2} \oplus ... \oplus a_0S=an1an2...a0称为监督关系式

9.4.2 纠错基本原理

S=an−1⊕an−2⊕...⊕a0S=a_{n-1} \oplus a_{n-2} \oplus ... \oplus a_0S=an1an2...a0中。SSS只有两种取值:表示有错和无错,而不能进一步指明错码的位置
若此码组长度增加一位,则能增加一个监督关系式。这样就能得到两个校正子
两个校正子的可能取值有4种组合,即00,01,10,11,能表示4种不同的信息
若用其中一种组合表示无错码,则其他3种组合可以用于指明一位错码的3种不同位置,从而可以有纠错能力

  • 一般而言,若有rrr个监督关系式,则rrr个校正子可以指明一个错码的(2r−1)(2^r-1)(2r1)个不同位置

当校正子可以指明的错码位数目等于或大于码组长度nnn时,才能够纠正码组中任何一个位置上的错码,即要求
2r−1≥n2^r-1 \geq n2r1n2r≥k+r+12^r \geq k+r+12rk+r+1

  • 汉明码:一种能够纠正一个错码的线性分组码

【填空题】要求设计一个能够纠正1个错码的分组码(n,k)(n,k)(n,k),设给定的码组中有4个信息位,即k=4k=4k=4,求nnn的值
:由2r−1≥n2^r-1 \geq n2r1n2r≥r+k+12^r \geq r+k+12rr+k+1知,这时要求监督位数r≥3r \geq 3r3
若取r=3r=3r=3,则n=k+r=7n=k+r=7n=k+r=7
现在用a6a5a4a3a2a1a0a_6a_5a_4a_3a_2a_1a_0a6a5a4a3a2a1a0表示这7个码元,用S1S2S3S_1S_2S_3S1S2S3表示校正子,则这3个校正子恰好能够指明23−1=72^3-1=7231=7个错码的位置
若规定校正子和错码位置的关系如下表:

S1S2S3S_1S_2S_3S1S2S3错码位置S1S2S3S_1S_2S_3S1S2S3错码位置
001a0a_0a0101a4a_4a4
010a1a_1a1110a5a_5a5
100a2a_2a2111a6a_6a6
011a3a_3a3000无错码

则仅当发生一个错码,且位置在a6a_6a6a5a_5a5a4a_4a4a2a_2a2时,校正子S1S_1S1的值才等于1;否则S1S_1S1的值为零。这就移位着a6a5a4a2a_6a_5a_4a_2a6a5a4a2四个码元构成偶数监督关系:
S1=a6⊕a5⊕a4⊕a2S_1=a_6 \oplus a_5 \oplus a_4 \oplus a_2S1=a6a5a4a2
S2=a6⊕a5⊕a3⊕a1S_2=a_6 \oplus a_5 \oplus a_3 \oplus a_1S2=a6a5a3a1
S3=a6⊕a4⊕a3⊕a0S_3=a_6 \oplus a_4 \oplus a_3 \oplus a_0S3=a6a4a3a0
{a2=a6⊕a5⊕a4a1=a6⊕a5⊕a3a0=a6⊕a4⊕a3\begin{cases} a_2=a_6 \oplus a_5 \oplus a_4\\ a_1=a_6 \oplus a_5 \oplus a_3\\ a_0=a_6 \oplus a_4 \oplus a_3 \end{cases}a2=a6a5a4a1=a6a5a3a0=a6a4a3

【掌握判断】若接受码组为0000011,则按上三式计算得到:S1=0,S2=1,S3=1S_1=0,S_2=1,S_3=1S1=0,S2=1,S3=1。这样,由上表可知,错码位置在a3→a_3 \toa3 0001011

汉明码是(7,4)(7,4)(7,4)码,其最小码距d0=3d_0=3d0=3
则由d0≥e+1d_0 \geq e+1d0e+1d0≥2t+1d_0 \geq 2t+1d02t+1可知,此码能够检测2个错码,或纠正1个错码

【填空题】(15,11)(15,11)(15,11)汉明码中的r=4r=4r=4,最小码距d0=4d_0=4d0=4

  • 汉明码的码率
    kn=2r−r−12r−1\frac{k}{n}=\frac{2^r-r-1}{2^r-1}nk=2r12rr1

    • rrr很大时,码率趋近1——汉明码是一种高效编码

【结论】汉明码是一种可纠一位错的线性分组码,其码参数为n=2r−1,k=n−r=2r−1−r,r≥3,d0=3n=2^r-1,k=n-r=2^r-1-r,r \geq3,d_0=3n=2r1,k=nr=2r1r,r3,d0=3

  • 完备码

    • 通常若要设计能纠正ttt个错码的分组码(n,k)(n,k)(n,k),则当信息位kkk,码长nnn和监督位rrr的选取应满足:
      2r−1≥Cn1+Cn2+...+Cnt=∑i=1tCnt2^r-1 \geq C_n^1+C_n^2+...+C_n^t=\sum_{i=1}^{t}C_n^t2r1Cn1+Cn2+...+Cnt=i=1tCnt
      不等式左边是rrr位监督位所能显示的错码类型数,右边是所有可能发生的错码总数。取等式时,所设计的码称为完备码汉明码是完备码

【典型题】将(7,4)(7,4)(7,4)汉明码的编码结果按行写入一个10行7列的存储器阵列,每行一个码字,共计10个码字,再按列读出后通过信道传输。若传输这10个码字时,信道中发生了连续15个错误,请问接受端解交织并译码后,能译对几个码字?
分析:本题按行输入,按列输出,连续15个错误,则应该是15=10+515=10+515=10+5,其中有5行有2个错码,其他5行为1个错码。由于(7,4)(7,4)(7,4)汉明码是可以纠1个错,因此可以纠正发生1个错码的5行,也就是能译对5个码字

  • 分组码的一般原理

    线性分组码是监督位和信息位满足一组线性方程的码,如前述(7,4)(7,4)(7,4)码满足如下关系:
    {a6⊕a5⊕a4⊕a2=0a6⊕a5⊕a3⊕a1=0a6⊕a4⊕a3⊕a0=0\begin{cases} a_6 \oplus a_5 \oplus a_4 \oplus a_2=0\\ a_6 \oplus a_5 \oplus a_3 \oplus a_1=0\\ a_6 \oplus a_4 \oplus a_3 \oplus a_0=0 \end{cases}a6a5a4a2=0a6a5a3a1=0a6a4a3a0=0
    可以改写为
    {1⋅a6+1⋅a5+1⋅a4+0⋅a3+1⋅a2+0⋅a1+0⋅a0=01⋅a6+1⋅a5+0⋅a4+1⋅a3+0⋅a2+1⋅a1+0⋅a0=01⋅a6+0⋅a5+1⋅a4+1⋅a3+0⋅a2+0⋅a1+1⋅a0=0\begin{cases} 1 \cdot a_6 + 1 \cdot a_5 +1 \cdot a_4 + 0 \cdot a_3 +1 \cdot a_2 + 0 \cdot a_1 +0 \cdot a_0=0\\ 1 \cdot a_6 + 1 \cdot a_5 +0 \cdot a_4 + 1 \cdot a_3 +0 \cdot a_2 + 1 \cdot a_1+0 \cdot a_0=0\\ 1 \cdot a_6 + 0 \cdot a_5 +1 \cdot a_4 + 1 \cdot a_3 +0 \cdot a_2 + 0 \cdot a_1+1 \cdot a_0=0\\ \end{cases}1a6+1a5+1a4+0a3+1a2+0a1+0a0=01a6+1a5+0a4+1a3+0a2+1a1+0a0=01a6+0a5+1a4+1a3+0a2+0a1+1a0=0
    可以写成矩阵形式:
    [111010011010101011001][a6a5a4a3a2a1a0]=[000]\begin{bmatrix} 1&1&1&0&1&0&0 \\ 1&1&0&1&0&1&0 \\ 1&0&1&1&0&0&1 \end{bmatrix} \begin{bmatrix} a_6\\a_5\\a_4\\a_3\\a_2\\a_1\\a_0 \end{bmatrix}= \begin{bmatrix} 0\\0\\0 \end{bmatrix}111110101011100010001a6a5a4a3a2a1a0=000
    上式可简写为HAT=0THA^T=0^THAT=0TAHT=0AH^T=0AHT=0
    其中Hr×n=[111010011010101011001] H_{r \times n}=\begin{bmatrix} 1&1&1&0&1&0&0 \\ 1&1&0&1&0&1&0 \\ 1&0&1&1&0&0&1 \end{bmatrix}Hr×n=111110101011100010001称为监督矩阵
    A=[a6a5a4a3a2a1a0]A=[a_6a_5a_4a_3a_2a_1a_0]A=[a6a5a4a3a2a1a0]称为码字

    • HHH矩阵与码字的转置乘积必为零,可以用来作为判断接受码字AAA是否出错的依据
    • 监督矩阵的性质
      • 监督矩阵HHH确定码组中的信息位和监督位的关系

      • HHH的行数就是监督关系式的数目,即监督位数rrr

      • HHH的每行中“1”的位置表示相应的码元参与监督关系
        HHH可以分成两部分
        Hr×n=[1110∣1001101∣0101011∣001]=[PIr] H_{r \times n}=\begin{bmatrix} 1&1&1&0&|&1&0&0 \\ 1&1&0&1&|&0&1&0 \\ 1&0&1&1&|&0&0&1 \end{bmatrix}=[PI_r ]Hr×n=111110101011100010001=[PIr]为典型监督矩阵

    • 典型监督矩阵
      • 将具有[PIr][PI_r][PIr]形式的HHH矩阵称为典型阵
      • HHH矩阵的各行应该是线性无关的,否则将得不到rrr个线性无关的监督关系式
      • 若一个矩阵能写成典型阵形式[PIr][PI_r][PIr],则其各行一定是线性无关的
  • 生成矩阵
    {a2=a6⊕a5⊕a4a1=a6⊕a5⊕a3a0=a6⊕a4⊕a3\begin{cases} a_2=a_6 \oplus a_5 \oplus a_4\\ a_1=a_6 \oplus a_5 \oplus a_3\\ a_0=a_6 \oplus a_4 \oplus a_3 \end{cases}a2=a6a5a4a1=a6a5a3a0=a6a4a3
    可以写为
    [a2a1a0]=[111011011011][a6a5a4a3] \begin{bmatrix} a_2\\ a_1\\a_0 \end{bmatrix}= \begin{bmatrix} 1&1&1&0\\ 1&1&0&1\\ 1&0&1&1 \end{bmatrix} \begin{bmatrix} a_6\\a_5\\a_4\\a_3 \end{bmatrix} a2a1a0=111110101011a6a5a4a3
    上式两端分别转置后,可以变成
    [a2a1a0]=[a6a5a4a3][111110101011]=[a6a5a4a3]Q \begin{bmatrix} a_2a_1a_0 \end{bmatrix}= \begin{bmatrix} a_6a_5a_4a_3 \end{bmatrix} \begin{bmatrix} 1&1&1\\ 1&1&0\\ 1&0&1\\ 0&1&1 \end{bmatrix}= \begin{bmatrix} a_6a_5a_4a_3 \end{bmatrix}Q [a2a1a0]=[a6a5a4a3]111011011011=[a6a5a4a3]Q
    QQQk×rk \times rk×r阶矩阵,是PPP的转置,即Q=PTQ=P^TQ=PT
    QQQ的左边加上一个kkk阶单位方阵,称为生成矩阵,即
    G=[IkQ]=[1000∣1110100∣1100010∣1010001∣011] G= [I_kQ]= \begin{bmatrix} 1&0&0&0&|&1&1&1\\ 0&1&0&0&|&1&1&0\\ 0&0&1&0&|&1&0&1\\ 0&0&0&1&|&0&1&1 \end{bmatrix} G=[IkQ]=1000010000100001111011011011
    GGG称为生成矩阵,因为可以用它产生整个码组AAA,即有
    A=[a6a5a4a3a2a1a0]=[a6a5a4a3]GA=[a_6a_5a_4a_3a_2a_1a_0]=[a_6a_5a_4a_3]GA=[a6a5a4a3a2a1a0]=[a6a5a4a3]G
    【知识点】如何由监督矩阵如何产生生成矩阵?
    把监督矩阵典型化后,得到了一个Pr×kP_{r \times k}Pr×k阶矩阵,转置后得到Qk×rQ_{k \times r}Qk×r阶矩阵后,前面加一个kkk阶的单位矩阵,就可以得到一个典型化的生成矩阵,信息位和生成矩阵相乘,可以得到整个码组

    • 生成矩阵的性质
      • 具有[IkQ][I_kQ][IkQ]形式的生成矩阵称为典型生成矩阵
      • 由典型生成矩阵得出的码组AAA中,信息位的位置不变,监督位附加于其后——系统码
      • 生成矩阵G的各行也必须是线性无关的
        • 任意码组AAA都是GGG的各行的线性组合
        • GGG共有kkk行,若他们线性无关,则可组合出2k2^k2k中不同的码组AAA,它恰好是kkk位信息位的全部码组
        • GGG的各行有线性相关的,则不可能由GGG生出2k2^k2k中不同码组
        • 实际上,GGG的各行本身就是一个码组
      • 如果已有kkk个线性无关的码组,则可以将其用来作为生成矩阵GGG,并由它生成其余码组
  • 错误图样
    发送码组AAA是一个nnn列的行矩阵:
    A=[an−1an2...a1a0]A=[a_{n-1}a_{n_2}...a_1a_0]A=[an1an2...a1a0]
    接受码组是一个nnn列的行矩阵BBB
    B=[bn−1bn−2...b1b0]B=[b_{n-1}b_{n-2}...b_1b_0]B=[bn1bn2...b1b0]
    令接受码组和发送码组之差位
    B−A=EB-A=EBA=E
    EEE就是错码的行矩阵
    E=[en−1en−2...e1e0]E=[e_{n-1}e_{n-2}...e_1e_0]E=[en1en2...e1e0],称为错误图样
    式中,ei={0,当bi=ai1,当bi≠aie_i=\begin{cases}0,&\text{当}b_i=a_i\\1,&\text{当}b_i \neq a_i \end{cases}ei={0,1,bi=aibi=ai

  • 校正子矩阵
    B−A=EB-A=EBA=E可以改写为B=A+EB=A+EB=A+E
    在接受端解码时,将接受码组BBB带入式
    AHT=0AH^T=0AHT=0
    AAA的位置进行计算

    • 若接受码组中无错码,则B=AB=AB=A。代入后,该式仍成立,即有:BHT=0BH^T=0BHT=0

    • 当接受码组有错时,E≠0E \neq 0E=0,将BBB带入AHT=0AH^T=0AHT=0中,该式不一定成立

      • 只有当错码较多,已经超出了这种编码的检测能力时,BBB变为另一许用码组,上式才成立

      • 当错码未超过检错能力时,上式不成立,即其右端不为0。假设此时该式的右端等于SSS,即有
        BHT=SBH^T=SBHT=S
        B=A+EB=A+EB=A+E代入上式,得到:
        S=(A+E)HT=AHT+EHTS=(A+E)H^T=AH^T+EH^TS=(A+E)HT=AHT+EHT
        上式右端第一项等于0,所以
        S=EHTS=EH^TS=EHT
        SSS称为校正子
        HHH确定后,上式中SSS只与EEE有关,而与AAA无关
        SSS和错码EEE之间有确定的线性变形变换关系。若SSSEEE有一一对应关系,则SSS将能代表错码位置

  • 线性码的封闭性
    A1A_1A1A2A_2A2是一种线性码中的两个码组,则仍是其中一个码组
    由于线性码具有封闭性,所以两个码组A1A_1A1A2A_2A2之间的距离(即对应位不同的数目)必定时另一个码组(A1+A2)(A_1+A_2)(A1+A2)的重量(即“1”的数目)。因此,码的最小距离就是码的最小重量(除全“0”码组外)

【例题】已知(7,3)(7,3)(7,3)分组码的监督关系为
{a6+a3+a2+a1=0a5+a2+a1+a0=0a6+a5+a1=0a5+a4+a0=0 \begin{cases} a_6+a_3+a_2+a_1=0\\ a_5+a_2+a_1+a_0=0\\ a_6+a_5+a_1=0\\ a_5+a_4+a_0=0 \end{cases} a6+a3+a2+a1=0a5+a2+a1+a0=0a6+a5+a1=0a5+a4+a0=0
求其监督矩阵、生成矩阵、全部码字及纠错能力
解:由监督关系式可写出监督矩阵
H=[1001110010011111000100110001] H=\begin{bmatrix}1&0&0&1&1&1&0\\0&1&0&0&1&1&1\\1&1&0&0&0&1&0\\0&1&1&0&0&0&1 \end{bmatrix} H=1010011100011000110011100101
写成典型监督矩阵
H=[1011000111010011000100110001]=[PIr] H=\begin{bmatrix}1&0&1&1&0&0&0\\1&1&1&0&1&0&0\\1&1&0&0&0&1&0\\0&1&1&0&0&0&1 \end{bmatrix}=[PI_r] H=1110011111011000010000100001=[PIr]
生成矩阵满足关系[a6a5a4a3a2a1a0]=[a6a5a4][IkQ][a_6a_5a_4a_3a_2a_1a_0]=[a_6a_5a_4][I_kQ][a6a5a4a3a2a1a0]=[a6a5a4][IkQ]
生成矩阵为
G=[IkG]=[IkPT]=[100111001001110011101]G=[I_kG]=[I_kP^T]= \begin{bmatrix} 1&0&0&1&1&1&0\\0&1&0&0&1&1&1\\0&0&1&1&1&0&1 \end{bmatrix} G=[IkG]=[IkPT]=100010001101111110011
最小码距d0=4d_0=4d0=4,可纠错1位

  • 扩展汉明码
    在汉明码基础上,再加上一位所有码字进行校验的监督位

    • 监督码字由rrr增加r+1r+1r+1

    • 信息位不变

    • d0=4d_0=4d0=4

      • 码长n=2rn=2^rn=2r,码结构(2r,2r−r−1)(2^r,2^r-r-1)(2r,2rr1)
      • 纠1位错,同时检测2位错
      • (8,4)(8,4)(8,4)(16,11)(16,11)(16,11)

(7,4)(7,4)(7,4)汉明码字中至少一个码字重量等于d0=3d_0=3d0=3,加上1位监督位,则d0=4d_0=4d0=4。于是,相应的监督矩阵HHH通过在(7,4)(7,4)(7,4)码的HHH中顶部或底部加1行“1”,右边加1列“0”来构成

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值