?? 16qam.m
字號:
function Symbol=QAM16Mod(bit)
% 16QAM調制
% 16QAM: s3 s2 s1 s0 m1 mQ
% 0 0 0 0 3A 3A
% 0 0 0 1 A 3A
% 0 0 1 1 -A 3A
% 0 0 1 0 -3A 3A
% 0 1 0 0 3A A
% 0 1 0 1 A A
% 0 1 1 1 -A A
% 0 1 1 0 -3A A
% 1 1 0 0 3A -A
% 1 1 0 1 A -A
% 1 1 1 1 -A -A
% 1 1 1 0 -3A -A
% 1 0 0 0 3A -3A
% 1 0 0 1 A -3A
% 1 0 1 1 -A -3A
% 1 0 1 0 -3A -3A
%
% note:A=1/sqrt(10)
%
bitlength=length(bit);
A=1/sqrt(10);
% bit(ii*4)=s3,bit(ii*4-1)=s2,bit(ii*4-2)=s1,bit(ii*4-3)=s0
for ii=1:bitlength/4
if bit(ii*4)==0
if bit(ii*4-1)==0 %00**
if bit(ii*4-2)==0
if bit (ii*4-3)==0
Symbol(ii)=3*A+3*A*j;
else
Symbol(ii)=A+3*A*j;
end
else
if bit(ii*4-3)==0
Symbol(ii)=-3*A+3*A*j;
else
Symbol(ii)=-A+3*A*j;
end
end
else %01**
if bit(ii*4-2)==0
if bit (ii*4-3)==0
Symbol(ii)=3*A+A*j;
else
Symbol(ii)=A+A*j;
end
else
if bit (ii*4-3)==0
Symbol(ii)=-3*A+A*j;
else
Symbol(ii)=-A+A*j;
end
end
end
else
if bit(ii*4-1)==0 %10**
if bit(ii*4-2)==0
if bit (ii*4-3)==0
Symbol(ii)=3*A-3*A*j;
else
Symbol(ii)=A-3*A*j;
end
else
if bit (ii*4-3)==0
Symbol(ii)=-3*A-3*A*j;
else
Symbol(ii)=-A-3*A*j;
end
end
else %11**
if bit(ii*4-2)==0
if bit (ii*4-3)==0
Symbol(ii)=3*A-A*j;
else
Symbol(ii)=A-A*j;
end
else
if bit (ii*4-3)==0
Symbol(ii)=-3*A-A*j;
else
Symbol(ii)=-A-A*j;
end
end
end
end
end
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -