多项式码

维基百科,自由的百科全书

编码理论中,多项式码(英語:polynomial code)是有效码字英语codeword集合是由多項式(通常是固定长度的多项式)可以被特定多项式(长度较短,称为生成多项式整除的一种线性码英语linear code

定义[编辑]

对于有限域 ,其元素我们称作码元。为了建立多项式码,我们要确定一个 个码元的序列 其多项式为

对于整数 ,令 阶多项式,称为生成多项式。由 生成的多项式码其码字都是阶数低于 ,并且可以被 整除(没有余式)的多项式。

例子[编辑]

考虑 上,、生成多项式为 的多项式码。此码由下列码字组成:

或直接写成:

由于多项式码定义在二元伽罗华域 中,多项式元素用q求和表示,于是最终多项式为:

等价地,用二进制位的序列表示,这些码字就是:

注意到如所有多项式码一样,这个码确实是一个线性码英语linear code,即码字的线性组合还是码字。在域为 GF(2) 的情形,可以通过对二进制形式的两个码字取XOR(如00111 XOR 10010 = 10101)得到其线性组合。

编码[编辑]

上长度为 、生成多项式为 阶多项式 的多项式码中,会有 个码字。事实上,根据定义,当且仅当一个码字形式为 (其中 的阶小于 )时, 才是一个码元。因为会有 个商,所以也会有相同数量的码字。 未编码的数据字长度应为

一些作者,如(Lidl & Pilz, 1999),仅讨论了从数据字到码字赋值的映射 。但在数据字不是码字的一部分时会存在缺陷。

相反,常用下面的方法来建立系统码英语systematic code:给定长度为 的数据字 ,先把 乘以 ,这样的效果就是将 向左移 位。 一般不能被 整除,也就不是一个有效的码字。不过,调整 的最右面 个符号可以得到唯一的码字。 要求它,需要计算 除以 的余式:

其中 的阶数小于 。于是对应于数据字 的码字定义为

注意以下性质:

  1. 可以被 整除。特别地, 是一个有效码字。
  2. 由于 的阶数小于 最左面的 个符号与 中对应符号相同。换句话说,码字的前 个符号与原数据字相同。剩下的 个符号称为校验位

例子[编辑]

对于 、生成多项式为 的上述码,我们的带下列从数据字到码字的赋值:

  • 000 ↦ 00000
  • 001 ↦ 00111
  • 010 ↦ 01001
  • 011 ↦ 01110
  • 100 ↦ 10010
  • 101 ↦ 10101
  • 110 ↦ 11011
  • 111 ↦ 11100

译码[编辑]

错误消息可以直接通过多项式除以生成多项式得到非零余式而检测出来。

假设码字没有差错,系统码可以通过剥离 个检验位译码。

如果存在差错,则应在译码前纠错。有些多项式码(如BCH码)会有高效的译码算法。

多项式码的性质[编辑]

对于所有数字码来说,多项式码的误差检测与校正能力取决于该码的最小汉明距离。由于多项式码是线性码,最小汉明距离等于任何非零码字的最小重量。在上面的例子中,最小汉明距离是2,因为01001是一个码字,并且没有非零码字只有一位是1的。

多项式码更具体的性质往往取决于它的生成多项式的特定的代数性质。这里有此类性质的一些例子:

  • 一个多项式码当且仅当生成多项式能够整除 时为循环码
  • 如果生成多项式是本原多项式英语Primitive polynomial (field theory),若 ,则得到的码的汉明距离最小为3。
  • BCH码中,生成多项式在扩展域中有能够得到很大汉明距离的特定的根。

巧妙选取生成多项式的多项式码的代数性质可以用来寻找有效的误差校正算法。BCH码就属于这种情况。

特定多项式码[编辑]

  • 循环码;所有循环码都是多项式码;如CRC码。
  • BCH码;一类汉明距离很大、有代数纠错算法的循环码。
  • 里德-所罗门码;BCH码的一个重要子集,有特别高效的结构。

参考文献[编辑]

  • W.J. Gilbert and W.K. Nicholson: Modern Algebra with Applications, 2nd edition, Wiley, 2004.
  • R. Lidl and G. Pilz. Applied Abstract Algebra, 2nd edition. Wiley, 1999.