ImageVerifierCode 换一换
格式:DOCX , 页数:26 ,大小:213.10KB ,
资源ID:9555908      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/9555908.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(基于matlab的QPSK与BPSK信号性能比较仿真教材.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

基于matlab的QPSK与BPSK信号性能比较仿真教材.docx

1、基于matlab的QPSK与BPSK信号性能比较仿真教材第一章 概述QPSK是英文Quadrature Phase Shift Keying的缩略语简称,意为正交相移键控,是一种数字调制方式。它以其抗干扰性能强、误码性能好、频谱利用率高等优点,广泛应用于数字微波通信系统、数字卫星通信系统、宽带接人、移动通信及有线电视系统之中。BPSK是英文Binary Phase Shift Keying的缩略语简称,意为二相相移键控,是利用偏离相位的复数波浪组合来表现信息键控移相方式的一种。它使用了基准的正弦波和相位反转的波浪,使一方为0,另一方为1,从而可以同时传送接受2值(1比特)的信息。本文所研究的Q

2、PSK系统与二进制的BPSK系统相比,具有以下特点:1. 在传码率相同的情况下,四进制数字调制系统的信息速率是二进制系统的2倍。2. 在相同信息速率条件下,四进制数字调制系统的传码率是二进制系统的1/4倍,这一特点使得四进制码元宽度是二进制码元宽度的2倍,码元宽度的加大,可增加每个码元的能量,也可减小码间串扰的影响。3. 由于四进制码元速率比二进制的降低,所需信道带宽减小。4. 在接收系统输入信噪比相同的条件下,四进制数字调制系统的误码率要高于二进制系统。5. 四进制数字调制系统较二进制系统复杂,常在信息速率要求较高的场合。基于以上优点,在数字信号的调制方式中QPSK(Quadrature P

3、hase Shift Keying)四相移键控是目前最常用的一种卫星数字信号调制方式,它具有较高的频谱利用率、较强的抗干扰性,在电路上实现也较为简单,因而被WCDMA和CDMA2000等第三代移动通信系统采用。第二章 QPSK通信系统原理与仿真2.1 QPSK系统框图介绍在图2.1的系统中,发送方,QPSK数据源采用随机生成,信源编码采用差分编码,编码后的信号经QPSK调制器,经由发送滤波器进入传输信道。接收方,信号首先经过相位旋转,再经匹配滤波器解调,经阈值比较得到未解码的接收信号,差分译码后得到接收信号,与信源发送信号相比较,由此得到系统误码率,同时计算系统误码率的理论值,将系统值与理论值

4、进行比较。对于信道,这里选取的是加性高斯白噪声(Additive White Gaussian Noise)以及多径Rayleigh衰落信道(Multipath Rayleigh Fading Channel)。图2.1 QPSK系统框图在实验中,选用的是差分码。差分码又称为相对码,在差分码中利用电平跳变来分别表示1或0,分为传号差分码和空号差分码。传号差分码:当输入数据为“1”时,编码波型相对于前一码电平产生跳变;输入为“0”时,波型不产生跳变。空号差分码:当输入数据为“0”时,编码波型相对于前一码电平产生跳变;输入为“1”时,波型不产生跳变。2.2 QPSK信号的调制原理2.2.1 QPS

5、K信号产生方法QPSK信号通常由图2.2所示的调相法产生,输入的二进制序列经过一个串/并转换器后分为两路二进制序列,这里假设两路序列为a,b,并通过平衡调制器分别对同相载波及正交载波进行二相调制,得到如图2.3中的虚线矢量。QPSK信号每个码元含有2比特的信息,如图2.3所示现用ab代表这两个比特。两个比特有4种组合,即00、01、10和11。它们和相位之间的关系通常都按格雷码的规律安排,如表2-1所示。图2.2 调相法产生QPSK信号 图2.3 信号矢量2.2.2 QPSK星座图在本次系统仿真中使用仿真代码产生QPSK信号星座图,具体代码如附录代码1。运行得到的信号星座图如图2.4,2.5:

6、表2-1 QPSK编码规则abA方式B方式00101101表中一组间隔均匀的受调制相位2.3 QPSK解调原理及误码率分析2.3.1 QPSK解调方法由于QPSK信号可以看作两个正交2PSK信号的叠加,解调框图如图2.6,用相干解调方法,即用两路正交的相干载波,可以很容易的分离出这两路正交的2PSK信号。解调后的两路基带信号码元a和b,经过并串变换后,成为串行数据输出。图2.4 A方式信号星座图 图2.5 B方式信号星座图2.3.2 QPSK系统误码率在QPSK体制中,由其矢量图(图2.7)可以看出,因噪声的影响使接收端解调时发生错误判决,是由于信号矢量的相位发生偏离造成的。例如,设发送矢量的

7、相位为,它代表基带信号码元“11”,若因噪声的影响使接收矢量的相位变成,则将误判为“01”。当各个发送矢量以等概率出现时,合理的判决门限应该设在和相邻矢量等距离的位置。在图中对于矢量“11”来说,判决门限应该设在和。当发送“11”时,接收信号矢量的相位若超出这一范围(图图2.6 QPSK信号解调原理框图 图2.7 QPSK噪声容限中阴影区),则将发生错判。设为接收矢量(包括信号和噪声)相位的概率密度,则发生错误的概率为:省略计算和Pe的繁琐过程,直接给出计算结果:上式计算出的是QPSK信号的误码率。若考虑其误比特率,正交的两路相干解调方法和2PSK中采用的解调方法一样。所以其误比特率的计算公式

8、也和2PSK的误码率公式一样。2.4 QPSK信号在AWGN信道下仿真仿真代码见附录代码2。运行结果如图2.8:图2.8 AWGN环境下QPSK系统的仿真和理论结果由运行结果可以看出,仿真值与理论值基本吻合,误码率值随信噪比增大而下降。第三章 BPSK通信系统原理与仿真3.1 BPSK信号的调制原理图3.1 模拟调制方法图3.2 键控调制方法BSPK信号通常有2种调制方式,分别如图3.1、3.2所示。在2PSK中,通常用初始相位0和p分别表示二进制“1”和“0”。因此,2PSK信号的时域表达式为 式中,表示第n个符号的绝对相位:因此,上式可以改写为3.2 BPSK解调原理及误码率分析BPSK信

9、号的解调器原理方框图3.3和波形图3.4,这里给出的解调框图采用相干解调的接收方法。图3.3 BPSK信号相干解调框图波形图中,假设相干载波的基准相位与2PSK信号的调制载波的基准相位一致(通常默认为0相位)。但是,由于在2PSK信号的载波恢复过程中存在着的相位模糊,即恢复的本地载波与所需的相干载波可能同相,也可能反相,这种相位关系的不确定性将会造成解调出的数字基带信号与发送的数字基带信号正好相反,即“1”变为“0”,“0”变为“1”,判决器输出数字信图3.4 相干解调波形示意图号全部出错。这种现象称为2PSK 方式的“倒”现象或“反相工作”。这也是2PSK方式在实际中很少采用的主要原因。另外

10、,在随机信号码元序列中,信号波形有可能出现长时间连续的正弦波形,致使在接收端无法辨认信号码元的起止时刻。第四章 QPSK与BPSK性能比较4.1 QPSK与BPSK在多信道下比较仿真QPSK仿真程序见代码3。BPSK仿真程序见代码4。下面对QPSK与BPSK在多信道下的BER-SNR曲线进行横向及纵向的比较,如表4-1所示。4.1.1 纵向比较分析图中依次给出LOS信道、莱斯平坦衰落信道、莱斯频率选择性衰落、瑞利平坦衰落信道、瑞利频率选择性衰落。比较频率选择性衰落和其相应的平坦衰落,可发现频率选择性衰落比相应的平坦衰落的性能差。比较莱斯信道和瑞利信道,可发现不存在视距分量的瑞利信道比存在视距分

11、量的任何莱斯信道的性能差。表4-1 QPSK与BPSK在多信道下性能比较信道QPSKBPSKLOS莱斯平坦衰落莱斯频率选择性衰落信道QPSKBPSK瑞利平坦衰落瑞利频率选择性衰落4.1.2 横向比较分析相同信道下,BPSK调制的系统误码率小于QPSK调制。本次仿真过程中,莱斯平坦衰落信道下两者误码率差别显著。4.2 仿真结果分析4.2.1 误码率分析由前面介绍的误码率内容可以看出,QPSK判决门限为,BPSK的判决门限为。因此相同系统情况下的误码率BPSK优于QPSK。4.2.2 频带利用率比较在传码率相同的情况下,四进制数字调制系统的信息速率是二进制系统的2倍。频带利用率公式在相同信号速率的

12、情况下,QPSK和BPSK系统的带宽是相同的,但是由于QPSK每个信号都是四进制的,QPSK每个信号包含2bit信息,所以比特率就是BPSK的两倍,因而其频带利用率即为BPSK的两倍。BPSK系统理论的频带利用率最大为1,但是在实际的实现中不能达到1,而在QPSK系统中,频带利用率可以超过1。附 录代码1function qpskconstellationA(M)M=4;x=0:M-1;scatterplot(pskmod(x,M); % A方式QPSK信号grid on;returnfunction qpskconstellationB(M)M=4;x=0:M-1;scatterplot(p

13、skmod(x,M,pi/4); % B方式QPSK信号grid on;return代码2function x,bits=random_binary(nbits,nsamples) x=zeros(1,nbits*nsamples);bits=round(rand(1,nbits);for m=1:nbits for n=1:nsamples index=(m-1)*nsamples+n; x(1,index)=(-1)bits(m); endend returnfunction c,lags=vxcorr(a,b)%计算a b 的互相关系数,返回C是列向量,长度为ab的长度和减1a=a(:)

14、;b=b(:);M=length(a);maxlag=M-1;lags=-maxlag:maxlag;A=fft(a,2nextpow2(2*M-1);%快速傅立叶变换B=fft(b,2nextpow2(2*M-1);c=ifft(A.*conj(B);%快速傅立叶反变换 c=c(end-maxlag+1:end,1);c(1:maxlag+1,1); nr nc=size(a);if(nrnc) c=c; lags=lags.;end returnfunction BER_MC=MCQPSKrun(N,Eb,N0,ChanAtt,TimingBias,TimingJitter,PhaseBi

15、as,PhaseJitter) fs=1e+6; % 采样速率SymRate=1e+5; % 信号速率Ts=1/fs; % 采样周期TSym=1/SymRate; % 信号周期SymToSend=N; % 发送信号数ChanBW=4.99e+5; % 带宽MeanCarrierPhaseError=PhaseBias; % 载波相位均值StdCarrierPhaseError=PhaseJitter; % 相位误差标准差MeanSymbolSyncError=TimingBias; % 符号同步误差均值StdSymbolSyncError=TimingJitter; % 符号同步误差标准差Ch

16、anGain=10(-ChanAtt/20); % 信道增益TxBitClock=Ts/2; % 发送机时钟RxBitClock=Ts/2; % 接收机时钟 %接收机输入端噪声标准差和信号幅度 RxNoiseStd=sqrt(10(N0-30)/10)*(fs/2);TxSigAmp=sqrt(10(Eb-30)/10)*SymRate); %分配缓存 SampPerSym=fs/SymRate;probe1=zeros(SymToSend+1)*SampPerSym,1);probe1counter=1;probe2=zeros(SymToSend+1)*SampPerSym,1);prob

17、e2counter=1; %计已传输信号的个数 TxSymSent=1;RxSymDemod=0; %发送和接收数据缓冲区unused,SourceBitsI=random_binary(SymToSend,1);unused,SourceBitsQ=random_binary(SymToSend,1); %差分编码TxBitsI=SourceBitsI*0;TxBitsQ=SourceBitsQ*0;for k=2:length(TxBitsI) TxBitsI(k)=or(and(not(xor(SourceBitsI(k),SourceBitsQ(k),xor(SourceBitsI(k

18、),TxBitsI(k-1),and(xor(SourceBitsI(k),SourceBitsQ(k),xor(SourceBitsQ(k),TxBitsQ(k-1); TxBitsQ(k)=or(and(not(xor(SourceBitsI(k),SourceBitsQ(k),xor(SourceBitsQ(k),TxBitsQ(k-1),and(xor(SourceBitsI(k),SourceBitsQ(k),xor(SourceBitsI(k),TxBitsI(k-1);end % 产生复信号 TxBits=(TxBitsI*2)-1)+(sqrt(-1)*(TxBitsQ*2)-

19、1); RxIntegrator=0; %初始化接收机积分器TxBitClock=2*TSym; %初始化发送机 %设计信道滤波器,产生滤波器参数序列b,a=butter(2,ChanBW/(fs/2);b=1;a=1;junk,FilterState=filter(b,a,0); % 开始仿真循环 while TxSymSentTSym TxSymSent=TxSymSent+1; TxBitClock=mod(TxBitClock,TSym); TxOutput=TxBits(TxSymSent)*TxSigAmp; end %信号经过信道滤波器 Rx,FilterState=filter

20、(b,a,TxOutput,FilterState); %加高斯白噪声 Rx=(ChanGain*Rx)+(RxNoiseStd*(randn(1,1)+sqrt(-1)*randn(1,1); %基于接收机载波同步误差的相位旋转 PhaseRotation=exp(sqrt(-1)*2*pi*(MeanCarrierPhaseError+(randn(1,1)*StdCarrierPhaseError)/360); Rx=Rx*PhaseRotation; probe1(probe1counter)=Rx; probe1counter= probe1counter+1; %更新接收机积分清除

21、器 RxIntegrator=RxIntegrator+Rx; probe2(probe2counter)=RxIntegrator; probe2counter= probe2counter+1; %更新接收机时钟,判断是不是适合采样 RxBitClock=RxBitClock+Ts; RxTSym=TSym*(1+MeanSymbolSyncError+(StdSymbolSyncError*randn(1,1); if RxBitClockRxTSym %解调信号 RxSymDemod=RxSymDemod+1; RxBitsI(RxSymDemod)=round(sign(real(R

22、xIntegrator)+1)/2; RxBitsQ(RxSymDemod)=round(sign(imag(RxIntegrator)+1)/2; RxBitClock=RxBitClock-TSym; RxIntegrator=0; endend% 差分解码SinkBitsI=SourceBitsI*0;SinkBitsQ=SourceBitsQ*0; for k=2:RxSymDemod SinkBitsI(k)=or(and(not(xor(RxBitsI(k),RxBitsQ(k),xor(RxBitsI(k),RxBitsI(k-1),and(xor(RxBitsI(k),RxBi

23、tsQ(k),xor(RxBitsQ(k),RxBitsQ(k-1); SinkBitsQ(k)=or(and(not(xor(RxBitsI(k),RxBitsQ(k),xor(RxBitsQ(k),RxBitsQ(k-1),and(xor(RxBitsI(k),RxBitsQ(k),xor(RxBitsI(k),RxBitsI(k-1);end %在输入和输出100字节中寻找最佳时延C,Lags=vxcorr(SourceBitsI(10:110),SinkBitsI(10:110);MaxC,LocMaxC=max(C);BestLag=Lags(LocMaxC);% 调整时延if Be

24、stLag0 SourceBitsI=SourceBitsI(BestLag+1:length(SourceBitsI); SourceBitsQ=SourceBitsQ(BestLag+1:length(SourceBitsQ);elseif BestLag0 SinkBitsI=SinkBitsI(-BestLag+1:length(SinkBitsI); SinkBitsQ=SinkBitsQ(-BestLag+1:length(SinkBitsQ);end% 将序列调整成相同长度TotalBits=min(length(SourceBitsI),length(SinkBitsI);To

25、talBits=TotalBits-20;SourceBitsI=SourceBitsI(10:TotalBits);SourceBitsQ=SourceBitsQ(10:TotalBits);SinkBitsI=SinkBitsI(10:TotalBits);SinkBitsQ=SinkBitsQ(10:TotalBits); Errors=sum(SourceBitsI = SinkBitsI)+sum(SourceBitsQ = SinkBitsQ);BER_MC=Errors/(2*length(SourceBitsI); returnfunction MCQPSKBER Eb=22:

26、0.5:26;N0=-50;ChannelAttenuation=70;EbN0dB=(Eb-ChannelAttenuation)-N0;EbN0=10.(EbN0dB./10);BER_T=0.5*erfc(sqrt(EbN0);N=round(100./BER_T);BER_MC=zeros(size(Eb);for k=1:length(Eb) BER_MC(k)=MCQPSKrun(N(k),Eb(k),N0,ChannelAttenuation,0,0,0,0); disp(simulation,num2str(k*100/length(Eb),%complate);end fig

27、ure(1);semilogy(EbN0dB,BER_MC,o,EbN0dB,2*BER_T,-);xlabel(Eb/N0(dB);ylabel(bit error rate);legend(MC BER Estimate,Theoretical BER);grid; return代码3function peideal,pesystem=qpsk_berest(xx,yy,ebn0db,eb,tb,nbw)%xx为输入序列,yy为输出序列,ebn0db为信噪比,eb为单个信号能力,tb信号周期,nbw噪声带宽n1 n2=size(xx);nx=n1*n2;n3 n4=size(yy);ny=

28、n3*n4;n5 n6=size(ebn0db);neb=n5*n6;%接收机带宽设定为rs/2nbwideal=1/(2*tb*2);for m=1:neb peideal(m)=0.0; % 初始化 pesystem(m)=0.0; % 初始化%计算n0和噪声方差 string1=Eb/N0=,num2str(ebn0db(m); disp(string1) ebn0(m)=10(ebn0db(m)/10); n0=eb/ebn0(m); % 噪声功率 sigma=sqrt(n0*nbw*2); % 方差 sigma1=sqrt(n0*nbwideal*2); % 理想方差 b=sqrt(

29、2*eb/tb)/sqrt(sum(abs(xx).2)/nx); for n=1:nx theta=angle(xx(n); if(theta0) theta=theta+2*pi; end%接收信号的相位旋转 xxx(n)=b*xx(n)*exp(-i*(theta-(pi/4); yyy(n)=yy(n)*exp(-i*(theta-(pi/4); d1=real(xxx(n); d2=imag(xxx(n); d3=real(yyy(n); d4=imag(yyy(n); pe1=q(d1/sigma1)+q(d2/sigma1); pe2=q(d3/sigma)+q(d4/sigma); peideal(m)=peideal(m)+pe1; pesystem(m)=pesystem(m)+pe2; endend peideal=(1/2)*peideal./nx;pesystem=(1/2)*pesystem./nx; returnfunction QPSKThreeray(p0,p1,p2,delay)NN=256; %发送的信号数tb=0.5; %信号周期fs=16; %每信号的采样数ebn0db=1:2:14; %信噪比矢量%产生QPSK信号x=random_binary(NN,fs)+i*rando

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1