⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 qam_8.m

📁 数字调制解调的MATLAB仿
💻 M
字号:
function [p]=QAM_8(snr_in_dB)
N=10000;
d=1;				  	% 符号间最小距离
Eav=6*d^2;		 	  	% 符号能量
snr=10^(snr_in_dB/10);	 	  	% 每比特符号的信噪比
sgma=sqrt(Eav/(6*snr));	  	  	%  噪声方差
M=8;
% 产生数据
for i=1:N,	
  temp=rand;			  
  dsource(i)=1+floor(M*temp);	  	% 生成[1,8]的随机数 
end;
% 映射图案
mapping=[-3*d d;
         -d d;
         d d;
         3*d d;
         3*d -d;
         d -d;
         -d -d;
         -3*d -d];
for i=1:N,
  qam_sig(i,:)=mapping(dsource(i),:);
end;
% 接收信号
for i=1:N,
  [n(1) n(2)]=gngauss(sgma);
  r(i,:)=qam_sig(i,:)+n;
end;
% 解调检测及误码率计算
numoferr=0;
for i=1:N,
  % 量化计算
  for j=1:M,
    metrics(j)=(r(i,1)-mapping(j,1))^2+(r(i,2)-mapping(j,2))^2;
  end;
  [min_metric decis] = min(metrics);
  if (decis~=dsource(i)),
    numoferr=numoferr+1;
  end;
end;
p=numoferr/(N);		  

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -