- 1、本文档共15页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
通信系统仿真课程设计报告
题 目: 基于Matlab的通信系统仿真
班 级:
姓 名:
学 号:
指导老师:
一、系统综述
利用Matlab仿真软件,完成如图所示的一个基本的数字通信系统。信号源产生0、1等概分布的随机信号,映射到16QAM的星座图上,同时一路信号已经被分成了实部和虚部,后边的处理建立在这两路信号的基础上。实部、虚部信号分别经过平方根升余弦滤波器,再加入高斯白噪声,然后通过匹配滤波器(平方根升余弦滤波器)。最后经过采样,判决,得到0、1信号,同原信号进行比较,给出16QAM数字系统的误码。
系统框图
二、系统实现
1、随机信号的产生
利用Matlab中自带的函数randint来产生n*k随机二进制信号。源程序如下:
M = 16;
k = log2(M); % 每个符号的比特数
n = 6000; % 输入码元的长度
fd=1;
fc=4*fd;
fs=4*fc;
xEnc = randint(n*k,1); %产生长度为n*k的随机二进制信号
plot(xEnc);
2、星座图映射
将随机二进制信号映射到16QAM星座图上。每四个bit构成一个码子,具体实现的方法是,将输入的信号进行串并转换分成两路,分别叫做I路和Q路。再把每一路的信号分别按照两位格雷码的规则进行映射,这样实际上最终得到了四位格雷码。为了清楚说明,参看表1。
表1 两位格雷码的映射规律
两位0、1码 映射后(按格雷码) 0 0 -3 0 1 -1 1 1 1 1 0 3
16QAM调制模块程序如下:
function [ gPsk,map ] = qam_modu( M )
gPsk = bitxor(0:sqrt(M)-1,floor((0:sqrt(M)-1)/2));%转换成格雷码
% 产生16QAM的星座对应点的十进制数值
map = repmat(gPsk,1,sqrt(M))+repmat(sqrt(M)*gPsk,sqrt(M),1);%remat(A,m,n)表示复制m行A,n列A
map = map(:);
end
星座图映射模块程序如下(系统框图中图1的程序):
function xmod = plot_astrology(M,k,mapping,xEnc,d)
t1 = qammod(mapping,M);% 16-QAM调制,将十进制数化为复数
if(d==1)
scatterplot(t1); % 星座图 (图1)
title(16QAM调制后的星座图(图1))
grid on
hold on;
% 加入每个点的对应4位二进制码
for jj=1:length(t1)
text(real(t1(jj))-0.5,imag(t1(jj))+0.5,dec2base(jj-1,2,4));
end
set(gca,yTick,(-(k+1):2:k+1),xTick,(-(k+1):2:k+1),...
XLim,[-(k+1) k+1],YLim,[-(k+1) k+1],Box,on,...
YGrid,on, XGrid,on);
end
xlabel (In-Phase);
hold off;
set(gcf,Color,w)
xSym = reshape(xEnc,k,numel(xEnc)/k).; %将一个长信号变化为每4个一组,分为4个数的矩阵,用于编码
xSym = bi2de(xSym, left-msb) ; %将4位二进制数化为10进制数
xSym = mapping(xSym+1); %映射到星座图上对应该的点
xmod = qammod(xSym,M); %转化为复数形式
end
得到的星座图如图1所示,图上注明了每一个点对应的01序列。
图1 16QAM调制后的星座图
从上边的星座图上可以清楚的看到,任意相邻的两个点之间它们对应的4个bit中只有一个有差别,也就是格雷码的特点。而采用格雷码主要目的是当信噪比较大时,也就是系统的误码率比较低的情况下,当出现一个符号错误的情况下,往往只是这个符号中的一个bit位出现了误码,因此这个情况下误码
文档评论(0)