lược đồ giải mã
LƯỢC ĐỒ GIẢI MÃ Mục tiêu Sau khi hoàn tất bài học này bạn có thể: Biết đặt vấn đề bài toán giải mã, Hiểu các khái niệm cơ bản của kỹ thuật truyền tin, Biết và hiểu các dạng sai số cơ bản của kỹ thuật truyền tin, ...
LƯỢC ĐỒ GIẢI MÃ
Mục tiêu
Sau khi hoàn tất bài học này bạn có thể:
- Biết đặt vấn đề bài toán giải mã,
- Hiểu các khái niệm cơ bản của kỹ thuật truyền tin,
- Biết và hiểu các dạng sai số cơ bản của kỹ thuật truyền tin,
- Hiểu phương pháp xây dựng tối ưu,
- Vận dụng xây dựng tối ưu và tính các dạng xác suất truyền sai.
Đặt vấn đề bài toán giải mã
Phân tích yêu cầu giải mã:
Khi truyền giá trị xi, ta sẽ nhận được yj.
Đối với kênh truyền không nhiễu thì yj chính là xi. Đối với kênh truyền có nhiễu thì yj có thể khác xi. Do đó ta cần tìm cách giải mã yj về giá trị xi khi kênh truyền có nhiễu.
Phép phân hoạch các giá trị ở đầu nhận:
Phép phân hoạch tập các giá trị ở đầu nhập yj thuộc Y là phép phân chia tập Y thành các tập con Bi sao cho:
1.
(mọi i ≠ j)
2. Khi nhận yj thuộc Bi thì giải mã về xi.
Ví dụ bài toán giải mã
Cho tập các từ mã truyền X và tập các dãy n bit nhận được Y như sau:
X={0000, 0101, 1110, 1011}
Y={0000, 0001, 0010, 0011, 0100, 0101, 0110, 0111,
1000, 1001, 1010, 1011, 1100, 1101, 1110, 1111}
Giả sử ta có thể phân hoạch tập Y thành các tập con Bi như sau:
B1={0000, 1000, 0001, 0010}
B2={0101, 1101, 0100, 0111}
B3={1110, 0110, 1111, 1100}
B4={1011, 0011, 1010, 1001}
Giả sử nhận yj = 0011 thì giải mã về x4 = 1011 vì yj thuộc B4.
Các khái niệm cơ bản của kỹ thuật truyền tin
Xét sơ đồ truyền tin như sau:
Diễn giải:
- Nguồn phát tín hiệu (hay thông báo) với vận tốc R (tín hiệu/giây).
- Tín hiệu được mã hóa từ bộ ký tự mã.
- Tín hiệu mã hóa được truyền trên kênh với vận tốc C (ký tự/giây), C đồng thời là dung lượng của kênh truyền.
- Tín hiệu truyền trên kênh có thể bị nhiễu với xác suất P(e).
- Trước khi nhận, tín hiệu mã hóa được giải mã theo một phương thức tối ưu và độ chính xác cao nhất có thể có.
Bài toán đặt ra ở đây: tìm giải pháp tạo mã sao cho sai số đầu nhận có xác suất nhỏ hơn ε bất kỳ (ε < P(e)) đồng thời với đồng bộ hóa: vận tốc phát thông báo ở nguồn R và vận tốc truyền tải ≤ C (C là dung lượng kênh).
Các khái niệm cơ bản:
Từ mã: là dãy n ký tự truyền hay dãy n ký tự nhận đúng.
Bộ mã (S,n): là tập hợp gồm S từ mã với độ dài mỗi từ mã đều bằng n và được ký hiệu là x(1), …, x(s).
Lược đồ giải mã: là một hàm gán cho một dãy n ký tự nhận được yj một từ mã của bộ mã W = {w1, w2, …, ws}. Ký hiệu: g(yj) = wi
Lược đồ giải mã tối ưu: là sao cho tổng xác suất truyền sai là nhỏ nhất hay tổng xác suất truyền đúng là lớn nhất.
Nghĩa là: khi nhận yj thì ta giải mã về wi* sao cho:
P(wi*/yj) = Max{P(wk/yj)}
mọi wk thuộc W
Ví dụ minh họa các khái niệm cơ bản
Giả sử kênh truyền từng bit với C=1, nguồn phát thông báo với tốc độ R=2/5 bit/giây (R<C). Để thuận lợi cho mã hóa và giảm nhiễu, ta xét từng khoảng thời gian n = 5 giây. Như vậy trong khoảng thời gian n = 5 giây, ta có:
- Tập hợp các tín hiệu khác nhau là 2nR = 4. Giả sử 4 tín hiệu là m1, m2, m3, m4.
- Số bit được phát ra là nR=2 bit và một tín hiệu dạng mi được kết cấu bởi một dãy các bit.
- Quá trình mã hóa các tín hiệu m1, m2, m3, m4 cầnchú ý là: mỗi mi cần được mã hóa với số bit tối đa là nC=5 bit. Vậy, ta có thể mã hóa các tín hiệu mi theo 2 cách sau:
Cách 1:
m1=00000
m2=01101
m3=11010
m4=10111
Cách 2:
m1=00
m2=01
m3=10
m4=11
Nếu sử dụng cách 1 với độ dài 5 bit, trong đó 5 bit có thể hiểu là có 2 bit thông tin cần truyền và 3 bit con lại là 3 bit được bổ sung để phát hiện nhiễu theo một phương pháp nào đó sẽ được đề cập ở các nội dung tiếp theo sau. Với cách mã hóa này, ta có nhiều khả năng phát hiện và sửa sai do nhiễu.
Nếu sử dụng cách 2 thì trường hợp có 1 bit truyền sai sẽ dẫn đến trùng lặp sang một trong các tín hiệu khác. Ví dụ truyền m1=00 và nhận 2 bit là 01 (do nhiễu), trong trường hợp này 01 chính là m2, đây là một tín hiệu đúng nên ta không thể phát hiện có nhiễu hay không nhiễu.
Như vậy, trong khoảng thời gian truyền và dung lượng kênh cho phép, ta cần mã hóa mỗi tín hiệu càng dài càng tốt nhưng không được vượt quá độ dài mã cho phép. Trường hợp với thời gian n=5 và c= 1 bit thì nC=5 là số bit tối đa có thể truyền nên ta chỉ mã hóa tín hiệu với độ dài mã tối đa là 5 bit.
Các dạng sai số cơ bản
Xác suất truyền sai từ mã xi:
Xác suất truyền sai trung bình:
Xác suất truyền sai lớn nhất:
Phương pháp xây dựng lượt đồ giải mã tối ưu
Theo công thức Bayes:
Ta có: P(wk/yj) = [p(wk).p(yj/wk)] / p(yj) với (mọi wk thuộc W)
Từ định nghĩa tối ưu:
⇒ tìm wk sao cho P(wk/yj) → Max <=> p(wk).p(yj/wk) → Max.
Như vậy, ta có thể xây dựng tối ưu theo các bước sau:
Bước 0: Khởi tạo các Bi = ϕ (mọi i)
Bước lặp: xét với mọi yj thuộc Y
+ Tính:
p(w1).p(yj/w1)
p(w2).p(yj/w2)
…
p(wM).p(yj/wM)
+ So sánh các giá trị tính trên và chọn giá trị w*i sao cho p(w*i).p(yj/w*i)= Max {p(wk).p(yj/wk)} (mọi wk thuộc W)
+ Bi = Bi + {yj} và g(yj) = w*i.
Minh họa xây dựng tối ưu
Bài toán:
Cho ma trận truyền tin A và xác suất ở đầu truyền như sau:
Với p(x1)=1/2; p(x2)=p(x3)=1/4. Hãy xây dựng tối ưu.
Áp dụng phương pháp xây dựng tối ưu:
Bước 0: B1={}; B2={}; B3={};
Bước 1: Nhận giá trị y1, ta tính:
+ p(x1).p(y1/x1)= 1/2.1/2 = 1/4 (Max)
+ p(x2).p(y1/x2)= 1/4.1/3 = 1/12
+ p(x3).p(y1/x3)= 1/4.1/6 = 1/24
Do p(x1).p(y1/x1) lớn nhất nên liệt kê y1 vào tập hợp B1 tương ứng với x1.
=> B1={y1}.
Bước 2: Nhận giá trị y2, ta tính:
+ p(x1).p(y2/x1)= 1/2 . 1/3 = 1/6 (Max)
+ p(x2).p(y2/x2)= 1/4 . 1/6 = 1/24
+ p(x3).p(y2/x3)= 1/4 . 1/2 = 1/8
Do p(x1).p(y1/x1) lớn nhất nên liệt kê y2 vào tập hợp B1 tương ứng với x1.
=> B1={y1, y2}.
Bước 3: Nhận giá trị y3, ta tính:
+ p(x1).p(y3/x1)= 1/2 . 1/6 = 1/12
+ p(x2).p(y3/x2)= 1/4 . 1/2 = 1/8 (Max)
+ p(x3).p(y3/x3)= 1/4 . 1/3 = 1/12
Do p(x1).p(y2/x1) lớn nhất nên liệt kê y3 vào tập hợp B2 tương ứng với x2.
=> B2={y3}.
Kết quả:
Phân hoạch: B1={y1, y2}, B2=
{y3} và B3={}.
Lược đồ giải mã tối ưu:
Minh họa cách tính các sai số
Xét lại ví dụ minh họa xây dựng tối ưu trên, ta có:
- Ma trận truyền tin A:
- Xác suất ở đầu truyền: p(x1)=1/2; p(x2)=p(x3)=1/4.
- Lược đồ giải mã tối ưu:
- Phân hoạch: B1={y1, y2}, B2={y3} và B3={}.
Tính các xác suất truyền sai:
Xác suất truyền sai một từ mã:
Bài tập 1
Cho ma trận truyền tin sau:
Biết xác suất ở đầu truyền: p(x1)=5/10, p(x2)=3/10, p(x3)=2/10.
- Tính dung lượng kênh truyền.
- Xây dựng tối ưu.
- Tính các sai số p(e) và pm(e).
Cho ma trận truyền tin sau:
Biết xác suất ở đầu truyền: p(x1)=1/3, p(x2)=1/3, p(x3)=1/3.
- Tính dung lượng kênh truyền.
- Xây dựng tối ưu
- Tìm các sai số p(e) và pm(e).
Bài Tập 2
Cho ma trận truyền tin sau:
Biết p(x1)=1/2, p(x2)=1/4, p(x3)=1/4.
- Tính dung lượng kênh truyền.
- Xây dựng tối ưu.
- Tính các sai số p(e) và pm(e).
Cho ma trận truyền tin sau:
Biết xác suất truyền p(x1)=0.4, p(x2)=0.4, p(x3)=0.2.
- Tính dung lượng kênh truyền.
- Xây dựng tối ưu.
- Tính các sai số p(e) và pm(e).