Trên đây em đã trình bày toàn bộ phần nội dung nghiên cứu vê bộ lọc
thích nghi. Để hiểu về hoạt động của bộ lọc, em đã thực hiện tìm hiểu cụ thể
về các thuật toán dùng trong đó. Các thuật toán đó được bao gồm các thuật
toán cho bộ lọc FIR dạng trực tiếp và cho cấu trúc lưới. Các thuật toán cho bộ
lọc FIR dạng trực tiếp là thuật toán LMS đơn giản, thuật toán bình phương tối
thiểu đệ quy thời gian(RLS).
Trong đó thuật toán LMS là đơn giản nhất. Nó được sử dụng trong nhiều
ứng dụng yêu cầu tốc độ hội tụ chậm. Thuật toán RLS được dùng trong các
ứng dụng yêu cầu tốc độ hội tụ cao hơn.Các thuật toán dành cho bộ lọc có cấu
trúc thang lưới là: thuật toán thang lưới RLS tối ưu, thuật toán thang lưới
gradient. Các thuật toán này giúp bộ lọc thích nghi được với sự thay đổi của
tín hiệu đầu vào và tốc độ hội tụ thích hợp. Và từ phần mô phỏng trên, ta
cũng thấy rõ hơn về hoạt động của bộ lọc với một thuật toán cụ thể, thuật toán LMS.
74 trang |
Chia sẻ: linhlinh11 | Lượt xem: 958 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Đồ án Nghiên cứu bộ lọc thích nghi, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
hông thấp, thông dải, ...) một cách
chung nhất là dựa trên những biến đổi của thiết kế tương tự.
- Các thiết kế Butterword
- Các thiết kế Bessel
- Các thiết kế Chebyshev
- Các thiết kế Elliptic
Tất cả những phương pháp trên dùng phép phân tích tự nhiên và được
ứng dụng rộng rãi để thiết kế các bộ lọc IIR. Thêm vào đó các phương pháp
tối ưu hoá IIR đã được phát triển cho thiết kế xấp xỉ liệt kê, điều này không dễ
thích nghi với một trong các phương pháp xấp xỉ trên.
Sự khác nhau chính giữa FIR và IIR là IIR không thể thiết kế để có pha
tuyến tính chính xác, khi mà FIR có những thuộc tính này, còn bộ lọc IIR hiệu
quả hơn trong thực hiện lọc cắt nhọn hơn là FIR.
Mạng bao hàm phương trình (1.1.12) được biểu diễn trong hình 1.2a cho
trường hợp N=M=3, nó thường được gọi là dạng biểu diễn trực tiếp.
Đặc biệt bộ phương trình sau thường được sử dụng:
M
r
r
N
k
k
rnwbny
nxknwanw
0
1 (1.1.15)
Bộ phương trình này có thể biểu diễn như trong hình 1.2b, với bộ nhớ để
lưu giữ được yêu cầu và chứa các giá trị dãy trễ.
Phương trình (1.1.7) chỉ ra rằng H(Z) có thể biểu diễn như một tích các
15
điểm cực. Những điểm cực và điểm không này là các cặp liên hiệp phức, vì
các hệ số ak và bk là thực.
Bằng những nhóm liên hiệp phức điểm cực và điểm không trong cặp liên
hợp phức, nó cũng có thể biểu diễn H(Z) như tích của các hàm hệ thống cơ
bản cấp hai dạng:
K
k kk
kk
ZaZa
ZbZb
AZH
1
2
2
1
1
2
2
1
1
1
1
(1.1.16)
K là phần nguyên của (N+1)/2. Hệ thống cấp hai này được biểu diễn như
trong hình 1.3a cho trường hợp N=M=4.
(a)
(b)
Hình 1.2. (a) Cấu trúc dạng trực tiếp;
(b) Cấu trúc dạng trực tiếp tối giản
Tiếp tục, một cấp độ cao hơn được xét đến. Bằng cách kết hợp những
phần liên quan đến cực liên hợp phức, H(Z) có thể viết dạng:
Z-1
x(n)
+
Z-1
+
Z-1
b0
b1
b2
b3
+
+
Z-1
+
Z-1
+
Z-1
a1
a2
a3
+
+
y(n)
x(n)
+
+
b0
b1
b2
b3 +
+
Z-1
+
Z-1
+
Z-1
a1
a2
a3 +
+
y(n) w(n)
16
K
k kk
kk
ZaZa
Zcc
ZH
1
2
2
1
1
1
10
1
(1.1.17)
Điều này gợi ý một dạng sơ đồ song song biểu diễn như hình 1.3b cho N=4.
(a)
(b)
Hình 1.3. (a) Dạng tầng;
(b) Dạng song song
Trong những ứng dụng lọc tuyến tính, dạng song song đưa ra những đặc
tính cao hơn về phương diện làm tròn giảm tiếng ồn, các sai số hệ số, và tính
ổn định.
x(n)
+
+
b10
b11
b12
+
Z-1
+
Z-1
+
a11
a12
+
y(n)
+
+
b20
b21
b22
+
Z-1
+
Z-1
+
a21
a22
+
c10
x(n)
+
+
c11
+
Z-1
+
Z-1
a11
a12
y(n)
+
+
+
c20
c21
+
Z-1
+
Z-1
a21
a22
17
Chương 2.
BỘ LỌC THÍCH NGHI
2.1. Bộ lọc FIR thích nghi dạng trực tiếp
Từ chuẩn bình phương tối thiểu đưa tới khuôn mẫu chung thiết lập công
thức tuyến tính cho hệ số bộ lọc.
(2.1.1)
Dãy tự tương quan và tương quan chéo nhận được từ dữ
liệu, do đó chúng mô tả những ước lượng của dãy tương quan và tự tương
quan thực. Hệ số h(k) ở (2.1.1) cũng là những ước lượng của hệ số thực. Độ
chính xác của các ước lượng phụ thuộc vào độ dài của bản ghi dữ liệu, đó là
1 vấn đề cần cân nhắc trong hệ thống xử lí của bộ lọc.
Vấn đề thứ 2 cần quan tâm đó là quá trình ngẫu nhiên cơ bản x(n)
thường xuyên không ổn định. Ví dụ, trong bộ hiệu chỉnh kênh, các thông số
đặc trưng cho tần số có thể biến đổi theo thời gian. Như 1 hệ quả, các dãy
tương quan và tự tương quan thống kê, và các ước lượng của chúng thay đổi
theo thời gian. Điều này làm cho hệ số của bộ lọc thích nghi cũng phải thay
đổi theo thời gian để phản ánh được các thông số thay đổi theo thời gian của
tín hiệu ở đầu vào bộ lọc. Điều này cũng kéo theo chất lượng của ước lượng
không thể tăng bằng cách đơn giản là tăng số mẫu tín hiệu được sử dụng trong
ước lượng các dãy tương quan và tự tương quan.
Có nhiều cách để hệ số của bộ lọc có thể biến đổi theo thời gian cùng với
các thông số thống kê theo thời gian của tín hiệu. Phương pháp phổ biến nhất
là đưa vào bộ lọc dựa trên các mẫu liên tiếp một cách đệ quy mỗi khi nhận
được một mẫu tín hiệu. Cách thứ 2 là ước lượng và trên cơ sở
các khối liên tiếp, và không duy trì sự liên tục của các giá trị của hệ số bộ lọc
từ một khối dữ liệu tới một khối khác. Kích thước khối phải tương đối nhỏ,
chiếm một khoảng thời gian ngắn khi so sánh với khoảng thời gian mà các
18
đặc trưng thống kê của dữ liệu thay đổi một cách đáng kể.
Khi nghiên cứu về các thuật toán của bộ lọc thích nghi, ta chỉ chú ý tới
các thuật toán đệ quy thời gian mà nó cập nhật hệ số dựa trên các mẫu liên
tiếp. Trong thực tế ta xét tới hai dạng thuật toán: thuật toán LMS (Least
Mean Squares), là thuật toán dựa trên kiểu gradient hướng theo sự thay đổi
theo thời gian của các thông số đặc trưng của tín hiệu, và loại thật toán bình
phương tối thiểu đệ quy, là thuật toán phức tạp hơn so với LMS.
2.1.1. Tiêu chuẩn lỗi trung bình bình phương tối thiểu (MMES)
Thuật toán LMS được xác định dễ dàng nhất bằng cách lập công thức tối
ưu tính hệ số của bộ lọc FIR như một sự ước lượng dựa trên việc tối thiểu hóa
lỗi bình phương trung bình.
Ta giả sử có dãy dữ liệu x(n) là các mẫu từ việc xử lí ngẫu nhiên dãy tự
tương quan
(2.1.2)
Từ những mẫu này ta ước lượng dãy d(n) bằng cách đưa x(n) qua bộ lọc
FIR với hệ số bộ lọc h(n), . Đầu ra của bộ lọc là
(2.1.3)
Với là ước lượng của d(n) với lỗi ước lượng là
(2.1.4)
Lỗi trung bình phương như là một hàm của hệ số bộ lọc
19
(2.1.5)
Với và là vector hệ số.
là liên hợp của
là chuyển vị của
Ta thấy rằng MSE là hàm bậc 2 của hệ số bộ lọc. Do đó giá trị nhỏ nhất
của dẫn tới việc thiết lập biểu thức tuyến tính M
(2.1.6)
Bộ lọc có hệ số nhận được từ (2.1.6) (2.1.6 là công thức Wiener-Hopf)
được gọi là bộ lọc Wiener.
Khi so sánh (2.1.6) và (2.1.1) ta thấy rằng chúng cùng dạng. Ở (2.1.1) ta
dùng sự ước lượng về tự tương quan và tương quan chéo để xác định hệ số
bộ lọc, trong khi ở (2.1.6) người ta dùng dãy tự tương quan và tương quan
chéo thống kê được, vì thế (2.1.6) cung cấp hệ số bộ lọc tối ưu trong hướng
MSE, trong khi (2.1.1) đưa ra sự ước lượng về hệ số tối ưu.
Biểu thức (2.1.6) ở dạng ma trận như sau :
(2.1.7)
Với là ma trận Toeplizt ( với thành phần
và bằng vetor tương quan chéo với thành phần
. Và ta có hệ số bộ lọc tối ưu là
20
(2.1.8)
Và
(2.1.9)
Với H là chuyển vị liên hợp.
Việc thiết lập biểu thức tuyến tính (2.1.6) cũng có thể thực hiện bằng
cách đưa ra nguyên lí trực giao trong việc ước lượng trung bình bình phương.
Theo nguyên lí này, lỗi ước lượng trung bình bình phương được tối thiểu hóa
khi e(n) trực giao với ước lượng
(2.1.10)
Hoặc tương đương với
(2.1.11)
Nếu ta thay thế e(n) trong (2.1.11) bằng e(n) trong (2.1.4) và sử dụng
phép toán trung bình ta nhận được biểu thức như (2.1.6).
Do là trực giao với e(n), lỗi bình phương trung bình nhỏ nhất là
(2.1.12)
Hệ số bộ lọc tối ưu như ở (2.1.8) có thể được thực hiện một cách hiệu
quả khi dùng thuật toán Levinson-Durbin. Tuy nhiên ta cần chú ý tới việc
dùng phương pháp gradient, việc đó dẫn tới thuật toán LMS cho bộ lọc.
2.1.2. Thuật toán Widrow LMS
Có nhiều phương pháp để thiết lập biểu thức tuyến tính (2.1.6) hay
(2.1.7) cho hệ số bộ lọc tối ưu. Ở đây ta xét tới phương pháp đệ quy, nó cho
phép tìm cực tiểu của một hàm nhiều biến, MSE là một hàm bậc 2 của hệ số
bộ lọc, do vậy hàm này có duy nhất một giá trị cực tiểu và chúng ta sẽ xác
21
định nó bằng cách lặp nhiều lần.
Ta giả thiết ma trận tự tương quan và vector tương quan chéo đã
biết trước, do đó là hàm đã biết của hệ số h(n), . Các
thuật toán để tính toán một cách đệ quy hệ số bộ lọc và tìm cực tiểu của
có dạng:
(2.1.13)
Với là vector của hệ số bộ lọc tại bước lặp thứ n
là độ lớn bước nhảy tại bước lặp thứ n
là vector hướng cho bước lặp thứ n
giá trị ban đầu được chọn tùy ý.
Phương pháp đơn giản nhất để tìm cực tiểu của một cách đệ quy
là dựa vào việc tìm theo sự hạ thấp của đường dốc, ở phương pháp này vector
, với là vector gradient tại bước nhảy thứ n.
(2.1.14)
Do đó ta sẽ tính vector gradient cho mỗi bước nhảy và thay đổi giá trị
của theo gradient chiều ngược, và ta có thuật toán đệ quy dựa trên
phương pháp tìm theo sự hạ thấp của đường dốc là:
(2.1.15)
Tương đương với
(2.1.16)
Ta không chứng minh thuật toán dẫn tới việc hộ tụ tới khi
, dãy độ lớn bước nhảy hoàn toàn khả tổng và khi .
Một số thuật toán khác cho ta sự hội tụ nhanh hơn như thuật toán liên
hợp gradient và thuật toán Fletcher-Powel. Trong thuật toán liên hợp gradient:
(2.1.17)
22
Với là hàm vô hướng của vector gradient
Trong thuật toán Fletcher-Powel:
(2.1.18)
Với là ma trận dương và nó hội tụ ngược với .
Rõ ràng 3 thuật toán có cách xác định hướng vector khác nhau.
Ba thuật toán trên là thích hợp khi và đã biết, tuy nhiên đó không
phải là trường hợp trong các ứng dụng của bộ lọc thích nghi. Khi không biết
và ta có thể thay thế ước lượng cho thực tế.
Đầu tiên, chú ý rằng vecter gradient ở (2.1.14) cũng có thể được thể hiện
ở điều kiện trực giao như trong (2.1.10), thực tế (2.1.10) tương đương với:
(2.1.19)
Với là vector với các thành phần .
Do vậy vector gradient là
(2.1.20)
Từ (2.1.20) ta có ước lượng khá chính xác về vector gradient
(2.1.21)
Với và là bộ mẫu tín hiệu M trong bộ lọc ở
bước lặp thứ n, khi thay cho ta có thuật toán
(2.1.22)
Và nó gọi là thuật toán hạ bậc gradient ngẫu nhiên, thuật toán này được
áp dụng phổ biến trong các bộ lọc thích nghi để sử dụng thuật toán độ lớn
bước cố định vì hai lí do. Một là thuật toán độ lớn bước cố định được thực
hiện dễ dàng với cả phần cứng và phần mềm. Thứ hai, một bước nhảy đã ấn
định kích thước thì thích ứng với dòng tín hiệu thay đổi theo thời gian, trong
khi nếu khi , việc thích nghi với sự thay đổi của tín hiệu
không thể xảy ra. Vì những lí do đó (2.1.22) có thể được viết
(2.1.23)
23
Với là kích thước bước nhảy đã được ấn định.
Thuật toán này được đưa ra đầu tiên bởi Windrow và Hoft (1960), giờ
đây nó được biết đến rộng rãi với cái tên thuật toán LMS (Least Mean
Square). Rõ ràng, nó là thuật toán gradient ngẫu nhiên.
Thuật toán LMS là thuật toán sử dụng dễ dàng, vì thế nó được dùng rộng
rãi trong nhiều ứng dụng của bộ lọc thích nghi. Các thuộc tính và giới hạn của
nó được nghiên cứu kĩ lưỡng. Trong phần dưới đây, ta sẽ đưa ra bản tóm tắt
về các thuộc tính quan trọng của nó liên quan tới sự hội tụ, độ ổn định và
nhiễu do việc ước lượng vector gradient. Sau đó ta sẽ so sánh thuộc tính của
nó với các thuật toán bình phương tối thiểu đệ quy phức tạp hơn.
Nhiều biến dạng của thuật toán LMS cơ bản được đặt ra trên lí thuyết và
được thực hiện trong một vài ứng dụng của bộ lọc, một trong số đó là: nếu ta
lấy trung bình các vector gradient qua nhiều lần lặp để điều chỉnh hệ số bộ
lọc, ví dụ trung bình K vector gradient là
(2.1.24)
Và theo công thức đệ quy, việc thiết lập hệ số bộ lọc ở mỗi bước lặp K là
(2.1.25)
Việc lấy trung bình như ở (2.1.24) giảm nhiễu trong việc ước lượng
vector gradient.
Một cách khác là đặt một bộ lọc thông thấp và dùng đầu ra của nó để
ước lượng vector gradient. Ví dụ, một bộ lọc thông thấp đơn giản cung cấp
vector gradient ở đầu ra
(2.1.26)
Với xác định dải thông của bộ lọc thông thấp. Khi tiến tới
1, dải thông bộ lọc nhỏ và việc lấy trung bình được thực hiện trên rất nhiều
vector gradient. Mặt khác, khi nhỏ bộ lọc có dải thông lớn và do đó ít
vector gradient được lấy trung bình hơn. Với ở (2.1.26) ta nhận được
một phiên bản mới của thuật toán LMS
24
(2.1.27)
2.1.3. Thuộc tính của thuật toán LMS
Trên thực tế ta tập trung vào thuộc tính hộ tụ, tính ổn định và việc xử lí
nhiễu phát sinh khi thay thế vector gradient nhiễu cho vector gradient thực.
Việc ước lượng nhiễu của vector gradient làm cho hệ số bộ lọc dao động ngẫu
nhiên, và do đó việc giải thích thuộc tính của thuật toán được thực hiện bằng
cách thống kê.
Tính hội tụ và ổn định của thuật toán LMS được nghiên cứu bằng việc
xác định cách mà giá trị trung bình của hội tụ tới hệ số tối ưu
(2.1.28)
Với và I là ma trận đồng nhất.
Hệ thức đệ quy (2.1.28) được thể hiện bởi hệ thống điều khiển vòng kín
như ở hình 2.1. Tốc độ hội tụ và tính ổn định của hệ thống này được điều
khiển bằng cách chọn kích cỡ bước nhảy . Để xác định trạng thái hội tụ
thuận tiện nhất là tách rời M phương trình sai phân đồng thời cho ở (2.1.28)
bằng cách sử dụng phương pháp biến đổi tuyến tính vector hệ số trung bình
. Khi chú ý tới ma trận tự tương quan , ta có biến đổi tương ứng
(2.1.29)
Với là ma trận chuẩn hóa của và A là đường chéo của ma trận với
các thành phần , bằng với giá trị riêng của
Thay (2.1.29) vào (2.1.28) ta có
(2.1.30)
Với và
25
Tính hội tụ và ổn định được xác định từ công thức đồng nhất
(2.1.31)
Ta có
(2.1.32)
Với C là hằng số tùy ý
là dãy bước nhảy đơn vị
Rõ ràng hội tụ tới 0 khi
Tương đương với
(2.1.33)
Tốc độ hội tụ cực đại khi .
Điều kiện ở (2.1.33) cho sự hội tụ của phương trình sai phân đồng nhất
đối với hệ số bộ lọc thứ k (mô hình thứ k của hệ thống kín) phải thỏa mãn cho
mọi k=0, 1, ..., M-1. Do vậy dải giá trị của đảm bảo sự hội tụ của vector hệ
số trong thuật toán LMS là
(2.1.34)
Với là giá trị riêng lớn nhất của
+
Filter
Hình 2.1 Hệ thống điều khiển kín
26
Do là một ma trận tự tương quan, giá trị riêng của nó không âm. Do
vậy cận trên của là
(2.1.35)
Với là nguồn tín hiệu đầu vào, nó dễ dàng được ước lượng từ tín
hiệu nhận được, do vậy cận trên của là .
LMS hội tụ nhanh khi nhỏ. Tuy nhiên, ta không thể có điều
kiện như mong muốn và vẫn thỏa mãn cận trên khi có một khoảng cách lớn
giữa giá trị riêng lớn nhất và nhỏ nhất của . Nói cách khác, nếu ta chọn
bằng , tốc độ hội tụ của LMS sẽ được xác định bởi sự suy giảm của
mô hình tương ứng tới giá trị nhỏ nhất . Ở mô hình này, thay
vào công thức (2.1.32) ta có
Tỉ số giới hạn tốc độ hội tụ, nếu nhỏ ( sự
hội tụ sẽ chậm và ngược lại khi .
Một đặc tính quan trọng nữa của LMS là nhiễu do việc sử dụng ước
lượng của vector gradient. Nhiễu này làm cho hệ số bộ lọc dao động ngẫu
nhiên quanh giá trị tối ưu và điều đó làm tăng giá trị cực tiểu của MSE ở đầu
ra của bộ lọc. Do đó tổng MSE là với là lỗi bình phương trung
bình dư.
Tổng MSE ở đầu ra bộ lọc có thể được viết như sau:
(2.1.36)
Với là hệ số tối ưu của bộ lọc được xác định bởi (2.1.8)
được gọi là đường cong tiếp thu
Khi thay như ở (6.2.29) và biến đổi trực giao tuyến tính ta có
(2.1.37)
27
Với được coi là lỗi trong hệ số bộ lọc thứ k (trong hệ
thống sắp xếp trực giao). Và lỗi bình phương trung bình dư là
(2.1.38)
Ta giả sử giá trị trung bình của hệ số bộ lọc hộ tụ tới giá trị tối ưu
của nó là . Và phần trong (2.1.23) là vector nhiễu trung
bình không. Hiệp phương sai của nó là
(2.1.39)
Ta giả sử không liên quan tới vector tín hiệu, dù giả thiết này
không chặt chẽ lắm nhưng nó rút ngắn dẫn dắt và cho kết quả đầy đủ. Và
(2.1.40)
Đối với vector hệ số , cộng thêm nhiễu, ta có
(2.1.41)
Với là vector nhiễu cộng thêm, nó liên quan tới vector nhiễu
qua biến đổi
(2.1.42)
Có thể thấy ma trận hiệp phương sai của vector nhiễu là
(2.1.43)
Do vậy các thành phần M của không liên quan tới nhau và mỗi
thành phần có một sai số
Do các thành phần M của không liên quan tới nhau nên ta có thể
tách riêng M công thức, mỗi công thức bậc nhất thể hiện một bộ lọc với đáp
ứng xung . Khi một bộ lọc bị ảnh hưởng bởi dãy nhiễu ,
28
nhiễu ở đầu ra của bộ lọc là
(2.1.44)
Ta giả thiết là nhiễu trắng, và (2.1.44) được rút gọn
(2.1.45)
Thay (2.1.45) vào (2.1.38) ta có
(2.1.46)
Khi coi với mọi k, ta được
(2.1.47)
Với là công suất tín hiệu vào.
Ta thấy lỗi bình phương trung bình dư thì tỉ lệ thuận với bước nhảy .
Do đó khi chọn phải đảm bảo hội tụ nhanh và lỗi bình phương trung bình
dư nhỏ. Trên thực tế, mong muốn có , ta có
Tương đương
(2.1.48)
29
Trong điều kiện ổn định phải thỏa mãn (2.1.48). Nói cách khác, lỗi
bình phương trung bình dư cũng làm giảm đáng kể chất lượng bộ lọc thích
nghi.
Những lí giải về lỗi bình phương trung bình dư ở trên là dựa vào giả thiết
giá trị trung bình của hệ số bộ lọc hội tụ tới giá trị tối ưu . Ở điều kiện đó,
kích thước bước nhảy phải thỏa mãn (2.1.48). Mặt khác, ta đã xác định để
vector hệ số trung bình hội tụ thì điều kiện cần là . Trong khi việc
chọn gần với cận trên có thể dẫn tới sự hội tụ ban đầu của thuật toán
gradient, khi mở rộng sẽ làm thuật toán gradient LMS ngẫu nhiên mất ổn
định.
Tính hội tụ ban đầu hay trạng thái nhất thời của LMS được nhiều nhà
khoa học nghiên cứu. Họ chỉ ra rằng kích thước bước nhảy tỉ lệ thuận với độ
dài bộ lọc thích nghi. Cận trên (2.1.48) là cần thiết để đảm bảo sự hội tụ ban
đầu của LMS gradient ngẫu nhiên. Thực tế thường chọn .
Trong hoạt động của LMS, việc chọn kích thước bước nhảy quan trọng
hơn. Ta có thể giảm lỗi bình phương trung bình dư bằng cách giảm tới điểm
mà tại đó tổng của lỗi bình phương trung bình đầu ra giảm. Điều đó xảy ra khi
các thành phần gradient được ước lượng,
sau phép nhân bởi thông số độ lớn bậc nhỏ (nhỏ hơn một nửa của bit nhỏ
nhất trong biểu diễn điểm cố định của hệ số bộ lọc). Do đó điều quan trọng là
kích thước bước nhảy phải đủ rộng để hệ số bộ lọc hội tụ tới . Nếu muốn
giảm kích thước bước nhảy một cách đáng kể thì điều cần thiết là phải tăng độ
chính xác của hệ số bộ lọc. Thông thường, 16 bits được dùng cho các hệ số bộ
lọc, với từ 8 đến 12 bits dùng cho xử lí số học trong lọc dữ liệu, từ 4 đến 8 bits
cho xử lí thích nghi. Các thành phần gradient ước lượng dùng số bit ít nhất.
Cuối cùng, ta cần chỉ ra rằng thuật toán LMS thích ứng với dòng tín hiệu
thống kê biến đổi chậm theo thời gian, như trong trường hợp cực tiểu MSE và
hệ số tối ưu biến đổi theo thời gian. Nói cách khác, là một hàm theo
thời gian. LMS chứa một loại lỗi khác, đó là lỗi trễ, là lỗi giá trị bình phương
trung bình giảm cùng với việc tăng kích thước bước nhảy. Tổng lỗi MSE giờ
là
30
(2.1.49)
Nếu ta vẽ và như một hàm của , ta có hình 2.2. Ta thấy khi tăng
thì tăng còn lại giảm, từ đó thấy giá trị mà tại đó tổng lỗi là nhỏ nhất.
Khi tín hiệu biến đổi nhanh theo thời gian lỗi trễ sẽ lấn át chất lượng bộ
lọc. như trong trường hợp , khi giá trị lớn nhất của được
dùng. Khi đó thuật toán LMS không còn thích hợp cho các ứng dụng và cần
tới một thuật toán phức tạp hơn, thuật toán bình phương tối thiểu đệ quy, để
có được sự hội tụ nhanh hơn và bám sát.
Hình 2.2 Lỗi trung bình bình phương dư và lỗi trễ
2.1.4. Thuật toán bình phương tối thiểu đệ quy
Lợi thế cơ bản của LMS là cách tính toán đơn giản. Tuy nhiên, nó lại hội
tụ chậm đặc biệt khi các giá trị riêng của ma trận tự tương quan có khoảng
cách lớn. Nhìn theo quan điểm khác, thuật toán LMS chỉ có một thông số để
điều khiển tốc độ hội tụ, đó là . Do bị hạn chế bởi cận trên để đảm bảo tính
ổn định, các giá trị riêng nhỏ hơn nên hội tụ rất chậm.
Để có được sự hội tụ nhanh hơn, cần có một thuật toán hoàn chỉnh hơn
cho nhiều thông số hơn. Thực tế, nếu ma trận tự tương quan có các giá trị
riêng không bằng nhau , ta phải dùng một thuật toán có
31
M thông số, mỗi thông số cho một giá trị riêng.
Để dẫn tới các thuật toán cho sự hội tụ nhanh hơn, ta cần chấp nhận thay
thế phép xấp xỉ thống kê dựa trên chuẩn MSE bằng chuẩn bình phương tối
thiểu. Ta sẽ quan tâm trực tiếp tới dữ liệu và nhận được ước lượng về
tương quan từ dữ liệu.
Điều thuận lợi để thể hiện thuật toán bình phương tối thiểu là dạng ma
trận, các thuật toán đệ quy trong miền thời gian. Cũng cần phải đưa chỉ số
thời gian và vector hệ số bộ lọc dãy lỗi. Vector hệ số bộ lọc ở miền thời gian
n là
(2.1.50)
Với chỉ số M là độ dài bộ lọc. Tương tự, vector tín hiệu đầu vào của bộ
lọc là
(2.1.51)
Giả sử với n<0. Điều này được gọi là lấy dữ liệu vào qua cửa sổ.
Bình phương tối thiểu đệ quy giờ tính toán như sau: Giả sử ta đã có
vector và ta muốn xác định vector hệ số sao
cho nó làm giảm tối thiểu độ lớn của lỗi bình phương.
(2.1.52)
Với lỗi được định nghĩa là khoảng cách giữa dãy mong muốn và
dãy ước lượng
32
(2.1.53)
Với là chỉ số và .
Chỉ số là để xử lí hầu hết các điểm dữ liệu mới và do đó cho phép hệ
số bộ lọc đáp ứng được các thông số đặc trưng biến đổi theo thời gian của dữ
liệu. điều đó được thực hiện bằng cách sử dụng hệ số trọng số lũy thừa với dữ
liệu chuyển qua. Tương tự, ta có thể sử dụng cửa sổ trượt độ dài hữu hạn với
trọng số đồng dạng trên toàn kích thước cửa sổ. Ta có
(2.1.54)
Với là kích thước cửa sổ trượt.
Việc tối thiểu hóa mà vẫn ổn định vector hệ số bộ lọc dẫn tới
thiết lập công thức tuyến tính
(2.1.55)
Với là ma trận tương quan tín hiệu
(2.1.56)
là vector tương quan chéo
(2.1.57)
Từ (2.1.55) có
(2.1.58)
Rõ ràng ma trận giống ma trận tự tương quan trong khi ma trận
giống vector tương quan chéo . Tuy nhiên cần nhấn mạnh rằng
không phải là ma trận Toeplizt như . Ta cũng cần chú ý tới giá trị nhỏ của n,
không tính được đảo của . Như trong trường hợp cộng thêm ma trận
33
vào , với là ma trận đồng nhất và là hằng số dương nhỏ.
Giả sử ta có (2.1.58) ở (n-l) (ví dụ ta có ) và ta muốn tính
, do đó trong thực tế không thể thiết lập các biểu thức tuyến tính M cho
mỗi thành phần tín hiệu mới. Thay vào đó ta có thể tính ma trận và vector một
cách đệ quy. Đầu tiên, tính
(2.1.59)
Ta gọi (2.1.59) là biểu thức cập nhật thời gian cho .
Do đảo của là cần thiết, ta dùng bổ đề đảo ma trận
(2.1.60)
Ta đặt để thuận tiện cho việc xác định vector khuếch
đại Kalman
(2.1.61)
Với vô hướng
(2.1.62)
Khi đó (2.1.60) trở thành
(2.1.63)
Nhân (2.1.63) với ta có
(2.1.64)
Do vậy vector khuếch đại Kalman cũng được định nghĩa như
.
Ta dùng ma trận đảo để lập biểu thức tính hệ số bộ lọc một cách đệ quy.
34
Do
(2.1.65)
Và
(2.1.66)
Ta có
(2.1.67)
Ta thấy rằng là đầu ra của bộ lọc thích nghi ở thời
điểm n dựa vào hệ số bộ lọc ở thời điểm (n-1). Do đó
(2.1.68)
Và
(2.1.69)
(2.1.70)
Tương đương
(2.1.71)
Giả sử ta có hệ số bộ lọc tối ưu , ma trận và vector
. Khi nhận được một tín hiệu mới ta lập vector bằng cách
tách phần từ và cộng thêm phần . Và hệ số bộ lọc
được tính một cách đệ quy như sau:
1. Tính đầu ra của bộ lọc:
35
(2.1.72)
2. Tính lỗi
(2.1.73)
3. Tính vector Kalman
(2.1.74)
4. Cập nhật ma trận đảo của ma trận tương quan
(2.1.75)
5. Cập nhật vector hệ số của bộ lọc
(2.1.76)
Thuật toán đệ quy được thiết lập bởi (2.1.72) qua (2.1.76) gọi là thuật
toán bình phương tối thiểu đệ quy (RLS). Ban đầu đặt và
, là số dương nhỏ.
Phần lỗi bình phương trung bình còn dư do việc tối ưu hóa là
(2.1.77)
Từ (2.1.76) ta thấy các hệ số bộ lọc thay đổi theo thời gian một lượng
bằng . Do là một vector thứ nguyên, mỗi hệ số bộ lọc sẽ
được diều khiển bởi 1 trong những thành phần của . Vì vậy, ta có được
sự hội tụ nhanh. Ngược lại, biểu thức thay đổi theo thời gian của các hệ số bộ
lọc sử dụng trong thuật toán LMS
(2.1.78)
Tìm thừa số LDU và thuật toán căn bậc hai. Thuật toán LMS chỉ có
một thông số để điều khiển tốc độ hội tụ. Thuật toán RLS ở trên rất dễ dàng
chấp nhận làm tròn nhiễu trong hoạt động của thuật toán với phép toán độ
36
chính xác giới hạn. Vấn đề chính của việc làm tròn xảy ra khi cập nhật .
Để khắc phục vấn đề này, ta có thể khai triển hoặc ma trận tương quan
hoặc nghịch đảo của nó .
Ta hãy xét khai triển LDU của .
(2.1.79)
Với là ma trận (phần dưới) dạng tam giác với các phần tử ,
là đường chéo ma trận và các phần tử , là ma trận (phần trên)
tam giác. Các phần tử trên đường chéo của bằng 1. Để thay cho việc
tính một cách đệ quy, ta có thể xác định công thức cập nhật và
một cách trực tiếp.
Từ (2.1.75) và (2.1.79) ta có
(2.1.80)
Với
(2.1.81)
Phần bên trong ngoặc của (2.1.80) là ma trận Hermitian và có thể được
viết dưới dạng
(2.1.82)
Sau đó thay (2.1.82) vào (2.1.80)
(2.1.83)
Và
37
(2.1.84)
Kết quả thuật toán nhận được từ (2.1.84) phụ thuộc trực tiếp vào vector
dữ liệu và không phụ thuộc vào bình phương dữ liệu. Vì thế thuật toán
bình phương bị loại bỏ và ảnh hưởng của lỗi làm tròn được giảm thiểu.
Thuật toán RLS nhận được từ việc khai triển hoặc được
gọi là thuật toán căn bậc hai RLS.
Thuật toán RLS nhanh
Thuật toán RLS dạng trực tiếp và dạng căn bậc hai có cách tính toán
phức tạp tỉ lệ với . Mặt khác, thuật toán giàn RLS (ở 2.3) lại tỉ lệ với M.
các thuật toán giàn loại bỏ việc nhân ma trận xuất hiện khi tính .
Bằng cách sử dụng các công thức cho giàn LMS ta có thể nhận được các
biểu thức theo thời gian của vector khuếch đại Kalman mà hoàn toàn không
dùng tới việc nhân ma trận. Các thuật toán phức tạp tỉ lệ với M được gọi là
thuật toán RLS nhanh cho bộ lọc FIR dạng trực tiếp.
2.1.5. Các thuộc tính của thuật toán RLS dạng trực tiếp
Thuật toán RLS hơn LMS ở chỗ là có sự hội tụ nhanh. Trạng thái đặc
trưng này được thể hiện ở 2.3 (diễn tả tốc độ hội tụ của 2 thuật toán đối với
kênh cân bằng FIR thích nghi có độ dài M=11. Ma trận tự tương quan
dành cho tín hiệu nhận có tỉ lệ giá trị riêng là . Tất cả các hệ
số bộ cân bằng ban đầu được đặt bằng 0. Kích thước bước nhảy thuật toán
LMS , là giá trị tối ưu đảm bảo cho cả tốc độ hội tụ cả lỗi bình
phương trung bình dư.
38
Sự hội tụ nhanh hơn của RLS thể hiện rất rõ. Nó hội tụ trong ít hơn 70
(70 mẫu tín hiệu) trong khi thuật toán LMS không hội tụ trong hơn 600
lần lặp. tốc độ hội tụ này của RLS vô cùng quan trọng trong các ứng dụng khi
mà tín hiệu thay đổi nhanh theo thời gian.
Không kể tới chất lượng tự hiệu chỉnh cao, thuật toán RLS của bộ lọc
thích ứng FIR có 2 nhược điểm lớn. Một là cách tính toán phức tạp. Thuật
toán căn bậc hai tỉ lệ với , RLS nhanh tỉ lệ với M nhưng hệ số tỉ lệ bằng 4
đến 5 lần so với LMS. Nhược điểm thứ hai là đặc tính nhạy của nó khi làm
tròn lỗi tích lũy khi tính toán đệ quy. Trong một vài trường hợp, lỗi làm tròn
khiến cho thuật toán không ổn định.
Thuộc tính của RLS được nghiên cứu bởi nhiều nhà nghiên cứu. Bảng
2.1 đưa ra kết quả mô phỏng lỗi bình phương trong trạng thái ổn định của
thuật toán căn bậc hai RLS, RLS nhanh và LMS với các độ dài từ khác nhau.
Việc mô phỏng được thực hiện với bộ cân bằng thích ứng có độ dài M=11.
Với chỉ số trọng số lũy thừa đối với RLS là và kích thước bước
nhảy đối với LMS. Nhiễu cộng thêm là 0.001, đầu ra MSE với tính
toán chính xác là .
Ta có thể chỉ ra rằng thuật toán RLS dạng trực tiếp trở nên mất ổn định
Thuật toán gradient
RLS Thuật
toán
w=0.999
Số lần lặp
Lỗi
Hình 2.3 Đồ thị cho thuậ toán RLS và LMS
39
và do đó không thể làm việc với các phép toán 16 bits. Đối với thuật toán này,
cần 24 bits. Mặt khác, thuật toán căn bậc hai làm việc dưới 9 bits, RLS nhanh
làm việc khá tốt dưới 11 bits trong thời gian ngắn, với 500 lần lặp, nếu số lần
lặp lớn hơn thuât toán sẽ mất ổn định. Điều đó dẫn gây tích lũy lỗi làm tròn.
Số bit
Thuật toán
RLS
Square root
Fast RLS
LMS
16
13
11
10
9
8
2.17
2.33
6.14
17.6
75.3
2.17
2.21
3.34
2.30
2.30
19.0
77.2
311.0
1170.0
Bảng 2.1 Độ chính xác của các thuật toán bộ lọc thíc nghi FIR
2.2. Bộ lọc thích nghi dạng thang lưới
Bộ lọc FIR có thể được thực hiện với cấu trúc giàn với thông số giàn
được gọi là hệ số phản xạ, được liên kết với các hệ số bộ lọc ở dạng trực tiếp.
Có phương pháp để chuyển đổi hệ số bộ lọc FIR thành hệ số phản xạ.
Trong phần này ta nghiên cứu các thuật toán của bộ lọc thích nghi với
cấu trúc giàn hoặc giàn hình thang. Các thuật toán này dựa trên phương pháp
bình phương tối thiểu và có nhiều thuộc tính mong muốn, đưa ra cách tính
toán hiệu quả và lỗi sai số làm tròn được kiểm soát tốt.
2.2.1. Thuật toán thang lưới bình phương tối thiểu hồi qui
Các thuật toán bình phương tối thiểu đệ quy dành cho bộ lọc FIR dạng
trực tiếp mô tả trong phần 2.1.4 chỉ đệ quy trong miền thời gian. Độ dài của
bộ lọc được cố định. Sự thay đổi độ dài bộ lọc sẽ tạo ra các hệ số bộ lọc mới
hoàn toàn khác với các hệ số trước đó.
40
Ngược lại, bộ lọc giàn là hồi quy bậc, vì thế độ dài một số bộ lọc có thể
tăng hoặc giảm mà không ảnh hưởng tới hệ số phản xạ của các bộ lọc còn lại.
Giả sử ta nhận được tín hiệu và chú ý tới việc
ước lượng . Gọi là lỗi ước lượng trước đối với việc ước lượng
bậc thứ m
(2.2.1)
Với vector chứa các hệ số ước lượng trước
(2.2.2)
Và vector dữ liệu là
(2.2.3)
Các hệ số ước lượng được chọn để tối thiểu hóa lỗi bình phương
trọng số thời gian trung bình.
(2.2.4)
Việc tối thiểu đồng thời chú ý tới dẫn tới biểu thức tuyến
tính
(2.2.5)
Với là ma trận tương quan tín hiệu
Và được định nghĩa là
(2.2.6)
41
Từ (2.2.5) ta có
(2.2.7)
Giá trị nhỏ nhất của được coi như
(2.2.8)
Với
(2.2.9)
(2.2.5) và (2.2.8) có thể ở dạng ma trận
(2.2.10)
Khi là vector rỗng thứ nguyên m. Cần chú ý rằng
(2.2.11)
Ta cũng tối thiểu hóa lỗi bình phương trọng số thời gian trung bình phía sau
(2.2.12)
Với lỗi phía sau là
(2.2.13)
Và là vector hệ số ước lượng
lùi. Việc tối thiểu hóa dẫn tới biểu thức
42
(2.2.14)
(2.2.15)
Với
(2.2.16)
Giá trị nhỏ nhất của là
(2.2.17)
Với là đại lượng vô hướng.
(2.2.18)
Từ (2.2.14) và (2.2.17) có
(2.2.19)
Ma trận tự tương quan cũng được ước lượng
(2.2.20)
Như vậy ta đã có công thức ước lượng bình phương tối thiểu tiến và lùi
của bậc m.
Tiếp theo ta sẽ suy ra các biểu thức bậc khác. Ta dùng hai ma trận đảo
đồng nhất của ma trận dạng
(2.2.21)
43
(2.2.22)
Và
(2.2.23)
Với
(2.2.24)
Hồi quy nâng bậc
Dùng biểu thức (2.1.22) để tìm ma trận đảo của . Đầu tiên, ta có
(2.2.25)
Và
(2.2.26)
Do vậy
(2.2.27)
Tương đương với
Thay n bằng (n-1) vào (2.2.27) và nhân sau kết quả với ta có
44
(2.2.28)
Với là đại lượng vô hướng
(2.2.29)
(2.1.28) là sự đệ quy dạng Levinson cho các hệ số bộ lọc ước lượng.
Tương tự để nhận được biểu thức cập nhật cho ta dùng ma trận
đảo của . Trong trường hợp này ta có
(2.2.30)
Và
(2.2.31)
Do đó
Hoặc tương đương
(2.2.32)
Nếu nhân sau (2.2.32) bởi ta có
45
(2.2.33)
Khi
(2.2.34)
Các biểu thức cập nhật cho và cũng có thể tìm được. Từ
định nghĩa của ở (2.2.8) ta có
(2.2.35)
Thay ở (2.1.8) vào (2.2.35) ta có
(2.2.36)
Tương tự ta có
(2.2.37)
Bộ lọc giàn đặc trưng bởi cặp biểu thức lỗi tiến và lùi và
. Ta có
(2.2.38)
46
Thay từ (2.2.28) vào (2.2.38) nhận được
(2.2.39)
Ta định nghĩa
(2.2.40)
Vì thế (2.2.39) có thể viết là
(2.2.41)
Tương tự
(2.2.42)
Thay từ (2.2.33)
(2.2.43)
Tương đương
(2.2.44)
Hai biểu thức đệ quy (2.2.41) và (2.2.44) xác định bộ lọc giàn ở hình 2.3.
47
Để thuận tiện ta xác định các hệ số phản xạ cho giàn
(2.2.45)
Các điều kiện ban đầu cho việc thay đổi bậc là
(2.2.46)
Và (2.2.46) cũng là biểu thức theo thời gian của và .
Hình 2.4 Bộ lọc lưới bình phương tối thiểu
Tầng
1
Tầng
2
Tầng
3
Tầng
M-1
.
.
+
+
48
Hồi quy điều chỉnh theo thời gian
Ta cần xác định biểu thức theo thời gian , nó là cần thiết để bộ lọc
giàn trở nên thích nghi và đưa ra các biểu thức theo thời gian cho các hệ số bộ
lọc. Ta bắt đầu với
(2.2.47)
Biểu thức theo thời gian cho là
(2.2.48)
Biểu thức theo thời gian cho các hệ số ước lượng được xác định như sau.
Từ (2.2.6), (2.2.7) và (2.2.8) ta có
(2.2.49)
Với là vector khuếch đại Kalman ở bước lặp thứ n-1. Nhưng
từ (2.2.38) ta có
(2.2.50)
Bên cạnh đó, dùng (2.2.15), (2.2.16) và (2.2.63) ta được biểu thức theo
thời gian cho các hệ số ước lượng lùi ở dạng
(2.2.51)
Từ (2.2.48) và (2.2.50) ta có biểu thức theo thời gian của
49
Nhưng
(2.2.53)
Và
(2.2.54)
Với được định nghĩa ở (2.1.62).
(2.2.55)
Thay (2.2.53), (2.2.54) và (2.2.55) vào (2.2.52) ta có
(2.2.56)
Ta có một biến mới
(2.2.57)
có giá trị thực và
(2.2.56) giờ được viết
50
(2.2.58)
Điều chỉnh bậc cho
Dù có thể được tính trực tiếp với mỗi giá trị của m và n, nhưng
tốt hơn hết là dùng biểu thức theo bậc. Đầu tiên, từ định nghĩa ở
(2.1.61) ta thấy rằng
(2.2.59)
Để có được biểu thức theo thời gian cho , cần có biểu thức theo
bậc của vector Kalman . Nhưng có thể được viết
(2.2.60)
Trong đó
(2.2.61)
Do đó biểu thức theo bậc đối với ở (2.2.60) được viết
(2.2.62)
Từ (2.2.62) và (2.1.59) ta có
51
(2.2.63)
Như vậy ta đã nhận được các biểu thức theo bậc và theo thời gian của
giàn bình phương tối thiểu như ở hình 2.3. (2.2.41) và (2.2.44) là các biểu
thức cơ bản cho lỗi tiến và lùi, thường được gọi là các phần dư. (2.2.36) và
(2.2.37) là lỗi bình phương tối thiểu, (2.2.58) là biểu thức theo thời gian cho
, (2.2.63) là biểu thức theo bậc cho thông số Ta có
(2.2.64)
Ước lượng quá trình kết hợp.
Ta cần tìm ước lượng bình phương tối thiểu cho tín hiệu d(n) từ giàn.
Giả sử bộ lọc có m+1 hệ số và các hệ số này được xác định để tối thiểu hóa
lỗi bình phương trọng số trung bình
(2.2.65)
Khi
(2.2.66)
Ước lượng tuyến tính
(2.2.67)
52
Ước lượng này nhận được từ giàn bằng cách dùng phần dư , và
được gọi là ước lượng quá trình kết hợp. Ở (2.1.4) ta đã có các hệ số của bộ
lọc thích nghi được tối thiểu hóa bởi biểu thức
(2.2.68)
Ta có thỏa mãn biểu thức theo thời gian ở (2.1.76)
Từ (2.2.68) và (2.2.27) ta có
(2.2.69)
Đại lượng vô hướng
(2.2.70)
(2.2.69) có thể viết
(2.2.71)
thỏa mãn biểu thức theo thời gian, biểu thức này có được từ biểu
thức theo thời gian của và ở (2.2.51) và (2.2. 66).
(2.2.72)
Nhưng
(2.2.73)
Và
53
(2.2.74)
(2.2.75)
Thay kết quả ở (2.2.73) qua (2.2.75) vào (2.2.72) ta có
(2.2.76)
Như vậy ta đã có biểu thức theo bậc cho . Với
, biểu thức theo bậc cho là
(2.2.77)
Ước lượng đầu ra d(n) của giàn bình phương tối thiểu là
(2.2.78)
Nhưng không được tính toán cụ thể. Bằng cách dùng
như ở (2.2.71) ta có
(2.2.79)
Nói cách khác, ước lượng đầu ra là tổng trọng số tuyến tính của phần dư
tiến .
+
+ + + + +
+ + +
54
Hình 2.5 Bộ lọc thang lưới thích nghi RLS
Dạng ưu tiên của thuật toán giàn hình thang RLS được phân biệt với
dạng khác của thuật toán, gọi là dạng lùi. Ở dạng lùi này, được
thay bởi để ước lượng d(n). Trong bộ cân bằng kênh hoặc khử phản
hồi, dạng lùi không sử dụng được vì không thể tính toán để tính d(n).
Thuật toán thang lưới RLS cải tiến.
Có thể xây dựng các biểu thức khác mà không ảnh hưởng tới tính tối ưu
của thuật toán. Tuy nhiên, một vài biến thể của thuật toán vượt hẳn về số
lượng khi phép toán điểm ấn định được dùng trong thuật toán.
Đầu tiên, ta có mối liên hệ giữa phần lỗi dư tiến và lùi
Lỗi tiến
(2.2.80)
Lỗi lùi
55
(2.2.81)
hệ thức giữa (2.2.80) và (2.2.81) là
(2.2.82)
Thứ hai, ta tìm được các biểu thức theo thời gian cho lỗi bình phương tối
thiểu tiến và lùi. Từ (2.2.8) và (2.2.50) ta có
(2.2.83)
Tương tự từ (2.2.17) và (2.2.51) ta có
(2.2.84)
Thứ ba, ta có biểu thức theo thời gian cho vector hệ số khuếch đại Kalman,
vector này không được dùng trong thuật toán giàn mà sử dụng trong các thuật
toán nhanh. Để có được biểu thức này, ta cũng dùng các biểu thức theo thời gian
của hệ số ước lượng tiến và lùi cho bởi (2.2.50) và (2.2.51). Ta có
(2.2.85)
Khi đặt chứa thành phần đầu tiên của và chứa
các thành phần cuối cùng. Từ (2.2.60) ta có biểu thức theo bậc cho là
56
(2.2.86)
Cho (2.2.85) và (2.2.86) bằng nhau ta có
(2.2.87)
Và do đó
(2.2.88)
Thay (2.2.51) vào (2.2.88) ta có biểu thức theo thời gian cho vector hệ số
khuếch đại Kalman
(2.2.89)
Đó cũng là biểu thức theo thời gian cho đại lượng vô hướng . Từ
(2.2.63) ta có
(2.2.90)
Từ (2.2.85) ta có
(2.2.91)
Cho (2.2.90) và (2.2.91) bằng nhau ta có biểu thức theo thời gian cho
là
Cuối cùng, ta cần phân biệt giữa những phương pháp khác nhau để cập
nhật các hệ số phản xạ cho bộ lọc giàn và hình thang là phương pháp trực tiếp
và gián tiếp.
Trong phương pháp gián tiếp
57
(2.2.93)
(2.2.94)
(2.2.95)
Với là theo như (2.2.58), theo như (2.2.76), và
theo như (2.2.83) và (2.2.84). Thay từ (2.2.58) vào (2.2.93)
và dùng (2.2.84), ta có
(2.2.96)
Đây là công thức để cập nhật trực tiếp hệ số phản xạ trong giàn. Tương
tự, thay (2.2.58) vào (2.2 94) và dùng (2.2.83) ta có
(2.2.97)
Hệ số khuếch đại thang cũng có thể được cập nhật một cách trực tiếp
(2.2.98)
Một đặc tính của thuật toán thang lưới là phần dư tiến và lùi sẽ quay trở
lại cập nhật các hệ số phản xạ trong tầng giàn và phản hồi lại để cập
nhật . Vì vậy, thuật toán giàn hình thang được gọi là dạng phản hồi lỗi.
Có thể nhận được dạng tương tự dành cho thuật toán giàn hình thang RLS ưu
58
tiên.
Thuật toán RLS nhanh.
Có hai phiên bản của RLS nhanh. Thực tế, ta cố định kích thước của giàn
và kết hợp ước lượng tiến và lùi ở tầng thứ M-1. Vấn đề còn lại là xác định
biểu thức theo thời gian cho vector hệ số khuếch đại Kalman như ở (2.2.89).
Có hai điểm khác biệt cơ bản: thứ nhất, Feast dùng vector hệ số khuếch
đại thay thế để thay cho vector hệ số khuếch đại Kalman. Thứ 2, RLS nhanh
ước lượng lỗi qua bộ lọc FIR bằng cách dùng vector hệ số
, trong khi Feast tính qua cách tính toán vô hướng và chú thích là
phần tử cuối cùng của vector hệ số khuếch đại thay thế, , bằng
.
Chất lượng của RLS nhanh phụ thuộc nhiều vào việc khởi tạo ban đầu.
Thuật toán lưới chuẩn hay căn bậc hai.
Một dạng khác của thật toán giàn LS được gọi là căn bậc hai hay thuật
toán giàn chuẩn hóa. Để có được thuật toán này, đầu tiên ta định nghĩa góc và
độ lớn của lỗi LS thông thường
(2.2.99)
(2.2.100)
Kĩ thuật chuẩn hóa góc xuất phát từ thực tế là là cosine của góc
giữa khoảng của vector dữ liệu tại (n-l) và n. Thứ hai, ta xác định hệ số phản
xạ chuẩn hóa
59
(2.2.101)
Dễ dàng để chứng minh rằng cả 3 đại lượng đều có giá trị biên độ nhỏ
hơn 1. Do thộc tính này thuật toán giàn LS căn bậc 2 chuẩn hóa là tiện ích đối
với việc thực hiện các phép toán điểm ấn định. Thay thế (2.2.99), (2.2.100) và
(2.2.101) vào (2.2.58) ta có
(2.2.102)
Tương đương
(2.2.103)
Từ biểu thức theo thời gian của và ở (2.2.83) và (2.2.84)
có thể chỉ ra rằng
(2.2.104)
Và
(2.2.105)
Sau đó thay (2.2.104), (2.2.105) vào (2.2.103) ta có biểu thức theo thời
gian cho .
60
(2.2.106)
Để có biểu thức theo bậc cho lỗi chuẩn hóa trước và sau, trước tiên ta
viết biểu thức theo bậc cho lỗi tiến
(2.2.107)
Và
(2.2.108)
Sau đó viết (2.2.107) trong điều kiện của lỗi chuẩn hóa ta có
(2.2.109)
Cuối cùng ta có
(2.2.110)
Từ biểu thức theo bậc cho ở (2.2.36) có thể chỉ ra rằng
61
(2.2.111)
Từ (2.2.63) ta có
(2.2.112)
Sau đó bằng cách thay (2.2.111) và (2.2.112) vào (2.2.110) ta có kết quả
(2.2.113)
Tương tự ta có biểu thức theo bậc cho lỗi lùi chuẩn hóa là
(2.2.114)
Biểu thức (2.2.106), (2.2.113) và (2.2.114) xây dựng nên thuật toán giàn
LS chuẩn hóa hay căn bậc 2. Chú ý rằng thuật toán này chỉ chứa 3 biến và chỉ
được thực hiện với 3 biểu thức. Do vậy nó có dạng chắc chắn hơn so với các
dạng khác của thuật toán giàn LS. Tuy nhiên, nó yêu cầu các phép tính căn
bậc 2 các phép tính này mất nhiều thời gian. Vấn đề này thì được giải quyết
bằng cách sử dụng bộ xử lí CORDIC, có thể tính căn bậc 2 trong N xung, với
N là số bits độ dài từ được tính.
2.2.2. Thuật toán thang lưới Gradient
Các thuật toán giàn hình thang được mô tả ở các phần trước thì hoàn
phức tạp hơn so với thuật toán LMS nhưng lại có chất lượng tốt hơn. Khi cố
gắng đơn giản cách tính toán của dạng này, mà vẫn giữ được tính tối ưu của
nó, ta chú ý tới cấu trúc bộ lọc giàn hình thang với số tham số bộ lọc được
giảm thiểu. Trong thực tế, cấu trúc bộ lọc thang lưới được thể hiện như ở hình
2.6. Mỗi tầng của giàn đặc trưng bởi hệ thức giữa đầu vào và đầu ra
62
(2.2.115)
Với là hệ số phản xạ của tầng thứ m, và là phần dư
tiến và lùi.
Hình 2.6 Bộ lọc thang lưới gradient
Dạng bộ lọc này thì giống với dạng được suy ra từ thuật toán Levinson-
Durbin, trừ việc được phép thay đổi theo thời gian. So sánh với thuật
toán giàn RLS, thuật toán này hạn chế hơn trong việc ước lượng hệ số tiến và
+
+
+
+ + + + +
+ + +
Stage
1
Stage
1
Stage
M-1
-
-
-
- -
+ + +
..
..
..
..
63
lùi.
Tham số có thể được tối ưu theo chuẩn MSE hoặc theo phương
pháp bình phương tối thiểu. Giả sử ta có chuẩn MSE và chọn các tham số để
tối thiểu hóa tổng lỗi bình phương trung bình tiến và lùi.
Khi ta giảm sự phụ thuộc vào thời gian của
(2.2.116)
Chú ý rằng có dạng hệ số tương quan chuẩn hóa.
Khi đặc tính thống kê của tín hiệu chưa được biết đến, ta chấp nhận
chuẩn bình phương tối thiểu để xác định . Chỉ số đặc trưng được tối
thiểu hóa
(2.2.117)
Ta có
(2.2.118)
Trong (2.2.118), tử và mẫu có thể được viết theo thời gian như sau
(2.2.119)
Và
(2.2.120)
64
Biểu thức theo thời gian của
(2.2.121)
Ta định dạng đầu ra của cấu trúc như ở hình 6.4 như một tổ hợp tuyến
tính của các phần dư tiến
(2.2.122)
Với là trọng số của phần thang. Giá trị tối ưu của trọng số có thể
có được bằng cách tối thiểu MSE giữa tín hiệu mong muốn và ước
lượng của nó. Gọi là chênh lệch giữa và ước lượng của nó ở
tầng thứ m. Và với ta có
(2.2.123)
Lỗi trong (2.2.123) có thể viết ở dạng ma trận
(2.2.124)
Với là vector trọng số hình thang và là vector dư
tiến.
Nếu ta giả thiết việc thống kê tín hiệu là không đổi, ta có thể giảm sự
phụ thuộc vào thời gian của vector hệ số và chọn thỏa mãn điều kiện
trực giao
(2.2.125)
Thay (2.2.124) vào (2.2.125) và dùng phép toán kì vọng ta có
65
Tương đương
(2.2.126)
Một đặc tính quan trọng của phần dư tiến trong bộ lọc giàn được mô tả
bởi (2.2.115)
(2.2.127)
Do đó ma trận là ma trận chéo và do vậy hệ số khuếch
đại thang tối ưu là
(2.2.128)
Vấn đề còn lại là điều chỉnh hệ số khuếch đại thang cho thích nghi.
Do tối thiểu hóa MSE và , lỗi sẽ trực giao với phần dư trước
trong . Điều này đưa ra thuật toán gradient ở dạng
(2.2.129)
Với là ước của và có thể tính toán một cách đệ quy.
(2.2.130)
Tuy nhiên, việc tính toán như ở (2.2.130) có thể không thực hiện được.
Do đó phần dư trước và sau có giá trị bình phương trung bình ban đầu, và
biến được ước lượng bằng . Và (2.2.129) có thể được viết
(2.2.131)
Thuật toán ở (2.2.131) dùng để cập nhật hệ số khuếch đại thang là thuật
toán gradient, bộ lọc được gọi là bộ lọc giàn hình thang gradient. Thành phần
đóng vai trò như kích thước bước nhảy.
66
2.2.3. Thuộc tính của thuật toán thang lưới
Tốc độ hội tụ
Thuật toán giàn hình thang về cơ bản có tốc độ hội tụ như cấu trúc bội
lọc FIR dạng trực tiếp. Tuy thuật toán giàn gradient còn một vài đặc tính của
giàn RLS, nhưng lại không tối ưu trong hướng bình phương tối thiểu, do đó
nó hội tụ chậm.
Yêu cầu tính toán
Thuật toán giàn RLS mô tả trong phần trên có cách tính toán phức tạp tỉ
lệ thuận với M. Trái lại, thuật toán RLS căn bậc hai tỉ lệ với . Mặt khác,
thuật toán nhanh dạng trực tiếp, thuật toán bắt nguồn từ thuật toán giàn RLS,
tỉ lệ với M.
Thuộc tính số
Thuật toán giàn RLS và gradient là lớn về số lượng. Đầu tiên, thuật toán
giàn là ổn định về số. Ổn định về số có nghĩa là lỗi ước lượng ở đầu ra có
được nhờ tính toán thì bị chặn khi tín hiệu lỗi bị chặn được đưa vào đầu vào.
Thứ 2, độ chính xác số của phần tối ưu cũng được so sánh trong mối liên hệ
với thuật toán FIR dạng trực tiếp và thuật toán LMS.
Trong thuật toán giàn gradient, các hệ số phản xạ và hệ số khuếch đại
thang cũng được cập nhật trực tiếp.
Sự hoạt động
Cấu trúc bộ lọc giàn có tính kết cấu cao và cho phép tính toán nối truyền
liên tiếp. Thực tế, thuật toán RLS và giàn gradient thích ứng với sự hoạt động
trong VLSI.
Tổng kết
Trên đây chúng ta đã được thấy các thuật toán thích nghi cho bộ lọc FIR
dạng trực tiếp và cấu trúc lưới. Các thuật toán cho bộ lọc FIR dạng trực tiếp
là thuật toán LMS đơn giản, thuật toán bình phương tối thiểu đệ quy thời
gian(RLS).
Trong đó thuật toán LMS là đơn giản nhất. Nó được sử dụng trong nhiều
ứng dụng yêu cầu tốc độ hội tụ chậm. Thuật toán RLS được dùng trong các
67
ứng dụng yêu cầu tốc độ hội tụ cao hơn.
Các thuật toán dành cho bộ lọc có cấu trúc thang lưới là: thuật toán thang
lưới RLS tối ưu, thuật toán thang lưới gradient.
68
Chương 3.
MÔ PHỎNG ỨNG DỤNG CỦA BỘ LỌC THÍCH NGHI
Bộ lọc thích nghi được sử dụng rộng rãi trong các hệ thống liên lạc, điều
khiển. Một số ứng dụng được mô tả trên lí thuyết, một số khác được đưa vào
hệ thống anten thích nghi. Trong hệ thống đó, bộ lọc thích nghi được dùng để
chỉnh búp sóng. Bộ lọc thích nghi cũng được đưa vào bộ tiếp nhận thông tin
số để khử nhiễu liên kí tự và để nhận dạng kênh, đưa vào các kĩ thuật triệt
nhiễu để ước lượng và hạn chế thanh phần nhiễu trong tín hiệu.
Trong chương 3, ta đưa mô phỏng về ứng dụng của bộ lọc thích nghi. Bộ
lọc thích nghi với thuật toán LMS dùng trong ứng dụng này để ước lượng
nhiễu, đồng thời cũng đưa ra hệ số bộ lọc. Hệ số bộ lọc thay đổi theo thời gian
và lỗi ước lượng cũng giảm theo sự thay đổi đó.
3.1 Sơ đồ mô phỏng
Hình 3.1 Sơ đồ mô phỏng
Sơ đồ dùng các khối sau:
- Sine wave: cung cấp tín hiệu hình sin ban đầu. tín hiệu ở đầu ra của
khối này được đưa trực tiếp vào time scope.
- Random source: tạo nhiễu là 1 tín hiệu bất kì.
69
- Digital filter design: bộ lọc thông thấp giới hạn tần số của nhiễu.
- Bộ lọc thích nghi sử dụng thuật toán LMS với các thông số bộ lọc
được chọn như sau:
+ Filter length = 32
+ Algorithm = Normalized LMS
+ Specify step size via = Dialog
+ Step size (mu) = 0.1: xác định chi tiết bước nhảy của bộ lọc
+ Leakage factor (0 to 1) = 1.0
+ Initial value of filter weights = 0
+ Bỏ chọn Adapt port
+ Reset port = None
+ Chọn Output filter weights check box.
Dựa vào các thông số này, bộ lọc tính toán các trọng số bằng cách sử dụng
thuật toán LMS. Do ta chọn Leakage factor (0 to 1) = 1.0, giá trị của hệ số bộ
lọc phụ thuộc vào các điiều kiện ban đầu của bộ lọc và các giá trị đầu vào trước
đó. Giá trị ban đầu của hệ số bộ lọc bằng 0 và sẽ tăng theo thời gian.
- Time scope: dùng đo và thể hiện dạng tín hiệu tạo ra trong quá trình mô
phỏng.
- Vector scope: thể hiện các giá trị của hệ số bộ lọc.
3.2 Hoạt động
- Nối đầu ra của Random source với đầu vào của bộ lọc LMS.
- Nối đầu ra của Digital filter design với đầu desired của bộ lọc. Đây là
tín hiệu ta muốn bộ lọc sao chép lại.
- Nối đầu ra của ra của bộ lọc với port âm của bộ cộng thứ 2.
- Nối đầu ra của bộ cộng thứ nhất với port dương của bộ cộng thứ 2.
Đầu ra của bộ cộng thứ nhất là tổng của tín hiệu ban đầu và nhiễu tần số
thấp, gọi là . Đầu ra của bộ lọc là dự đoán tốt nhất của nhiễu tần
thấp, gọi là . Khi ta trừ 2 tín hiệu này, ta sẽ có gần đúng của tín hiệu ban
đầu.
70
Với là tín hiệu vào ban đầu.
là tín hiệu gần đúng của .
y là nhiễu được tạo ra từ Random source và Digital filter design.
là gần đúng của y.
Do bộ lọc chỉ có thể tính gần đúng với y nên vẫn có sự sai khác giữa
tín hiệu ban đầu và .
- Nối đầu ra của bộ cộng thứ 2 với port thứ 3 của time scope.
- Nối đầu ra erros của bộ lọc với port thứ 4 của time scope.
- Nối đầu ra wts của bộ lọc vơi vector scope.
Hình 3.1 Cửa sổ time scope
Kết quả mô phỏng được thể hiện trên cửa sổ của time scope. Ta sẽ thấy
theo thời gian lỗi sẽ giảm và tín hiệu nhận được sẽ gần giống với tín hiệu ban
đầu.
71
KẾT LUẬN
Trên đây em đã trình bày toàn bộ phần nội dung nghiên cứu vê bộ lọc
thích nghi. Để hiểu về hoạt động của bộ lọc, em đã thực hiện tìm hiểu cụ thể
về các thuật toán dùng trong đó. Các thuật toán đó được bao gồm các thuật
toán cho bộ lọc FIR dạng trực tiếp và cho cấu trúc lưới. Các thuật toán cho bộ
lọc FIR dạng trực tiếp là thuật toán LMS đơn giản, thuật toán bình phương tối
thiểu đệ quy thời gian(RLS).
Trong đó thuật toán LMS là đơn giản nhất. Nó được sử dụng trong nhiều
ứng dụng yêu cầu tốc độ hội tụ chậm. Thuật toán RLS được dùng trong các
ứng dụng yêu cầu tốc độ hội tụ cao hơn.Các thuật toán dành cho bộ lọc có cấu
trúc thang lưới là: thuật toán thang lưới RLS tối ưu, thuật toán thang lưới
gradient. Các thuật toán này giúp bộ lọc thích nghi được với sự thay đổi của
tín hiệu đầu vào và tốc độ hội tụ thích hợp. Và từ phần mô phỏng trên, ta
cũng thấy rõ hơn về hoạt động của bộ lọc với một thuật toán cụ thể, thuật toán
LMS.
Với sự phát triển mạnh mẽ của khoa học kỹ thuật, các ngôn ngữ lập trình
mạnh có kèm theo hộp công cụ xử lý số tín hiệu như ngôn ngữ MATLAB thì
việc phân tích và thiết kế các bộ lọc số ngày càng trở nên đơn giản (kể cả bộ
lọc FIR và bộ lọc IIR) và độ chính xác của phép toán sẽ tăng lên.
Do điều kiện thời gian có hạn cộng với khả năng còn hạn chế nên chắc
không tránh khỏi thiếu sót. Vậy rất mong được quý thầy cô chỉ bảo để quyển
đồ án này được hoàn thiện.
Em xin chân thành cám ơn thầy Nguyễn Văn Dương, thày giáo hướng
dẫn trực tiếp, và các thày cô khác trong bộ môn đã tận tình giúp đỡ và tạo
72
điều kiện để em hoàn thành quyển đồ án này.
TÀI LIỆU THAM KHẢO
1. John G. Proakis and Dimitris G.Manolakis (1982), Digital signal
processing,Macmillan Publishing Company.
2. John G. Proakis (1983), Digital Communication, McGraw-Hill Book
Company.
3. Nguyễn Quốc Trung (2001), Xử lí tín hiệu và lọc số tập 1 và 2, Nhà
xuất bản khoa học và kĩ thuật.
4. Các tài liệu liên quan khác của
- Eleftheiou và Falcorner(1987).
- Cioffi và Kailath(1984).
- Hsu(1982).
73
Các file đính kèm theo tài liệu này:
- 11.PhanThuyNinh_DT1001.pdf