在编码理论中,多项式码(英语:polynomial code)是有效码字集合是由多项式(通常是固定长度的多项式)可以被特定多项式(长度较短,称为生成多项式)整除的一种线性码。
对于有限域
,其元素我们称作码元。为了建立多项式码,我们要确定一个
个码元的序列
其多项式为
![{\displaystyle a_{n-1}x^{n-1}+\cdots +a_{1}x+a_{0}.\,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/45aecfdd7d64eeaf43b5314685383cafe40b43ee)
对于整数
,令
为
阶多项式,称为生成多项式。由
生成的多项式码其码字都是阶数低于
,并且可以被
整除(没有余式)的多项式。
考虑
上,
、
、生成多项式为
的多项式码。此码由下列码字组成:
![{\displaystyle 0\cdot g(x),\quad 1\cdot g(x),\quad x\cdot g(x),\quad (x+1)\cdot g(x),}](https://wikimedia.org/api/rest_v1/media/math/render/svg/6b49310d3ec9d03cf4d5cfd1767f02972531bf9e)
![{\displaystyle x^{2}\cdot g(x),\quad (x^{2}+1)\cdot g(x),\quad (x^{2}+x)\cdot g(x),\quad (x^{2}+x+1)\cdot g(x).}](https://wikimedia.org/api/rest_v1/media/math/render/svg/49b71362b93d7edc9f2e869247c80908ada2c713)
或直接写成:
![{\displaystyle 0,\quad x^{2}+x+1,\quad x^{3}+x^{2}+x,\quad x^{3}+2x^{2}+2x+1,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/d3261fdfa82532de9a537368096fba5e22fb33be)
![{\displaystyle x^{4}+x^{3}+x^{2},\quad x^{4}+x^{3}+2x^{2}+x+1,\quad x^{4}+2x^{3}+2x^{2}+x,\quad x^{4}+2x^{3}+3x^{2}+2x+1.}](https://wikimedia.org/api/rest_v1/media/math/render/svg/b55ef35cb35f6a51d70335d66f312af139a79083)
由于多项式码定义在二元伽罗华域
中,多项式元素用模q求和表示,于是最终多项式为:
![{\displaystyle 0,\quad x^{2}+x+1,\quad x^{3}+x^{2}+x,\quad x^{3}+1,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/e71037f4ad134f8665ae38b8c86a2309b2f10afa)
![{\displaystyle x^{4}+x^{3}+x^{2},\quad x^{4}+x^{3}+x+1,\quad x^{4}+x,\quad x^{4}+x^{2}+1.}](https://wikimedia.org/api/rest_v1/media/math/render/svg/381b9d833c6b33001508eba0616cba53099b05ad)
等价地,用二进制位的序列表示,这些码字就是:
![{\displaystyle 00000,\quad 00111,\quad 01110,\quad 01001,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/2e1d7ad5ac6066efd963a391e5ea189d560d7e60)
![{\displaystyle 11100,\quad 11011,\quad 10010,\quad 10101.}](https://wikimedia.org/api/rest_v1/media/math/render/svg/9de6982aa719d0ca17b03c31f0a8bb781f786082)
注意到如所有多项式码一样,这个码确实是一个线性码,即码字的线性组合还是码字。在域为 GF(2) 的情形,可以通过对二进制形式的两个码字取XOR(如00111 XOR 10010 = 10101)得到其线性组合。
在
上长度为
、生成多项式为
阶多项式
的多项式码中,会有
个码字。事实上,根据定义,当且仅当一个码字形式为
(其中
的阶小于
)时,
才是一个码元。因为会有
个商,所以也会有相同数量的码字。
未编码的数据字长度应为
。
一些作者,如(Lidl & Pilz, 1999),仅讨论了从数据字到码字赋值的映射
。但在数据字不是码字的一部分时会存在缺陷。
相反,常用下面的方法来建立系统码:给定长度为
的数据字
,先把
乘以
,这样的效果就是将
向左移
位。
一般不能被
整除,也就不是一个有效的码字。不过,调整
的最右面
个符号可以得到唯一的码字。
要求它,需要计算
除以
的余式:
![{\displaystyle x^{m}d(x)=g(x)\cdot q(x)+r(x),\,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/da3fc9334ddfdf188c5b90748bc81318dac87b9f)
其中
的阶数小于
。于是对应于数据字
的码字定义为
![{\displaystyle p(x):=x^{m}d(x)-r(x),\,}](https://wikimedia.org/api/rest_v1/media/math/render/svg/0f9971b68dad5fe44c1665c60b8e0090193078fe)
注意以下性质:
可以被
整除。特别地,
是一个有效码字。
- 由于
的阶数小于
,
最左面的
个符号与
中对应符号相同。换句话说,码字的前
个符号与原数据字相同。剩下的
个符号称为校验位。
对于
、
、生成多项式为
的上述码,我们的带下列从数据字到码字的赋值:
- 000 ↦ 00000
- 001 ↦ 00111
- 010 ↦ 01001
- 011 ↦ 01110
- 100 ↦ 10010
- 101 ↦ 10101
- 110 ↦ 11011
- 111 ↦ 11100
错误消息可以直接通过多项式除以生成多项式得到非零余式而检测出来。
假设码字没有差错,系统码可以通过剥离
个检验位译码。
如果存在差错,则应在译码前纠错。有些多项式码(如BCH码)会有高效的译码算法。
多项式码的性质[编辑]
对于所有数字码来说,多项式码的误差检测与校正能力取决于该码的最小汉明距离。由于多项式码是线性码,最小汉明距离等于任何非零码字的最小重量。在上面的例子中,最小汉明距离是2,因为01001是一个码字,并且没有非零码字只有一位是1的。
多项式码更具体的性质往往取决于它的生成多项式的特定的代数性质。这里有此类性质的一些例子:
- 一个多项式码当且仅当生成多项式能够整除
时为循环码。
- 如果生成多项式是本原多项式,若
,则得到的码的汉明距离最小为3。
- 在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.