Polinom kodu - Polynomial code

İçinde kodlama teorisi, bir polinom kodu bir tür doğrusal kod kimin grubu geçerli kod kelimeleri bunlardan oluşur polinomlar (genellikle sabit uzunlukta) bölünebilir belirli bir sabit polinom ile (daha kısa uzunlukta, üreteç polinomu).

Tanım

Düzelt bir sonlu alan , kime elemanlar diyoruz semboller. Polinom kodları oluşturmak amacıyla, bir dizi tanımlıyoruz semboller polinom ile

Tam sayıları düzelt ve izin ver sabit bir derece polinomu olmak , aradı üreteç polinomu. tarafından oluşturulan polinom kodu kod kelimeleri tam olarak şundan daha düşük derece polinomları olan koddur bunlar bölünebilir (kalan olmadan) tarafından .

Misal

Polinom kodunu düşünün ile , ve jeneratör polinomu . Bu kod aşağıdaki kod sözcüklerinden oluşur:

Veya açıkça yazılmış:

Polinom kodu İkili Galois Alanı üzerinde tanımlandığından polinom elementler bir modulo -2 toplamı ve son polinomlar şunlardır:

Benzer şekilde, ikili rakam dizileri olarak ifade edilen kod sözcükleri şunlardır:

Bu, her polinom kodu gibi, aslında bir doğrusal kod yani, kod kelimelerinin doğrusal kombinasyonları yine kod kelimeleridir. Alanın GF (2) olduğu böyle bir durumda, doğrusal kombinasyonlar ikili biçimde ifade edilen kod sözcüklerinin XOR'u alınarak bulunur (ör. 00111 XOR 10010 = 10101).

Kodlama

Bir polinom kodunda kod uzunluğu ile ve jeneratör polinomu derece tam olarak olacak kod kelimeleri. Nitekim, tanımı gereği, bir kod sözcüğü ancak ve ancak biçimindeyse , nerede ( bölüm) dereceden daha az . Olduğundan beri bu tür bölümler mevcutsa, aynı sayıda olası kod sözcüğü vardır. Bu nedenle, düz (kodlanmamış) veri sözcükleri uzunlukta olmalıdır

(Lidl ve Pilz, 1999) gibi bazı yazarlar, yalnızca veri sözcüklerinden kod sözcüklerine atama olarak. Bununla birlikte, bunun dezavantajı, veri kelimesinin kod kelimesinin bir parçası olarak görünmemesidir.

Bunun yerine, aşağıdaki yöntem genellikle bir sistematik kod: bir veri kelimesi verildiğinde uzunluk önce çarp tarafından değişen etkiye sahip olan tarafından soldaki yerler. Genel olarak, ile bölünemez yani geçerli bir kod kelimesi olmayacaktır. Bununla birlikte, en sağdaki ayarlayarak elde edilebilecek benzersiz bir kod sözcüğü vardır. sembolleri Hesaplamak için bölmenin kalanını hesaplayın. tarafından :

nerede dereceden daha az . Veri sözcüğüne karşılık gelen kod sözcüğü daha sonra olarak tanımlanır

Aşağıdaki özelliklere dikkat edin:

  1. , ile bölünebilen . Özellikle, geçerli bir kod kelimesidir.
  2. Dan beri dereceden daha az en soldaki sembolleri ilgili sembollere katılıyorum . Başka bir deyişle, ilk kod kelimesinin sembolleri orijinal veri kelimesiyle aynıdır. Kalan semboller denir sağlama toplamı rakamları veya bitleri kontrol et.

Misal

Yukarıdaki kod için , ve jeneratör polinomu , veri sözcüklerinden kod sözcüklerine aşağıdaki atamayı elde ederiz:

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

Kod çözme

Hatalı bir mesaj, sıfır olmayan bir kalanla sonuçlanan, jeneratör polinomu tarafından polinom bölünmesi yoluyla basit bir şekilde tespit edilebilir.

Kod sözcüğünün hatasız olduğunu varsayarsak, sistematik bir kod basitçe sağlama toplamı rakamları.

Hatalar varsa, kod çözmeden önce hata düzeltmesi yapılmalıdır. Belirli polinom kodlar için verimli kod çözme algoritmaları mevcuttur. BCH kodları.

Polinom kodlarının özellikleri

Tüm dijital kodlarda olduğu gibi, hata tespiti ve düzeltme polinom kodlarının yetenekleri minimum Hamming mesafesi kodun. Polinom kodlar doğrusal kodlar olduğundan, minimum Hamming mesafesi sıfır olmayan herhangi bir kod sözcüğün minimum ağırlığına eşittir. Yukarıdaki örnekte, minimum Hamming mesafesi 2'dir, çünkü 01001 bir kod sözcüğüdür ve yalnızca bir bit kümesine sahip sıfır olmayan bir kod sözcüğü yoktur.

Bir polinom kodunun daha spesifik özellikleri, genellikle onun oluşturucu polinomunun belirli cebirsel özelliklerine bağlıdır. İşte bu tür özelliklerin bazı örnekleri:

  • Bir polinom kodu döngüsel ancak ve ancak jeneratör polinomu bölünürse .
  • Jeneratör polinomu ise ilkel, daha sonra ortaya çıkan kodun Hamming mesafesi en az 3 olmalıdır. .
  • İçinde BCH kodları Oluşturucu polinomu, yüksek Hamming mesafesine ulaşacak şekilde bir uzatma alanında belirli köklere sahip olacak şekilde seçilir.

Polinom kodlarının cebirsel doğası, akıllıca seçilmiş üreteç polinomları ile birlikte, verimli hata düzeltme algoritmaları bulmak için sıklıkla kullanılabilir. Bu durum için BCH kodları.

Belirli polinom kod aileleri

  • Döngüsel kodlar - her döngüsel kod aynı zamanda bir polinom kodudur; popüler bir örnek, CRC kodu.
  • BCH kodları - yüksek Hamming mesafesine ve verimli cebirsel hata düzeltme algoritmalarına sahip döngüsel kodlar ailesi.
  • Reed-Solomon kodları - özellikle verimli bir yapıya sahip önemli bir BCH kodu alt kümesi.

Referanslar

  • W.J. Gilbert ve W.K. Nicholson: Uygulamalı Modern Cebir, 2. baskı, Wiley, 2004.
  • R. Lidl ve G. Pilz. Applied Abstract Cebir, 2. baskı. Wiley, 1999.