Mã tuyến tính

Từ testwiki
Bước tới điều hướng Bước tới tìm kiếm

Trong lý thuyết mã hóa, mã tuyến tínhmã sửa lỗi trong đó mọi tổ hợp tuyến tính của các mã tự cũng là một mã tự. Mã tuyến tính thường được phân loại thành mã khốimã chập, mặc dù mã Turbo có thể được coi là thuộc cả hai thể loại.[1] Mã tuyến tính thường có thuật toán mã hóa và giải mã hiệu quả hơn các loại mã khác (tham khảo giải mã hội chứng).

Mã tuyến tính được dùng trong sửa lỗi trước và được dùng để truyền các ký hiệu (chẳng hạn như bit) trên một kênh liên lạc sao cho, nếu có lỗi trong quá trình truyền, người nhận có thể phát hiện và sửa một số lỗi trong khối nhận được. Mỗi mã tự trong một mã khối tuyến tính là một khối các ký hiệu được mã hoá thành một khối lớn hơn khối ban đầu. Lượng thông tin thừa trong mỗi khối được dùng để phát hiện và sửa các lỗi trong quá trình truyền. Độ dài n của mã khối tuyến tính số ký hiệu trong một khối. Ví dụ, mã Hamming [7,4,3] là một mã nhị phân tuyến tính biểu diễn mỗi thông điệp 4 bit bằng một mã tự 7 bit. Hai mã tự khác nhau sai khác ở ít nhất 3 bit. Do đó, mã có thể phát hiện 2 lỗi sai và sửa 1 lỗi sai.[2] Mã này gồm 24=16 mã tự.

Định nghĩa và các tham số

Một mã tuyến tính với độ dài n và hạng/số chiều k là một không gian con C với số chiều k của không gian vectơ 𝔽qn trong đó 𝔽qtrường hữu hạn với q phần tử. Mã như vậy gọi là mã q-phân. Nếu q = 2 hay q = 3, thì mã đó được gọi tương ứng là mã nhị phân, và mã tam phân. Các vectơ trong C được gọi là các mã tự. Kích thước của một mã là số mã tự, và đúng bằng qk.

Trọng lượng của một mã tự là số lượng phần tử khác không của nó và khoảng cách giữa hai mã tự là khoảng cách Hamming giữa chúng, nghĩa là số phần tử khác nhau giữa hai mã tự. Khoảng cách d của một mã là trọng lượng nhỏ nhất trong các mã tự khác không, hoặc một cách tương đương, khoảng cách nhỏ nhất giữa hai mã tự khác nhau. Mã tuyến tính độ dài n, số chiều k, và khoảng cách d được ký hiệu là mã [n,k,d].

Ghi chú: Ta sử dụng cơ sở thông thường cho 𝔽qn vì mỗi tọa độ ứng với một ký hiệu được truyền trên "kênh nhiễu". Chỉ khi sử dụng cơ sở này thì khoảng cách Hamming mới tương ứng với số lỗi sai trong quá trình truyền.

Tính chất

Vì là một không gian con của 𝔽qn, toàn bộ mã C (có kích thước lớn) có thể được biểu diễn chỉ bằng một hệ sinh gồm ít nhất mã tự (gọi là cơ sở trong đại số tuyến tính). Nếu ghép các mã tự này làm các hàng của ma trận G thì ma trận đó gọi là ma trận sinh của mã C. Khi G có dạng khối G=(Ik|A), trong đó Ik là ma trận đơn vị k×k và A là một ma trận k×(nk), thì ta nói G nằm ở dạng chuẩn.

Ma trận H biểu diễn biến đổi tuyến tính ϕ:𝔽qn𝔽qnkhạt nhânC được gọi là ma trận kiểm tra của C (còn được gọi là ma trận kiểm tra tính chẵn lẻ). Nếu C là mã với ma trận sinh G ở dạng chuẩn, G = (Ik | A), thì H = (−At | In − k) là ma trận kiểm tra của C. Mã sinh bởi H được gọi là mã đối ngẫu của C.

Tính chất tuyến tính đảm bảo khoảng cách Hamming nhỏ nhất d giữa mã tự c0 và bất kì mã tự c ≠ c0 nào là độc lập với c0. Điều này được suy ra từ tính chất hiệu c − c0 của hai mã tự trong C cũng là một mã tự (nghĩa là một phần tử của không gian C), và tính chất d(c, c0) = d(c − c0, 0). Theo các tính chất này,

mincC, cc0d(c,c0)=mincC,cc0d(cc0,0)=mincC,c0d(c,0)=d.

Nói cách khác, để xác định khoảng cách nhỏ nhất giữa các mã tự của một mã tuyến tính, chỉ cần xét khoảng cách giữa các mã tự khác không và mã tự không. Mã tự khác không có trọng lượng nhỏ nhất chính là mã tự gần mã tự không nhất và trọng số đó chính là khoảng cách nhỏ nhất.

Khoảng cách d của một mã tuyến tính C cũng bằng số nhỏ nhất các cột phụ thuộc tuyến tính của ma trận kiểm tra H.

Chứng minh: Xét Bản mẫu:Mvar là mã tự có trọng số nhỏ nhất. Theo định nghĩa, 𝑯𝒄T=0 nên các cột 𝑯𝒊 với ci0 phụ thuộc tuyến tính. Vì vậy số cột nhỏ nhất phụ thuộc tuyến tính là nhỏ hơn hoặc bằng d.

Mặt khác xét một tập hợp nhỏ nhất các cột phụ thuộc tuyến tính {𝑯𝒋|jS} trong đó S là tập hợp các chỉ số các cột này. i=1n(ci𝑯𝒊)=jS(cj𝑯𝒋)+jS(cj𝑯𝒋)=0. Xét vectơ 𝒄 sao cho cj'=0 nếu jS. Ta nhận thấy 𝒄C𝑯𝒄T=0. Do đó ta có dwt(𝒄), chính là số nhỏ nhất các cột phụ thuộc tuyến tính của 𝑯.

Như vậy, ta thu được kết quả cần chứng minh.

Ví dụ: mã Hamming

Bản mẫu:Chính

Là loại mã đầu tiên được dùng cho mục đích sửa lỗi, mã Hamming được sử dụng rộng rãi trong các hệ thống truyền thông số. Với mọi số nguyên dương r2, tồn tại một mã Hamming [2r1,2rr1,3]2. Vì d=3, mã Hamming có thể sửa lỗi 1 bit.

Ví dụ: Sau đây là ma trận sinh và ma trận sửa lỗi của mã Hamming [7,4,3]2.

𝑮=(1 1 0 1 0 0 00 1 1 0 1 0 01 1 1 0 0 1 01 0 1 0 0 0 1),: 𝑯=(1 0 0 1 0 1 10 1 0 1 1 1 00 0 1 0 1 1 1)

Ví dụ: mã Hadamard

Bản mẫu:Chính

Mã Hadamard là một mã tuyến tính [2r,r,2r1]2 có thể sửa nhiều lỗi. Có thể xây dựng ma trận sinh của mã Hadamard lần lượt từng cột một: cột thứ i là các bit của biểu diễn nhị phân của số nguyên i, như trong ví dụ dưới đây. Mã Hadamard có khoảng cách nhỏ nhất 2r1 và do đó có thể sửa 2r21 lỗi.

Ví dụ: Sau đây là ma trận sinh của mã Hadamard [8,3,4]2: 𝑮Had=(0 0 0 0 1 1 1 10 0 1 1 0 0 1 10 1 0 1 0 1 0 1).

Mã Hadamard là một trường hợp đặc biệt của mã Reed–Muller. Nếu ta loại bỏ cột thứ nhất (cột toàn 0) của 𝑮Had, thì thu được mã đơn hình [7,3,4]2, chính là mã đối ngẫu của mã Hamming.

Ký hiệu phổ biến

Bản mẫu:Chính thường được ký hiệu bởi chữ cái C. Mã có chiều dài n và số chiều k (nghĩa là có k mã tự trong cơ sở và ma trận sinhk hàng) thường được gọi là mã (nk). Mã tuyến tính thường được ký hiệu là [nkd], trong đó d là khoảng cách Hamming nhỏ nhất giữa hai mã tự.

Ghi chú. Ký hiệu [nkd] là khác với ký hiệu (nMd) thường được dùng để ký hiệu mã không tuyến tính chiều dài n, kích thước M (nghĩa là có M mã tự), và khoảng cách Hamming nhỏ nhất d.

Ví dụ

Một vài ví dụ của mã tuyến tính bao gồm:

Xem thêm

Ghi chú

Bản mẫu:Tham khảo

Liên kết ngoài