收藏 分销(赏)

QPSK调制解调的仿真.doc

上传人:人****来 文档编号:4293127 上传时间:2024-09-04 格式:DOC 页数:23 大小:725.51KB
下载 相关 举报
QPSK调制解调的仿真.doc_第1页
第1页 / 共23页
QPSK调制解调的仿真.doc_第2页
第2页 / 共23页
QPSK调制解调的仿真.doc_第3页
第3页 / 共23页
QPSK调制解调的仿真.doc_第4页
第4页 / 共23页
QPSK调制解调的仿真.doc_第5页
第5页 / 共23页
点击查看更多>>
资源描述

1、 通信工程专业综合课程设计引言近年来,软件无线电作为解决通信体制兼容性问题的重要方法受到各方面的注意。它的中心思想是在通用的硬件平台上,用软件来实现各种功能,包括调制解调类型、数据格式、通信协议等。通过软件的增加、修改或升级就可以实现新的功能,充分体现了体制的灵活性、可扩展性等。其中软件的增加、高频谱效率的调制解调模块是移动通信系统的关键技术,它的软件化也是实现软件无线电的重要环节。QPSK是英文Quadrature Phase Shift Keying的缩略语简称,意为正交相移键控,是一种数字调制方式。在19世纪80年代初期,人们选用恒定包络数字调制。这类数字调制技术的优点是已调信号具有相对

2、窄的功率谱和对放大设备没有线性要求,不足之处是其频谱利用率低于线性调制技术。19世纪80年代中期以后,四相绝对移相键控(QPSK)技术以其抗干扰性能强、误码性能好、频谱利用率高等优点,广泛应用于数字微波通信系统、数字卫星通信系统、宽带接入、移动通信及有线电视系统之中。通过完成设计内容, 复习QPSK调制解调的基本原理,同时也要复习通信系统的主要组成部分,了解调制解调方式中最基础的方法。了解QPSK的实现方法及数学原理。并对“通信”这个概念有个整体的理解,学习数字调制中误码率测试的标准及计算方法。同时还要复习随机信号中时域用自相关函数,频域用功率谱密度来描述平稳随机过程的特性等基础知识,来理解高

3、斯信道中噪声的表示方法,以便在编程中使用。理解QPSK调制解调的基本原理,并使用MATLAB编程实现QPSK信号在高斯信道和瑞利衰落信道下传输,以及该方式的误码率测试。复习MATLAB编程的基础知识和编程的常用算法以及使用MATLAB仿真系统的注意事项,并锻炼自己的编程能力,通过编程完成QPSK调制解调系统的仿真,以及误码率测试,并得出响应波形。在完成要求任务的条件下,尝试优化程序。本课设是基于Matlab的软件仿真,只需PC机上安装MATLAB 6.0或者以上版本即可。课设的要求是1.构建一个理想信道基本QPSK仿真系统,要求仿真结果有:基带输入波形及其功率谱;QPSK信号及其功率谱 ;QP

4、SK信号星座图。2.构建一个在AWGN(高斯白噪声)信道条件下的QPSK仿真系统, 得出高斯白噪声信道条件下的误码性能以及高斯白噪声的理论曲线,要求所有误码性能曲线在同一坐标比例下绘制。通过本次实验,除了和队友培养了默契学到了知识之外,还可以将次实验作为一种推广,让更多的学生来深入一层的了解QPSK以至其他调制方式的原理和实现方法。可以方便学生进行测试和对比。足不出户便可以做实验。1 方案论证 本次课设是基于MATLAB环境下对QPSK调制解调系统进行仿真。在Matlab环境下有两种仿真方案,一种是基于simulink对QPSK进行模块化的仿真,要求是不能直接调用软件里面的集成模块,以此来实现

5、QPSK系统的仿真。另一种方案是在Matlab环境下,用软件编程的方法来实现调制解调系统的仿真,并且得出不同信道的误码率,并作以比较。 1.1 方案一 在Matlab环境下,用软件编程的方法来实现QPSK调制解调系统的仿真。Matlab是一款由美国Math Works公司出品的商业数学软件。MATLAB 是一种用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境。除了矩阵运算、绘制函数/数据图像等常用功能外,MATLAB还可以用来创建用户界面及与调用其它语言(包括C,C+和FORTRAN)编写的程序。我们此次可以应用它的这种功能,在熟练掌握语言编程以及深刻理解QPSK的

6、基础上,严格按照程序仿真的流程图对各部分进行程序编写并仿真。应用理论知识来验证最终的仿真结果是否正确。1.2 方案二在Matlab环境下的Simulink模块库中应用模块来搭建QPSK调制解调系统的仿真电路模块。在深入了解QPSK调制解调系统理论知识的情况下,根据理论知识构建调制解调的系统框图。在此基础上选择合适的电路器件以及设置合理的参数,构成调制解调的总体电路框图。Simulink是MATLAB最重要的组件之一,它提供一个动态系统建模、仿真和综合分析的集成环境。在该环境中只要通过简单的鼠标操作,就可以构造出复杂的系统。Simulink提供了一个建立模型方块图的图形用户接口,这个创建过程只需

7、单击和拖动鼠标操作就能完成,它提供了一种更快捷、直接明了的方式,而且用户可以立即看到系统的仿真结果。在此基础上完成电路图的搭建,得出仿真结果,并与实际的理论结果相比较。1.3 方案确立在经过详细的考虑和比较之后,我确立了方案一为本次课程设计的最终方案。QPSK的调制方法有两种,分别是相乘电路法和选择法,结合本次设计的实际情况,最终选择用程序方式实现相乘电路的调制方式。因为在Matlab中应用程序对QPSK调制解调系统进行仿真,一方面降低了系统设计的复杂性,并且有效的克服了电子瓶颈的问题。因为在电子电路中,总体电路对参数设置是非常敏感的,一旦参数设置出现小的偏差,将会影响到整个电路的结果。另一方

8、面程序的仿真过程中可以将主程序分为很多个子程序,将它们逐个进行仿真,这样不会影响到整体结果,可以逐步进行调试。结合以上的比较论证以及自身的能力,最终我决定用程序法来完成此次对QPSK调制解调系统的仿真。2 仿真原理四相相位调制解调是利用载波的四种不同相位差来表征输入的数字信息 ,是四进制移相键控。QPSK是在 M =4时的调相技术 ,它规定了四种载波相位 ,分别为 45, 135, 225, 275,调制器输入的数据是二进制数字序列 ,为了能和四进制的载波相位配合起来 ,则需要把二进制数据变换为四进制数据 ,这就是说需要把二进制数字序列中每两个比特分成一组 ,共有四种组合 ,即 00, 01,

9、 10, 11,其中每一组称为双比特码元。每一个双比特码元是由两位二进制信息比特组成 ,它们分别代表四进制四个符号中的一个符号。QPSK中每次调制可传输 2个信息比特 ,这些信息比特是通过载波的四种相位来传递的。解调器根据星座图及接收到的载波信号的相位来判断发送端发送的信息比特。数字调制用“星座图 ”来描述 ,星座图中定义了一种调制技术的两个基本参数 : (1)信号分布; (2) 与调制数字比特之间的映射关系。星座图中规定了星座点与传输比特间的对应关系 ,这种关系称为“映射 ”,一种调制技术的特性可由信号分布和映射完全定义 ,即可由星座图来完全定义3 。在 QPSK调制中 ,QPSK信号可以看

10、作两个载波正交的 2PSK调制器构成。串 /并变换器将输入的二进制序列分为速率减半的两个并行的双极性序列 ,然后分别对 sinct和 cosct调制 ,相加后得到QPSK调制信号。QPSK同相支路和正交支路可分别采用相干解调方式解调 ,得到 I( t)和 Q ( t)。经抽样判决和并 /串变换器 ,将上、下支路得到的并行数据恢复成串行数据。21 QPSK调制原理 在 QPSK调制中 ,QPSK信号可以看作两个载波正交的 2PSK调制器构成。串 /并变换器将输入的二进制序列分为速率减半的两个并行的双极性序列 ,然后分别对 sinct和 cosct调制 ,相加后得到QPSK调制信号。QPSK同相支

11、路和正交支路可分别采用相干解调方式解调 ,得到 I( t)和 Q ( t)。经抽样判决和并 /串变换器 ,将上、下支路得到的并行数据恢复成串行数据。调制原理框图如图2.1所示图2.1 QPSK调制原理框图原理分析:基本原理及系统结构QPSK与二进制PSK一样,传输信号包含的信息都存在于相位中。的别的载波相位取四个等间隔值之一,如/4, 3/4,5/4,和7/4。相应的,可将发射信号定义为 0tTSi(t) 0 (2.1.1)其中,i1,2,2,4;E为发射信号的每个符号的能量,T为符号持续时间,载波频率f等于nc/T,nc为固定整数。每一个可能的相位值对应于一个特定的二位组。例如,可用前述的一

12、组相位值来表示格雷码的一组二位组:10,00,01,11。下面介绍QPSK信号的产生和检测。如果a为典型的QPSK发射机框图。输入的二进制数据序列首先被不归零(NRZ)电平编码转换器转换为极性形式,即负号1和0分别用和表示。接着,该二进制波形被分接器分成两个分别由输入序列的奇数位偶数位组成的彼此独立的二进制波形,这两个二进制波形分别用a1(t),和a2(t)表示。容易注意到,在任何一信号时间间隔内a1(t),和a2(t)的幅度恰好分别等于Si1和 Si2,即由发送的二位组决定。这两个二进制波形a1(t),和a2(t)被用来调制一对正交载波或者说正交基本函数:1(t),2(t)。这样就得到一对二

13、进制PSK信号。1(t)和2(t)的正交性使这两个信号可以被独立地检测。最后,将这两个二进制PSK信号相加,从而得期望的QPSK。2.2 QPSK解调原理在 QPSK解调中 ,正交支路和同相支路分别设置两个相关器 (或匹配滤波器 ) ,得到 I( t)和 Q ( t) ,经电平判决和并 /串变换后即可恢复原始信息从发射机发射的已调信号经过传输媒质传播到接收端 ,接收机接收到的己调信号为:SQPSK( t) = I( t) cosct +Q ( t) sinct (2.2.1)I( t)、Q ( t)分别为同相和正交支路 ,c为载波频率 ,那么相干解调后 ,同相支路相乘可得:Ii( t) = S

14、QPSK( t) cosct = I( t) cosct +Q ( t) sinctcosct =I( t) cos2wct +Q ( t) sin wct /2=I( t)/2- I( t) cos 2ct +Q ( t) sin 2ct (2.2.2)正交支路相乘可得:Qq( t) = SQPSK( t) sinct = I( t) cosct +Q ( t) sinctsinct = I( t) sinct cosct +Q (t) sin2ct =I(t) sin 2ct/2 +Q ( t)-Q ( t) cos 2ct (2.2.3)经过低通滤波器可得:Ii( t) =0.5I( t

15、), Qq( t) =0.5Q ( t) (2.2.4) 原理框图如图2.2所示: 1(t ) 同相信道 门限0发送二进制序列的估计判决门限低通filrer判决门限复接器接收信 号x(t)低通filrer 2(t) 正交信道 门限0 图2.2 QPSK解调原理框图原理分析:QPSK接收机由一对共输入地相关器组成。这两个相关器分别提供本地产生地相干参考信号1(t)和2(t)。相关器接收信号x(t),相关器输出地x1和x2被用来与门限值0进行比较。如果x10,则判决同相信道地输出为符号1;如果x10.5; % 调用一个随机函数(0 or 1),输出到一个1*100的矩阵datanrz=data.*

16、2-1; % 变成极性码data1=zeros(1,nb/delta_T); % 创建一个1*nb/delta_T的零矩阵for q=1:nb data1(q-1)/delta_T+1:q/delta_T)=datanrz(q); % 将极性码变成对应的波形信号end % 将基带信号变换成对应波形信号data0=zeros(1,nb/delta_T); % 创建一个1*nb/delta_T的零矩阵for q=1:nb data0(q-1)/delta_T+1:q/delta_T)=data(q); % 将极性码变成对应的波形信号end % 发射的信号data2=abs(fft(data1);%

17、 串并转换,将奇偶位数据分开idata=datanrz(1:ml:(nb-1); % 将奇偶位分开,因此间隔m1为2 qdata=datanrz(2:ml:nb);% QPSK信号的调制ich=zeros(1,nb/delta_T/2); % 创建一个1*nb/delta_T/2的零矩阵,以便后面存放奇偶位数据for i=1:nb/2 ich(i-1)/delta_T+1:i/delta_T)=idata(i);endfor ii=1:N/2 a(ii)=sqrt(2/T)*cos(2*pi*fc*t(ii); endidata1=ich.*a; % 奇数位数据与余弦函数相乘,得到一路的调制信

18、号qch=zeros(1,nb/2/delta_T);for j1=1:nb/2 qch(j1-1)/delta_T+1:j1/delta_T)=qdata(j1);endfor jj=1:N/2 b(jj)=sqrt(2/T)*sin(2*pi*fc*t(jj);endqdata1=qch.*b; % 偶数位数据与余弦函数相乘,得到另一路的调制信号s=idata1+qdata1; % 将奇偶位数据合并,s即为QPSK调制信号ss=abs(fft(s); % 快速傅里叶变换得到频谱% 瑞利衰落信道和高斯信道% 瑞利衰落信道ray_ich=raylrnd(0.8,1,nb/2/delta_T);

19、ray_qch=raylrnd(0.8,1,nb/2/delta_T);Ray_idata=idata1.*ray_ich;Ray_qdata=qdata1.*ray_qch;Ray_s=Ray_idata+Ray_qdata;% 高斯信道 s1=awgn(s,SNR); % 通过高斯信道之后的信号s11=abs(fft(s1); % 快速傅里叶变换得到频谱 s111=s1-s; % 高斯噪声曲线%Awgn_s=awgn(Ray_s,SNR); % 通过高斯信道再通过瑞利衰落信道% QPSK 解调部分% 解调部分(高斯信道)idata2=s1.*a; % 这里面其实隐藏了一个串并转换的过程qd

20、ata2=s1.*b; % 对应的信号与正余弦信号相乘idata3=zeros(1,nb/2); % 建立1*nb数组,以存放解调之后的信号qdata3=zeros(1,nb/2);% 抽样判决的过程,与0作比较,data=0,则置1,否则置0for n=1:nb/2% A1(n)=sum(idata2(n-1)/delta_T+1:n/delta_T); if sum(idata2(n-1)/delta_T+1:n/delta_T)=0 idata3(n)=1; else idata3(n)=0; end% A2(n)=sum(qdata2(n-1)/delta_T+1:n/delta_T)

21、; if sum(qdata2(n-1)/delta_T+1:n/delta_T)=0 qdata3(n)=1; else qdata3(n)=0; endend % 为了显示星座图,将信号进行处理idata4=zeros(1,nb/2);qdata4=zeros(1,nb/2);for n=1:nb/2 Awgn_ichsum(n)=sum(idata2(n-1)/delta_T+1:n/delta_T)*delta_T; if Awgn_ichsum(n)=0 idata4(n)=1; else idata4(n)=0; end Awgn_qchsum(n)=sum(qdata2(n-1)

22、/delta_T+1:n/delta_T)*delta_T; if Awgn_qchsum(n)=0 qdata4(n)=1; else qdata4(n)=0; endend% 将判决之后的数据存放进数组demodata=zeros(1,nb);demodata(1:ml:(nb-1)=idata3; % 存放奇数位demodata(2:ml:nb)=qdata3; % 存放偶数位%为了显示,将它变成波形信号(即传输一个1代表单位宽度的高电平)demodata1=zeros(1,nb/delta_T); % 创建一个1*nb/delta_T的零矩阵for q=1:nb demodata1(q

23、-1)/delta_T+1:q/delta_T)=demodata(q); % 将极性码变成对应的波形信号end % 累计误码数% abs(demodata-data)求接收端和发射端% 数据差的绝对值,累计之后就是误码个数Awgn_num_BER=sum(abs(demodata-data) % 解调部分(瑞利+高斯)Ray_idata2=Ray_s.*a; % 这里面其实隐藏了一个串并转换的过程Ray_qdata2=Ray_s.*b; % 对应的信号与正余弦信号相乘% Ray_idata3=zeros(1,nb/2); % 建立1*nb数组,以存放解调之后的信号% Ray_qdata3=z

24、eros(1,nb/2);% 抽样判决的过程,与0作比较,data=0,则置1,否则置0% for n=1:nb/2% if Ray_sum(Ray_idata2(n-1)/delta_T+1:n/delta_T)=0% Ray_idata3(n)=1;% else Ray_idata3(n)=0; % end% if Ray_sum(Ray_qdata2(n-1)/delta_T+1:n/delta_T)=0% Ray_qdata3(n)=1;% else Ray_qdata3(n)=0;% end% end % 为了显示星座图,将信号进行处理Ray_idata4=zeros(1,nb/2)

25、;Ray_qdata4=zeros(1,nb/2);for n=1:nb/2 Ray_ichsum(n)=sum(idata2(n-1)/delta_T+1:n/delta_T)*delta_T; if Ray_ichsum(n)=0 Ray_idata4(n)=1; else Ray_idata4(n)=0; end Ray_qchsum(n)=sum(qdata2(n-1)/delta_T+1:n/delta_T)*delta_T; if Ray_qchsum(n)=0 Ray_qdata4(n)=1; else Ray_qdata4(n)=0; endend % 将判决之后的数据存放进数

26、组Ray_demodata=zeros(1,nb);Ray_demodata(1:ml:(nb-1)=Ray_idata4; % 存放奇数位Ray_demodata(2:ml:nb)=Ray_qdata4; % 存放偶数位%为了显示,将它变成波形信号(即传输一个1代表单位宽度的高电平)Ray_demodata1=zeros(1,nb/delta_T); % 创建一个1*nb/delta_T的零矩阵for q=1:nb Ray_demodata1(q-1)/delta_T+1:q/delta_T)=Ray_demodata(q); % 将极性码变成对应的波形信号end % 累计误码数% abs(

27、demodata-data)求接收端和发射端% 数据差的绝对值,累计之后就是误码个数Ray_num_BER=sum(abs(Ray_demodata-data) % % 误码率计算% 调用了cm_sm32();和cm_sm33()函数%声明: 函数声明在另外俩个M文件中%作用: cm_sm32()用于瑞利信道误码率的计算% cm_sm33()用于高斯信道误码率的计算% ecoh on/off 作用在于决定是否显示指令内容%SNRindB1=0:1:6;SNRindB2=0:0.1:6;% 瑞利衰落信道 for i=1:length(SNRindB1), pb,ps=cm_sm32(SNRind

28、B1(i); % 比特误码率 smld_bit_ray_err_prb(i)=pb; smld_symbol_ray_err_prb(i)=ps; disp(ps,pb); echo off; end;% 高斯信道 echo on;for i=1:length(SNRindB1), pb1,ps1=cm_sm33(SNRindB1(i); smld_bit_awgn_err_prb(i)=pb1; smld_symbol_awgn_err_prb(i)=ps1; disp(ps1,pb1); echo off;end;% 理论曲线echo on;for i=1:length(SNRindB2), SNR=exp(SNRindB2(i)*log(10)/10); % 信噪比 theo_err_awgn_p

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服