Xử lý tín hiệu số có hai mảng chính đó là xử lý tín hiệu âm thanh và xử lý ảnh.trong đó xử lý âm thanh được phổ biến trong cuộc sống hiện đại rất phổ biến.những ứng dụng có thể kể tơi đó
Trang 1TRƯỜNG ĐẠI HỌC BÁCH KHOA HÀ NỘI
VIỆN ĐIỆN TỬ - VIỄN THÔNG
BÁO CÁO BÀI TẬP LỚN
MÔN XỬ LÝ SỐ TÍN HIỆU
Đề tài:
Mã hóa, truyền và giải mã tín hiệu âm thanh
thời gian thực trên Matlab
Sinh viên thực hiện: Phan Thu Trang 20109648
Đinh Văn Nhâm 20109345 Nguyễn Đức Minh 20109587 Giảng viên hướng dẫn : Thầy Dương Tấn Nghĩa
Hà nội, 5-2013
Trang 2Mục lục
I Giới thiệu đề tài: 3
II Nội dung bài tập lớn 3
Khối 1:Nén tín hiệu 4
Khối 2:Lượng tử hóa tín hiệu 6
Khối 3:Integer to Bit Converter 8
Khối 4:Mã chập 8
Khối 5: Điều chế QPSK 9
Khối 6:Kênh truyền cộng nhiễu AWGN (ADDITIVE WHITE GAUSSIAN NOISE) 10
Khối 7: Giải điều chế QPSK 12
Khối 8:Giải mã mã chập 12
Khối 9: Giải mã Bit to Integer Converter 13
Khối 10 : Giải mã lượng tử hóa DPCM 13
Khối 11: Giãn tín hiệu 14
Khảo sát tỷ lệ lỗi bit trong đường truyền 14
III KẾT LUẬN 17
IV TÀI LIỆU THAM KHẢO: 17
Trang 3I Gi i thi u đ tài: ới thiệu đề tài: ệu đề tài: ề tài:
Ngày nay,cùng với sự phát triển của ngành công nghệ vi điện tử và máy tính thì ứng dụng của XỬ LÝ SỐ TÍN HIỆU(Digital Signal Processing ) đã trở thành một trong những ứng dụng cơ bản và phổ biến cho kỹ thuật mạch tích hợp hiện đại váo các vi xử lý có thể lập trình và hoạt động ở tốc dọ cao.
Xử lý tín hiệu số có hai mảng chính đó là xử lý tín hiệu âm thanh và xử lý ảnh.trong đó xử lý âm thanh được phổ biến trong cuộc sống hiện đại rất phổ biến.những ứng dụng có thể kể tơi đó là:nhận diện giọng nói,biến văn bản thành giọng nói,xử lý âm thanh trong âm nhạc …
Chính vì lý do đó nhóm em đã chọn đề tài cho bài tập lớn: Mã hóa, truyền và giải mã tín hiệu âm thanh thời gian thực Matlab.
Nhóm em xin gửi lời cảm ơn đến thầy Dương Tấn Nghĩa đã trực tiếp hướng dẫn, giúp đỡ chúng
em hoàn thành bài báo cáo này
II N i dung bài t p l n ội dung bài tập lớn ập lớn ới thiệu đề tài:
Đề tài: Mã hóa, truyền và giải mã tín hiệu âm thanh thời gian thực Matlab
Sơ đồ khối của quá trình thực hiện:
Tổng quan:
Do tín hiệu âm thanh thu được trên máy tính đã được lấy mẫu với chu kỳ lấy mẫu cho trước nên ta bỏ qua khối lấy mẫu
Trang 4Tín hiệu sau khi lượng tử hóa được các chỉ số Index và Quant_out Mã hóa các Index bằng bộ
mã hóa Integer to Bit Converter, sau đó cho các bít nhị phân đi qua bộ mã hóa bằng mã chập (Convolutional Encoder) với tốc độ R = ½ nghĩa là số bít ra gấp 2 lần số bit đầu vào Tiếp tục điều chế QPSK tín hiệu trước khi đưa lên kênh truyền cộng nhiễu AWGN Channel Thực hiện giả mã lần lượt QPSK, mã chập, mã nhị phân là lượng tử hóa ta sẽ được tín hiệu tín hiệu có được tín hiệu bên thu
Sử dụng các lệnh sau để đọc vào 1 file âm thanh wav:
[filename,pathname]=uigetfile('*.wav');
[signal Srate nBits] = wavread([pathname,filename]);
signal là một ma trận lưu dữ liệu âm thanh; nếu wav-file là mono thì signal là vector cột, còn
stereo thì nó là ma trận có 2 cột
Srate là tốc độ lấy mẫu của file này.
nBits là số bit dùng để lưu một mẫu dữ liệu.
filename đưa vào là file road.wav đi kèm.
Khảo sát tín hiệu đưa vào:
Mp = max(signal);
bits = 8;%Dùng 8 bit để mã hóa 1 mẫu
levels = 2^bits;%So mau 8 bit mã hóa được
step_size = (2*Mp)/levels;%Bước nhảy cho mỗi khoảng
codebook = [-Mp+step_size:step_size:Mp]; % Số đại diện cho mỗi khoảng trong phần
%partition
partition = [-Mp+2*step_size:step_size:Mp] %Chia tín hiệu thành 256 khoảng
%Chia tín hiệu thành các frame, mỗi frame có chứa 1024 mẫu
frame = reshape(signal,1024,length(signal)/1024);
%frame là một ma trận có 1024 hàng và length(signal)/1024 cột
k = length(signal)/1024;
Trang 5Kh i 1:Nén tín hi u ối 1:Nén tín hiệu ệu đề tài:
Trong các ứng dụng xử lý tín hiệu thoại (speech processing), trước khi lượng tử hoá, người ta thường thực hiện nén (compress) tín hiệu theo hàm logarithm, mục đích là để tín hiệu ở mức biên
độ nhỏ sẽ thay đổi nhiều mức hơn so với ở các giá trị biên độ lớn, do đó sai số lượng tử tương đối ở các mức biên độ nhỏ và lớn sẽ không chênh lệch nhau nhiều như đối với trường hợp không nén
Để khôi phục lại đúng tín hiệu ban đầu thì sau khi giải mã, ta phải đưa qua một bộ giãn tín hiệu (expander) có đặc tuyến truyền đạt là nghịch đảo của đặc tuyến của bộ nén (compressor)
Sự kết hợp của bộ nén và bộ giãn tín hiệu gọi chung là bộ nén giãn tín hiệu (compander) Hai luật nén giãn thường được sửdụng trong xử lý tín hiệu thoại là luật μ dùng ở Bắc Mỹ và luật A dùng ở châu Âu:
Luật µ :
max max
sgn ln(1 )
x x
Theo các chuẩn ởBắc Mỹ, giá trịcủa μ là 255 Max x và Max y lần lượt là các giá trị dương lớn nhất của x và y
Luật A:
max max
max max
1 ln
1 ln[ ( / )]
sgn
1 ln
A x x
A y
A x x
A
nếu
max
max
1 0
1
1
x
x
A x
với A là hắng số Giá trịchuẩn của A là 87.6
MATLAB cung cấp hàm compand để thực hiện nén giãn tín hiệu Hàm này hỗ trợ hai luật nén giãn A và μ nói trên
>> out = compand(in, param, v, method)
In là tín hiệu vào còn out là tín hiệu ra
v là biên độ đỉnh của tín hiệu vào
param là thông số của luật nén giãn (hằng sốA hoặc μ)
method có thể nhận một trong các giá trị sau:
Trang 6Code Matlab:
function sig_comp = compressor(sig_t)
%Nen tin hieu truoc khi dua vao khoi luong tu hoá
%sig_t la tin hieu dua vao
%Su dung nen theo luat A voi he so A = 86.7
A = 87.6;
V = max(sig_t);
sig_comp = compand(sig_t,A,V, 'A/compressor' );
end
Kh i 2:L ối 1:Nén tín hiệu ượng tử hóa tín hiệu ng t hóa tín hi u ử hóa tín hiệu ệu đề tài:
Lượng tử hoá là quá trình rời rạc hoá tín hiệu về mặt biên độ, cụ thể là thay thế tất cả các giá trị của tín hiệu nằm trong một khoảng xác định nào đó thành một giá trị duy nhất Miền giá trị của tín hiệu được chia thành một số hữu hạn các khoảng chia Nhưvậy, độ lớn của tín hiệu sau khi lượng tử chỉ có thể nhận một trong số hữu hạn các giá trị cho trước
Tập hợp các khoảng chia gọi là sự phân hoạch của tín hiệu (partition) Tập các giá trị thay thế cho mỗi khoảng chia gọi là bộ mã (codebook)
MATLAB biểu diễn phân hoạch của tín hiệu bằng một vector mà các phần tử của nó là các điểm ranh giới giữa hai khoảng chia liên tiếp Ví dụ, nếu tín hiệu có miền xác định là R, được phân hoạch thành các khoảng (-∞, 0], (0,2], (2,4] và (4,+∞) thì có thể biểu diễn sự phân hoạch này bằng vector:
>> partition = [0,2,4];
Tương ứng với vector phân hoạch tín hiệu là vector biểu diễn bộ mã tín hiệu Các phần tử của
nó là các giá trị thay thế trong mỗi khoảng chia tương ứng của phân hoạch Nếu ta thay thế các giá trị trong khoảng (-∞, 0] bằng -1, các giá trị trong khoảng (0,2] bằng 1, các giá trị trong khoảng (2,4] bằng 3 và các giá trị trong khoảng (4, +∞] bằng 5 thì vector biểu diễn bộ mã sẽ là:
>> codebook = [-1,1,3,5];
Trang 7Như trên đã đề cập, thông thường người ta sẽ phân hoạch miền xác định của tín hiệu thành 2^v khoảng, sau đó mỗi khoảng tín hiệu sẽ được lượng tử hoá, sau đó mã hoá bằng một từ mã nhị phân có chiều dài v bit Phương pháp lượng tử hoá này được gọi là phương pháp điều mã xung (Pulse Code Modulation) Phương pháp này không cần đòi hỏi bất kỳ thông tin nào về tín hiệu ở các thời điểm trước đó Trong thực tế, vì tín hiệu thường thay đổi chậm từ thời điểm lấy mẫu này sang thời điểm lấy mẫu kế tiếp nên nếu ta thực hiện lượng tử và mã hoá các giá trị sai biệt giữa thời điểm hiện tại với thời điểm trước đó thì sẽ tốn ít giá trị hơn so với mã hoá đầy đủ độ lớn của tín hiệu Trên cơ sở này, ta có một phương pháp lượng tử hoá mới, gọi là lượng tử hoá tiên đoán, trong đó giá trịcủa tín hiệu ở thời điểm hiện tại sẽ được tính thông qua một số các giá trị của tín hiệu ở các thời điểm quá khứ Tiêu biểu cho loại lượng tử hoá này là kỹ thuật điều mã xung vi sai (DPCM – Differential Pulse Code Modulation)
Để thực hiện mã hoá DPCM, ta không những phải xác định sự phân hoạch và bộ mã lượng tử
mà còn phải xác định hàm dự đoán, để dự đoán giá trị của tín hiệu ở thời điểm hiện tại Thông thường, người ta sử dụng hàm dự đoán tuyến tính:
y(k) = p(1)x(k-1) + p(2)x(k-2) + + p(m-1)x(k-m+1) + p(m)x(k-m) (14.1)
trong đó x là tín hiệu gốc còn y(k) là giá trịdự đoán của x(k); p là một vector gồm các hằng số thực
Thay vì lượng tử hoá tín hiệu x, ta sẽ thực hiện lượng tử hoá tín hiệu sai số dự đoán y – x m được gọi là bậc dự đoán Trường hợp đặc biệt m = 1 được gọi là điều chế delta
Trong MATLAB Communications Toolbox, hàm dự đoán được sửdụng là hàm dự đoán tuyến tính như trên và được biểu diễn bằng vector:
>> predictor = [0, p(1), p(2), p(3), , p(m-1), p(m)]
Sử dụng hàm dpcmenco thực hiện quá trình mã hóa với quant là vector chứa các giá trị lượng
tử còn index là vector chứa các chỉ số tương ứng trong bộ mã.
Code Matlab:
function [index,sig_quants] = DPCM(sig_comp, codebook,partition)
% Luong tu hoa DPCM voi tin hieu sig_comp sau khi nen
% bits la so bit bieu dien 1 mau
%Su dung ham du doan la y(k) = x(k-1)
predictor = [0 1]; % Ham du doan delta bac 1
[index,sig_quants] = dpcmenco(sig_comp,codebook,partition,predictor);
end
Trang 8Kh i 3:Integer to Bit Converter ối 1:Nén tín hiệu
Chuyển đổi các giá trị index từ 0- 255 thành các số nhị phân 8 bit
Code Matlab:
function sig_enc = Encoder(index)
%Bien doi tu ma thap phan sang nhi phan k bit
Sig_enc= de2bi (index, 'left-msb' ); %Bien doi chuoi thap phan
%thanh chuoi bit nhi phan
end
Kh i 4:Mã ch p ối 1:Nén tín hiệu ập lớn
Mã chập là một phương pháp mã hoá sửa sai quan trọng Khác với mã khối, mã chập là loại mã
có nhớ Mặc dù, bộ mã hoá chập cũng nhận các thông điệp có số lượng ký hiệu xác định và tạo
ra một từ mã cũng có số ký hiệu xác định, nhưng từ mã tạo ra ở mỗi thời điểm không chỉ phụ thuộc vào các ký hiệu của thông điệp hiện tại mà còn phụthuộc vào các ký hiệu của các thông điệp đã được mã hoá trước đó
Mã chập là mã tuyến tính có ma trận sinh có cấu trúc sao cho phép mã hóa có thể xem như 1 phép lọc Mã chập được sử dụng rộng rãi trong thực tế bởi mã hóa được xem như một tập hợp các bộ lọc số tuyến tính với các mã là các đầu ra của bộ lọc được ghép xen kẽ
Bộ mã hóa cho mã chập thường được coi là một tập hợp các bộ lọc số Ví dụ:
Dòng mk đi qua 2 bộ lọc dùng chung các phần tử nhớ tạo ra 2 dòng ra
C(1)
k = mk + mk-1 + mk-2 và C(2)
k = mk + mk-2
Vì cứ mỗi bit vào lại có hai bit được mã hóa đưa ra, kết quả là ta được một mã có tốc độ R=1/2
Trang 9M ã c h ậ p đ ư ợ c t ạ o r a b ằ n g c á c h c h o c h u ỗ i t h ô n g t i n t r u y ề n q u a h ệ t h ố n g
c á c thanh ghi dịch tuyến tính có số trạng thái hữu hạn Cho số lượng thanh ghi dịch
là m (cũng ký hiệu là N), bộ mã có k bit ngõ vào và đầu ra bộ mã chập có n bit ngõ ra(n hàm đại
số tuyến tính hoặc n ngõ ra cộng modulo) Tốc độ mã là R = k/n, s ố ô nhớ của bộ ghi dịch là m×k và tham số L gọi là chiều dài ràng buộc (Constraint length) của mã chập
(với L=k(m-1))
Code Matlab cho việc mã hóa mã chập:
function sig_conv = EnConv(sig_bit)
%Ham ma chap voi toc do R=1/2
%Cac da thuc sinh la G2=5, G3=7
%Chieu dai rang buoc L=3
%inpbits la tin hieu vào
L=3;
G =[5 7];
trellis = poly2trellis (L,G);
for i = 1 : 1024;
sig_conv(i,:) = convenc([sig_bit(i,:)],trellis);
end
end
Kh i 5: Đi u ch QPSK ối 1:Nén tín hiệu ề tài: ế QPSK
Điều chế tín hiệu là quá trình biến đổi một hay nhiều thông số của một tín hiệu tuần hoàn theo
sự thay đổi một tín hiệu mang thông tin cần truyền đi xa Tín hiệu tuần hoàn gọi là sóng mang Tín hiệu mang thông tin gọi là tín hiệu được điều chế Ở đầu thu bộ giải điều chế sẽ dựa vào sự thay đổi thông số đó của sóng mang để tái tạo lại tín hiệu mang thông tin ban đầu Các thông số của sóng mang được dùng trong quá trình điều chế có thể là biên độ, pha, tần số
Trong điều chế số, một sóng mang tương tự sẽ được biến đổi theo một chuỗi bit có chiều dài cố định hoặc thay đổi Đây cũng có thể được coi là một dạng biến đổi tương tự-số Hình dạng của sóng mang được lấy từ một tập hợp hữu hạn các ký hiệu
QPSK viết tắt của từ Quadrature Phase Shift Keying, gọi là điều chế pha cầu phương (điều
chế pha vuông góc) QPSK là 1 kỹ thuật điều chế tín hiệu số, mã hóa 2 bit thành 1 symbol.
Sơ đồ nguyên lý bộ điều chế QPSK sử dụng một trong 4 pha lệch nhau 900
Trang 10Tín hiệu băng gốc được đưa vào bộ biến đổi nối nối tiếp thành song song Đầu ra được 2 luồng
số liệu có tốc độ bit giảm đi 1 nửa, đồng thời biến đổi tín hiệu đơn cực thành tín hiệu 1 Hai sóng mang đưa tới 2 bộ trộn làm lệch pha nhau 900 Tổng hợp tín hiệu đầu ra 2 bộ trộn ta được tín hiệu QPSK
Trong Matlab sử dụng hàm pskmod với số mức điều chế là 4 để thực hiện điều chế QPSK
Trước khi điều chế thì phải đưa 2 bit thành các ký tự từ 0 đến 3
Code Matlab cho hàm QPSK
function sig_mod = QPSK(sig_conv)
%Dieu che QPSK cho tin hieu da dc ma chap
%Chuyen doi 2 bit thanh cac ky hieu
k = 2; %2bit/1ky tu
x = bi2de(reshape(sig_conv,k,length(sig_conv)/k).', 'left-msb' );
sig_mod = pskmod(x,4);
end
Kh i 6:Kênh truy n c ng nhi u AWGN (ADDITIVE WHITE GAUSSIAN ối 1:Nén tín hiệu ề tài: ội dung bài tập lớn ễu AWGN (ADDITIVE WHITE GAUSSIAN NOISE)
Với một kênh thông tin cơ bản, tín hiệu tin tức sau khi điều chế sẽ được gửi đi trên kênh truyền Trong thực tế tín hiệu khi truyền trên kênh truyền sẽ chịu tác động bởi các yếu tố của kênh truyền làm cho tín hiệu thu được không còn giống hoàn toàn tín hiệu phát Tuỳ theo các dạng môi trường truyền khác nhau và các hệ thống thông tin khác nhau, sự tác động nói trên
sẽ có những đặc trưng khác nhau MATLAB cho phép người sử dụng mô phỏng ba loại kênh truyền cơ bản, đó là: kênh truyền với nhiễu AWGN, kênh truyền fading và kênh truyền đối xứng nhị phân
Kênh truyền AWGN là dạng kênh truyền có nhiễu cộng, trắng và phân bố theo hàm Gauss Như vậy, một tín hiệu khi truyền qua kênh truyền này sẽ phải thêm vào một tín hiệu ngẫu
nhiên không mong muốn phân bố theo hàm Gauss:
Trang 112
1 ( )
2
x
Kênh truyền AWGN trong MATLAB được mô phỏng bằng hàm awgn Hàm này sẽ cộng nhiễu Gauss vào một tín hiệu cho trước (có thể là tín hiệu thực hay phức), mức công suất nhiễu do người sử dụng quy định thông qua hai thông số nhập:
- Mức công suất tín hiệu phát (đơn vịmặc định là dBW, hoặc có thểdùng đơn vị W)
- TỷsốSNR (đơn vị mặc định là dB)
Cú pháp của hàm awgn như sau:
>> awgn(X,SNR,SigPower,State,PowerType)
Trong đó: X là tín hiệu phát
SNR là tỷ số công suất tín hiệu trên nhiễu (tính bằng dB)
SigPower cho biết công suất tín hiệu vào (dBW), hoặc nếu SigPower = ‘measured’thì MATLAB
sẽ đo công suất tín hiệu phát trước khi cộng nhiễu
State cho biết trạng thái của bộ phát tín hiệu ngẫu nhiên
PowerType chỉ ra đơn vịcủa SNRvà SigPowerlà đơn vịdecibel (‘dB’) hay đơn vị tuyến
tính(‘linear’)
Ba thông số cuối không nhất thiết phải đưa vào, trong trường hợp không có các thông số này thì xem như công suất tín hiệu phát bằng 0 dBW và đơn vị của SNR là dB
Code Matlab cho kênh AWGN:
function sig_noise = awgnchan(sig_mod)
%Cho tin hieu sau khi da dieu che vao kenh truyen cong nhieu AWGN
%Kenh truyen AWGN la kenh truyen nhieu trang va phan bo Gauss
%Gia su kenh truyen co nang luong bit tren mat do cong suat nhieu Eb/N0 =
%9dB
M = 4; %Dieu che QPSK
k = log2 (M);
nsamp = 1;
EbNo = 9; %Don vi dB
SNR = EbNo + 10*log10 (k) - 10*log10 (nsamp);
sig_noise = awgn(sig_mod,SNR, 'measured' );
end