循环码(7,3)码

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
4
+ x3 + x 2 +1 )
摘要:本报告详细给出了循环码的定义以及由生成多项式求解生成
矩阵和系统生成矩阵的过程,并在 Matlab 环境下写出了循 环码的编码器和解码器代码,实现了编码和译码功能。分析和讨论了 此码发现错误、 纠正错误的能力, 并讨论了其与线性分组码、 Hamming 码等信道编码的区别与联系。
a
0
n − 1
n − 2
⋅ ⋅ ⋅ a
1
a
0
) 为一 循 环 码 组 , 则
⋅⋅⋅ a
n −1
(a
n − 2
a
n − 3
⋅ ⋅ ⋅ a
a
n −1
) 、 (a n − 3 a n − 4
a
n − 2
) 、…… 还
是许用码组。也就是说,不论是左移还是右移,也不论移多少位,仍
《信息论与编码》课程设计报告 -3-
A (i ) ( x ) 可以根据 x i A( x ) 按模 x n + 1 运算得到,即
(1.1.4)
A( i ) ( x ) ≡ x i A( x ) mod(x n + 1)

(1.1.5)
x i A( x) = Q( x)( x n + 1) + A(i ) ( x )
(1.1.6)
i
i 式中, Q( x) 为 x A ( x ) 除以 x n + 1 的商式,而 A (i ) ( x ) 等于 A ⋅ A ( x)
《信息论与编码》课程设计报告 -9-
又设码式的高幂次部分等于 m(x),即
c(x) =c0 +c1x +⋯+cn−k xn−k +cn−k+1xn−k+1 +⋯+cn−1xn−1
= x ⋅ m(x) + p(x)
n−k
∂� p(x) < r = n −k
其中 p(x)称为校验位多项式,由于码式是生成式的倍式,所以
a
0 1 0 1
4
a3
1 0 1 0
a2
1 0 0 1
a1
1 1 0 0
a0
0 1 1 0
表1.1-1(7,3)循环码组
以 3 号码 组 ( 0100111 )为 例 , 左 移 循 环 一 位 变 成 5 号码 组 (1001110) ,依次左移一位构成的状态图如图1.1-2所示。
8号 1110100 7号 1101001 6号 1010011
以生成多项式 g ( x ) = x + x + x + 1 构造 G ( x) , 相应的矩 阵 形式为
6 5 4 2 ⎡x2g(x) ⎤ ⎡x + x + x + x ⎤ ⎥ ⎢ ⎥ ⎢ G(x) = ⎢x g(x) ⎥ = ⎢x5 + x4 + x3 + x ⎥ ⎢ g(x)⎥ ⎢x4 + x3 + x2 +1 ⎥ ⎣ ⎦ ⎣ ⎦
1 0 1 1
0 1 0 1
0 0 1 0
0⎤ 0⎥ ⎥ 0⎥ ⎥ 1⎦
(1.1.16)
循环码也可以构成为系统循环码。为方便系统码的构造,将消息 多项式和码式都记为高位在前,即 m = ( m k − 1 , m k − 2 ,⋅ ⋅ ⋅ , m1 , m 0 ) 的消息多 项式为 m(x),
m( x) = m0 + m1 x + ⋯ + mk −1 x k −1
《信息论与编码》课程设计报告 -7-
而且线性无关, 因此以这 k 各多项式对应的码组作为 k 行就能构成该 循环码的生成矩阵,因此循环码的生成矩阵多项式可以写成
⎡x k −1 g (x)⎤ ⎢ ⎥ ⋮ ⎥ G(x ) = ⎢ ⎢x g (x) ⎥ ⎢ ⎥ ⎢ ⎣ g (x ) ⎥ ⎦
4 3 2
(1.1.10)
即可写成
n h( x ) = x + 1 g ( x)
(1.1.14)
由于 g(x)是常数项为 1 的 r 次多项式,所以 h(x)必为 k 次多项式。 称 h(x)为监督多项式或一致校验多项式, 与式 (1.1.10) 给出的 G(x) 相对应,监督矩阵多项式可表示为
⎡ x r −1 h* ( x) ⎤ ⎢ ⎥ ⋮ ⎥ H ( x) = ⎢ * ⎢ xh ( x ) ⎥ ⎢ ⎥ * ⎢ ⎣ h ( x) ⎥ ⎦
A = ( a n − 1 a n − 2 ⋅ ⋅ ⋅ a 1 a 0 ) 用码多项式表示则为
n
的码 组
A ( x ) = a n −1 x n −1 + an − 2 x n − 2 + ⋅ ⋅ ⋅a1 x + a 0
式中, x 的幂次是码元位置的标记。 若 把 一 个 码 组 左 移 i
(1.1.3)
(1.1.11)
则 G 为 g(x)升幂排列时的 G 为
⎡1 1 1 0 1 0 0⎤ ⎥ G= ⎢ 0 1 1 1 0 1 0 ⎢ ⎥ ⎢ ⎣0 0 1 1 1 0 1⎥ ⎦
⎡1 0 0 1 1 1 0⎤ ⎥ G=⎢ 0 1 0 0 1 1 1 ⎢ ⎥ ⎢ ⎣ 0 0 1 1 1 0 1⎥ ⎦
1.1.6、监督多项式与监督矩阵
力系统地构造这类码, 且易于实现, 所以循环码受到人们的高度重视 , 在 FEC 系统中得到了广泛应用。
1.1.1、循环码定义
定义:一个线性分组码,若具有下列特性,则称为循环码。设码字
c = (cn −1c n − 2 ⋅ ⋅ ⋅ c1c0 )
若将码元左移一位,得
(1.1.1)
c(1) = (cn −2 ⋅ ⋅ ⋅ c1c0 cn −1 )
g ( x ) = x 4 + x 3 + x 2 + 1 ,并且该码组集合中的任何码多项式 A ( x )
都可由信息位乘以生成多项式得到
《信息论与编码》课程设计报告 -6-
A ( x ) = ( mk −1 + mk − 2 + ⋅ ⋅ ⋅ + m1 + m0 ) g ( x ) mod( x n + 1)
* 式中, h ( x) 式 h(x)的逆多项式。
(1.1.15)
由式(1.1.14)可知,前述生成多项式的 g(x)的一致校验多项
3 2 式为 h( x) = x + x + 1,所以其一致校验矩阵(监督矩阵)为
⎡1 ⎢0 H (X ) = ⎢ ⎢0 ⎢ ⎣0
1.1.7、系统循环码
1 1 0 0
0 1 1 0
n 被 x + 1 除得之余式。
以码组1011100为例,若将此码左移两位,则由式(1.1.6)可得
x 2 ( x 6 + x 4 + x 3 + x 2 ) = Q ( x )( x 7 + 1) + A ( 2 ) ( x )
《信息论与编码》课程设计报告 -5-
易有其余式为 A ( i ) ( x ) = x 6 + x 5 + x 4 + x
(7,k) (7,1) (7,3) (7,4) (7,6)
g(x)
( x 3 + x 2 + 1)( x3 + x + 1)
(x3 + x2 +1)(x +1)或(x3 + x +1)(x +1)
x 3 + x 2 + 1或 x 3 + x + 1 x + 1
表1.1-2 (7,3)循环码的生成多项式
成都理工大学工程技术学院
《信息论与编码》课程设计报告
——循环码(7,3)码
2007 级信息工程
指导教师:梁维海 作者:钟玉东(1 班) 吴镇宏(2 班) 袁艳凤(1 班) 贾 辉(2 班)
2009 年 6 月 18 日
《信息论与编码》课程设计报告 -1-
循环码(7,3)码
(生成多项式 g ( x ) = x
p(x) + xn −k m( x) = a(x) g(x) = 0 (modg(x)) p( x) = − x r ⋅ m( x)(mod g ( x))
因此循环码的系统码码式为
c(x) = xr m(x) −[xr m(x) (mod g(x))]
1.1、循环码
循环码是线性分组码中一个重要的分支。 它的检、 纠错能力较强 , 编码和译码设备并不复杂,而且性能较好,不仅能纠随机错误,也能 纠突发错误。 循环码是目前研究得最成熟的一类码,并且有严密的代数理论 基础,故有许多特殊的代数性质,这些性质有助于按所要求的纠错能
《信息论与编码》课程设计报告 -2-
(1.1.2)
c (1) 也是一个码字。
由于( n, k )线性分组码是
n 维线性空间 Vn 中的一个 k 维子空
间,因此 (n, k ) 循环码是 n 维线性空间 Vn 中的一个 k 维循环子空间。 注意:循环码并非由一个码字的全部循环移位构成。
1.1.2、循环码的特点
循环码有两个数学特征: (1)线性分组码的封闭型; (2)循环性,即任一许用码组经过循环移位后所得到的码组仍为该 许用码组集合中的一个码组。 即 若 (a
,对应的码组为1110010 ,它与
直接对码组进行循环左移的结果相同。 码多项式之间可以进行代数运算,在二元码中遵循模 2运算的规 则。根据线性码的封闭性,任意两码字经模运算后仍为本码组中的码 字。
1.1.4、生成多项式
(n,k)循环码码组集合中(全“0”码除外)幂次最低的多项式 (n-k)阶称为生成多项式 g ( x ) 。它是能整除 x + 1 且常数项为1的 多项式,具有唯一性。集合中其他码多项式,都是按模( x + 1 )运 算下 g ( x ) 的倍式,即可以由多项式 g ( x ) 产生循环码的全部码组。 假设信息码多项式为 m ( x ) ,则对应的循环码多项式为
n n
A( x) = m( x) g ( x)
k
(1.1.7)
式中, m( x) 为次数不大于 k − 1 的多项式,共有 2 个( n, k )循环 码组。 考查表 1.1-1 ,其中 n − k = 4 阶的多项 式只有 编号 为 2的码组 ( 0011101 ) ,所以 表 中 所 示 ( 7 , 3 )循 环 码 组 的 生 成 多 项 式
从表 1.1-2 中可以看出,即使 n,k 均已确定,也可能由多种生成 多项式供选择,选用的多项式不同,产生出的循环码组也不同。
1.1.5、生成矩阵
根据各码组集合中生成多项式的唯一性,可以构造生成矩阵 G。 由于 g(x)的次数为 n − k ,则 g ( x), xg ( x ),⋅ ⋅ ⋅, x k −1 g ( x) 都是码多项式,
为方便系统码的构造将消息多项式和码式都记为高位在前即0121mmmmmkk????的消息多项式为mx1110??????kkxmxmmxm?又设码式的高幂次部分等于mx即111110xpxmxxcxcxcxccxcknnnknknknkn?????????????????????knrxp?????其中px称为校验位多项式由于码式是生成式的倍式所以mod0xgxgxaxmxxpkn????modxgxmxxpr???因此循环码的系统码码式为modxgxmxxmxxcrr??1117将循环码的系统码构造步骤总结为1多项式乘xmxxmxrr?2多项式求模余式modxpxgxmxr?3多项式减xcxpxmxr??如果令xm为单项式1?rx110??ki?rxpxpxgxaxiir?????1?iriixxpxc???那么容易看到xci对应的向量ic110??ki?是线性无关的从而得到循环码系统码的生成矩阵sg为???????????????????100010001111101111110100100rkkkrrspppppppppg???????1118故由式1118可以求得前述73循环码系统码的生成矩阵为???????????101110011100100111001sg118循环码的编码1
位 后 的 码 组 记 为
A ( i ) = ( a n − i − 1 , a n − i − 2 , ⋅ ⋅ ⋅, a n − i +1 , a n − i ) ,其码多项式为
A(i ) (x) = an−i −1xn−1 + an−i−2 xn−2 + ⋅ ⋅ ⋅ + an−i+1 x + an−i
关键字:循环码
编码 译码 检错 纠错 Matlab
信道编码:信道编码又称差错控制编码或纠错编码,它是提高信
息传输可靠性的有效方法之一。 一类一类信道编码是对 传输信号的码型进行变换, 使之更适合于信道特性或满足接收端对恢 复信号的要求,从而减少信息的损失;另一类信道编码是在信息序列 中人为的增加冗余位,使之具有相关特性,在接收端利用相关性进行 检错或纠错,从而达到可靠通信的目的。
3号Βιβλιοθήκη 01001110111010 4号
0011101 2号
1001110 5号
图1.1-1(7,3)循环码中的循环圈
可见除全零码组外,不论循环右移或左移,移多少位,其结果均 在该循环码组的集合中(全零码组自己构成独立的循环圈) 。
《信息论与编码》课程设计报告 -4-
1.1.3、码多项式
为了用代数理论研究循环码,可将码组用多项式表示,循环码 组中 各 码 元 分 别 为 多 项 式 的 系 数 。 长 度 为
然是许用的循环码组。 表1.1-1列出了某(7,3)循环码的全部码组。
码组 编号 1 2 3 4
信息位
监督位
码组
信息位
监督位
a6
0 0 0 0
a5
0 0 1 1
a4
0 1 0 1
a3
0 1 0 1
a2
0 1 1 0
a1
0 0 1 1
a0
0 1 1 0
编号 5 6 7 8
a6
1 1 1 1
a5
0 0 1 1
(1.1.12)
对式(1.1.12)作线性变换,整理成典型形式的生成矩阵
(1.1.13)
若信息码元与式(1.1.13)相乘,得到的就是系统循环码。
如前所述,在(n,k)循环码中,由于 g(x)能除尽,因此 x n + 1 可分解成 g(x)和其他因式的乘积,记为
《信息论与编码》课程设计报告 -8-
x n + 1 = g ( x ) h( x )
式中, ( m k −1mk − 2 ⋅ ⋅ ⋅ m1 m0 ) 为信息码元。 对于(7,k)循环码, x 7 + 1 的因式分解为
(1.1.8)
x 7 + 1 = ( x + 1)( x 3 + x + 1)( x 3 + x 2 + 1)
由该式可以构成表1.1-2所示几种(7,k)循环码。
(1.1.9)
相关文档
最新文档