BCH码

维基百科,自由的百科全书
跳转至: 导航搜索

BCH码取自 Bose、Ray-Chaudhuri 与 Hocquenghem 的缩写,是编码理论尤其是纠错码中研究得比较多的一种编码方法。用术语来说,BCH 码是用于校正多个随机错误模式的多级、循环、错误校正、变长数字编码。BCH 码也可以用于质数级或者质数的幂级的多级相移键控。11 级的 BCH 码已经用于表示 10 进制数外加一个符号位。

构建[编辑]

BCH 码使用有限域上的域論与多项式。为了检测错误可以构建一个检测多项式,这样接收端就可以检测是否有错误发生。

要构建一个能够检测、校正两个错误的 BCH 码,我们要使用有限域 GF(16) 或者 Z2[x]/<x4 + x + 1>。如果 α 是 m1(x) = x4 + x + 1 的一个根,那么 m1 就是 α 的极小多项式,这是因为

m1(x) = (x - α)(x - α2)(x - α4)(x - α8)=x4 + x + 1。

如果要构建一个能够纠正一个错误的 BCH 码,那么就使用 m1(x),这个代码就是所有满足

C(x) ≡ 0(mod m1(x))且根为 α, α2, α4, α8 的多项式 C(x)。

编码[编辑]

构建码字为

(c14, c13, ..., c8)

这样多项式为

c14+c13+...+c8

我们将它称为 CI

然后就要找出 CR 满足 CR=CI (mod m1,3(x))=c7+c6+...+c0

这样就得到待发的码字 C(x) = CI+CR (mod m1,3(x)) = 0

例如,如果我们要对 (1,1,0,0,1,1,0) 进行编码

CI=x14+x13+x10+x9

然后用 m1,3(x) 除以(这里的除法是多项式除法CI ,得到结果为 CR(x),在Z2域中,我们可以算出 CR

x3+1

这样,待发的码字为

(1,1,0,0,1,1,0, 0,0,0,0,1,0,0,1)

解码[编辑]

BCH 的解码过程可以分为以下四步

  1. 计算接收到的向量 R 的 2t 伴随矩阵
  2. 计算错误定位多项式
  3. 解多项式,得到错误位置
  4. 如果不是二进制 BCH 码,就计算错误位置的误差值

假设我们收到一个码字向量 r,即多项式 R(x))。

如果没有错误,那么 R(α)=R(α3)=0

如果有一个错误,例如 r=c+ei,其中 ei 表示 R14 的第 i个基向量 于是

S1=R(α)=C(α)+αii
S3=R3)=C(α3)+(α3)i
=(αi)3=S13

这样就可以纠正错误。α 的指数显示的数据位变化可以帮助我们校正错误。

如果有两个错误

r=c+ei+ej

那么

S1=R(α)=C(α)+αij
S3=R3)=C(α3)+(α3)i+(α3)j
= (α3)i+(α3)j

这与 S13 不同,所以我们认为有两个错误。更进一步的代数方法可以帮助校正着两个错误。

开头两段内容出自 Federal Standard 1037C

上面的文字摘自:http://bch-code.foosquare.com/

BCH 解码算法[编辑]

流行的解码算法有,

  1. Peterson Gorenstein Zierler 算法
  2. Berlekamp-Massey 算法

Peterson Gorenstein Zierler 算法[编辑]

假设[编辑]

Peterson 算法是普通 BCH 解码过程的第二步,在这里使用 Peterson 算法计算多项式  \Lambda(x) = 1 + \lambda_1 X + \lambda_2 X^2 + ... + \lambda_{2t}X^{2t} 的错误定位多项式系数  \lambda_1 , \lambda_2  ... \lambda_{2t}

这样给定 BCH 码 (n,k,d_{min}) ,可以校正 [t=\frac{d_{min}-1}{2}] 个错误的 Peterson Gorenstein Zierler 算法就是

算法[编辑]

  • 首先生成 2t 伴随矩阵
  • 然后生成元素为

S_{t \times t}=\begin{bmatrix}s_1&s_2&s_3&...&s_t\\
s_2&s_3&s_4...&...&s_{t+1}\\
s_3&s_4&s_5&...&s_{t+2}\\
...&...&...&...&...\\
s_{t}&s_{t+1}&s_{t+2}&...&s_{2t-1}\end{bmatrix} 的矩阵 S_{txt}

  • 生成元素为

C_{t \times 1}=\begin{bmatrix}s_{t+1}\\
s_{t+2}\\
...\\
...\\
s_{2t}\end{bmatrix}
的矩阵 c_{tx1}

  • \Lambda 表示未知的多项式系数,用

\Lambda_{t \times 1} = \begin{bmatrix}\lambda_{t}\\
\lambda_{t-1}\\
...\\
\lambda_{3}\\
\lambda_{2}\\
\lambda_{1}\end{bmatrix}
表示

  • 这样就得到矩阵方程

S_{t \times t} \Lambda_{t \times 1}  = C_{t \times 1}

  • 如果矩阵 S_{t \times t} 存在行列式,那么我们就可以找到这个矩阵的逆,然后就可以得到 \Lambda 的值
  • 如果  det(S_{t \times t}) = 0 ,那么按照
       if t = 0
       then
             declare an empty error locator polynomial
             stop Peterson procedure.
       end
       set  t \leftarrow t -1
       continue from the beginning of Peterson's decoding

  • \Lambda 的值确定之后,自然就得到错误定位多项式
  • 结束 Peterson procedure。

错误定位多项式的因式分解[编辑]

在得到 \Lambda(x) 多项式之后,用 Chiens search 算法就可以得到它的解 \Lambda(x)=(\alpha^i X + 1) (\alpha ^j X  + 1) ... (\alpha^k X + 1)。根据素元 \alpha 的指数幂就能得到接收到的码字中错误的位置,这也就是误差定位多项式名称的由来。

错误校正[编辑]

对于二进制的 BCH 码,可以直接根据错误定位多项式因数素元指数的位置校正接收到的向量。最后,对这些位置接收到的数值取反,就可以得到正确的 BCH 解码码字。

另外也可以使用 Berlekamp-Massey 算法确定错误定位多项式,从而解决 BCH 解码的问题。

参考文献[编辑]