Berlekamp – Welch algoritması - Berlekamp–Welch algorithm

Berlekamp – Welch algoritmasıolarak da bilinir Welch – Berlekamp algoritması, adı Elwyn R. Berlekamp ve Lloyd R. Welch. Bu, içindeki hataları verimli bir şekilde düzelten bir kod çözücü algoritmasıdır. Reed-Solomon kodları RS için (n, k), Reed Solomon orijinal görünümüne dayanan kod, bir mesajın bir polinomun katsayıları olarak kullanılır veya ile kullanıldı Lagrange enterpolasyonu polinomu oluşturmak için derece < k girişler için ve sonra uygulandı kodlanmış bir kod sözcüğü oluşturmak için .

Kod çözücünün amacı, orijinal kodlama polinomunu kurtarmaktır. bilinen girdileri kullanarak ve kod sözcüğü alındı olası hatalarla. Ayrıca bir hata polinomunu hesaplar nerede alınan kod sözcüğündeki hatalara karşılık gelir.

Anahtar denklemler

Tanımlama e = hata sayısı, anahtar seti n denklemler

Nerede E (aben) = 0 için e b olduğundaben ≠ F (birben) ve E (aben) ≠ 0 için n - e hata olmayan durumlar bben = F (aben). Bu denklemler doğrudan çözülemez, ancak Q () 'yu E () ve F ()' nin ürünü olarak tanımlayarak:

ve en önemli katsayısı olan E (aben) = ee = 1, sonuç doğrusal cebir ile çözülebilecek bir dizi denkleme yol açacaktır.

nerede q = n - e - 1. O zamandan beri ee 1 ile sınırlandırıldığında denklemler şöyle olur:

zaman karmaşıklığı O (n ^ 3) olan doğrusal cebir kullanılarak çözülebilen bir dizi denklemle sonuçlanır.

Algoritma, maksimum hata sayısını varsaymaya başlar e = ⌊ (n-k) / 2 ⌋. Denklemler çözülemiyorsa (fazlalık nedeniyle), e 1 azaltılır ve denklemler çözülene kadar süreç tekrarlanır veya e 0'a düşürülür ve hata olmadığını gösterir. Q () / E () kalanı = 0 ise, F () = Q () / E () ve kod kelime değerleri F (aben), E'nin (abenOrijinal kod sözcüğünü kurtarmak için) = 0. Kalan ≠ 0 ise, düzeltilemez bir hata tespit edilmiştir.

Misal

RS'yi düşünün (7,3) (n = 7, k = 3) içinde tanımlanmıştır GF(7) ile α = 3 ve giriş değerleri: aben = i-1: {0,1,2,3,4,5,6}. Sistematik olarak kodlanacak mesaj {1,6,3}. Lagrange enterpolasyonunu kullanarak, F (birben) = 3 x2 + 2 x + 1 ve uygulanıyor F (birben) için a4 = 3 ila a7 = 6, {1,6,3,6,1,2,2} kod kelimesiyle sonuçlanır. Hataların oluştuğunu varsayın c2 ve c5 alınan kod sözcüğü {1,5,3,6,3,2,2} ile sonuçlanır. Ile başlamak e = 2 ve doğrusal denklemleri çözün:



Sağ matrisin altından ve kısıtlamadan başlayarak e2 = 1:

kalan = 0.

E (aben) = 0 a2 = 1 ve a5 = 4F hesapla (a2 = 1) = 6 ve F (a5 = 4) = 1 düzeltilmiş kod sözcüğü {1,6,3,6,1,2,2} üretmek için.

Ayrıca bakınız

Dış bağlantılar