DS_CDMA 仿真源程序.doc_第1页
DS_CDMA 仿真源程序.doc_第2页
DS_CDMA 仿真源程序.doc_第3页
DS_CDMA 仿真源程序.doc_第4页
DS_CDMA 仿真源程序.doc_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

% main_DSCDMA.m% 这个仿真程序用于实现DS-CDMA通信系统仿真 % %+准备部分+ clear all;clc sr = 256000.0; % 符号速率ml = 2; % 调制阶数 br = sr * ml; % 比特速率 nd = 100; % 符号数SNR=-5:1:10; % Eb/No %+ %+滤波器初值设定+ irfn = 21; % 滤波器阶数IPOINT = 8; % 过采样倍数alfs = 0.5; % 滚降因子xh = hrollfcoef(irfn,IPOINT,sr,alfs,1); xh2 = hrollfcoef(irfn,IPOINT,sr,alfs,0); %+ %+扩频码初值设定+ user = 1; % 用户数seq = 1; % 1:m序列 2:Gold序列 3:正交Gold序列 stage = 3; % 序列阶数 ptap1 = 1 3; % 第一个线性移位寄存器的系数ptap2 = 2 3; % 第二个线性移位寄存器的系数regi1 = 1 1 1; % 第一个线性移位寄存器的初始化regi2 = 1 1 1; % 第二个线性移位寄存器的初始化%+disp(-start-);%+扩频码的产生+ for ebn0=-5:1:10switch seq case 1 % m序列 code = mseq(stage,ptap1,regi1,user); case 2 % Gold序列 m1 = mseq(stage,ptap1,regi1); m2 = mseq(stage,ptap2,regi2); code = goldseq(m1,m2,user); case 3 % 正交Gold序列 m1 = mseq(stage,ptap1,regi1); m2 = mseq(stage,ptap2,regi2); code = goldseq(m1,m2,user),zeros(user,1); end code = code * 2 - 1; clen = length(code); %+ %+信道衰减初值设定+ rfade = 0; % 瑞利衰减 0:不考虑 1:考虑itau = 0,8; % 延时 dlvl1 = 0.0,40.0; % 衰减电平n0 = 6,7; % 用于产生衰落的波数th1 = 0.0,0.0; % 延迟波形的初始相位itnd1 = 3001,4004; % 设置衰落计数now1 = 2; % 主径和延迟波形总数tstp = 1 / sr / IPOINT / clen; % 时间分辨率fd = 160; % 多普勒频移Hz flat = 1; % 平坦瑞利衰落环境itndel = nd * IPOINT * clen * 30; %+%+仿真运算开始+ nloop = 1000; % 仿真循环次数noe = 0; nod = 0; for ii=1:nloop %+ %+发射机+ data = rand(user,nd*ml) 0.5; ich, qch = qpskmod(data,user,nd,ml); % QPSK 调制 ich1,qch1 = spread(ich,qch,code); % 扩频 ich2,qch2 = compoversamp2(ich1,qch1,IPOINT); % 过采样 ich3,qch3 = compconv2(ich2,qch2,xh); % 滤波 if user = 1 ich4 = ich3; qch4 = qch3; else ich4 = sum(ich3); qch4 = sum(qch3); end %+ %+衰减信道+ if rfade = 0 ich5 = ich4; qch5 = qch4; else ich5,qch5 = sefade(ich4,qch4,itau,dlvl1,th1,n0,itnd1, . now1,length(ich4),tstp,fd,flat); itnd1 = itnd1 + itndel; end %+ %+接收机+ spow = sum(rot90(ich3.2 + qch3.2) / nd; % 衰减计算 attn = sqrt(0.5 * spow * sr / br * 10(-ebn0/10); ich6,qch6 = comb2(ich5,qch5,attn); % 添加高斯白噪声(AWGN) ich7,qch7 = compconv2(ich6,qch6,xh2); % 滤波 sampl = irfn * IPOINT + 1; ich8 = ich7(:,sampl:IPOINT:IPOINT*nd*clen+sampl-1); qch8 = qch7(:,sampl:IPOINT:IPOINT*nd*clen+sampl-1); ich9 qch9 = despread(ich8,qch8,code); % 解扩 demodata = qpskdemod(ich9,qch9,user,nd,ml); % QPSK解调%+ %+误码率分析+ noe2 = sum(sum(abs(data-demodata); nod2 = user * nd * ml; noe = noe + noe2; nod = nod + nod2; % fprintf(%dt%en,ii,noe2/nod2); end %+ %+数据文件+ ber = noe / nod; fprintf(%dt%dt%dt%en,ebn0,noe,nod,noe/nod); fid = fopen(BER.dat,a); fprintf(fid,%dt%et%ft%ftn,ebn0,noe/nod,noe,nod); fclose(fid); err_rate_final(ebn0+6)=ber;end%+%+性能仿真图+ figuresemilogy(SNR,err_rate_final,b-*);xlabel(信噪比/dB)ylabel(误码率)axis(-5,10,0,1)grid ondisp(-end-); %+% *beginning of file*% hrollfcoef.m % % 此函数用于产生Nyquist滤波器的系数% function xh = hrollfcoef(irfn,ipoint,sr,alfs,ncc) %+variables+ % irfn 用于滤波的符号数 % ipoint 每个符号的抽样值数% sr 符号速率% alfs 衰减截止频率 % ncc 1 - 发送端滤波 0 - 接收端滤波 %+ xi=zeros(1,irfn*ipoint+1); xq=zeros(1,irfn*ipoint+1); point = ipoint; tr = sr ; tstp = 1.0 ./ tr ./ ipoint; n = ipoint .* irfn; mid = ( n ./ 2 ) + 1; sub1 = 4.0 .* alfs .* tr; for i = 1 : n icon = i - mid; ym = icon; if icon = 0.0 xt = (1.0-alfs+4.0.*alfs./pi).* tr; else sub2 =16.0.*alfs.*alfs.*ym.*ym./ipoint./ipoint; if sub2 = 1.0 x1=sin(pi*(1.0-alfs)/ipoint*ym)./pi./(1.0-sub2)./ym./tstp; x2=cos(pi*(1.0+alfs)/ipoint*ym)./pi.*sub1./(1.0-sub2); xt = x1 + x2; else xt = alfs.*tr.*(1.0-2.0/pi).*cos(pi/4.0/alfs)+(1.0+2.0./pi).*sin(pi/4.0/alfs)./sqrt(2.0); end end if ncc = 0 %当接收机情况 xh( i ) = xt ./ ipoint ./ tr; elseif ncc = 1 %当发射机情况 xh( i ) = xt ./ tr; else error(ncc error); end end %*end of file*% *beginning of file*% mseq.m % % 此函数产生m序列% % 试举一例: % stg = 3 % taps = 1 , 3 % inidata = 1 , 1 , 1 % n = 2 % function mout = mseq(stg, taps, inidata, n) %+variables+ % stg m序列阶数% taps 线性移位寄存器的系数% inidata 序列的初始化% n 输出序列的数目 % mout 输出的m序列%+ if nargin 1 for ii=2:n mout(ii,:) = shift(mout(ii-1,:),1,0); end end %*end of file*% *beginning of file*% shift.m % % 此函数用于实现线性移位寄存器的移位操作 % function outregi = shift(inregi,shiftr,shiftu) %+variables+ % inrege 向量或矩阵% shiftr 右移量 % shiftu 顶部移位量 % outregi 寄存器的输出%+h, v = size(inregi); outregi = inregi; shiftr = rem(shiftr,v); shiftu = rem(shiftu,h); if shiftr 0 outregi(:,1 :shiftr) = inregi(:,v-shiftr+1:v ); outregi(:,1+shiftr:v ) = inregi(:,1 :v-shiftr); elseif shiftr 0 outregi(1 :h-shiftu,:) = inregi(1+shiftu:h, :); outregi(h-shiftu+1:h, :) = inregi(1 :shiftu,:); elseif shiftu 0 outregi(1 :-shiftu,:) = inregi(h+shiftu+1:h, :); outregi(1-shiftu:h, :) = inregi(1 :h+shiftu,:); end %*end of file*% *beginning of file*% goldseq.m % %此函数用于产生gold序列% function gout = goldseq(m1, m2, n) %+variables+ % m1 第一个m序列% m2 第二个m序列 % n 输出序列的数目% gout 输出产生的gold序列%+ if nargin hc error(lack of spread code sequences); end iout = zeros(hn,vn*vc); qout = zeros(hn,vn*vc); for ii=1:hn iout(ii,:) = reshape(rot90(code1(ii,:),3)*idata(ii,:),1,vn*vc); qout(ii,:) = reshape(rot90(code1(ii,:),3)*qdata(ii,:),1,vn*vc); end %*end of file*% *beginning of file*% compoversamp2.m % % 此函数实现sample倍升采样% function iout,qout = compoversamp2(iin, qin, sample) %+variables+ % iin 输入序列实部% qin 输入序列虚部% iout 输出序列实部% qout 输出序列虚部 % sample 升采样的倍数%+ h,v = size(iin); iout = zeros(h,v*sample); qout = zeros(h,v*sample); iout(:,1:sample:1+sample*(v-1) = iin; qout(:,1:sample:1+sample*(v-1) = qin; %*end of file*% *beginning of file*% compconv2.m % % 此函数用于实现有用信号的滤波% function iout, qout = compconv2(idata, qdata, filter) %+variables+ % idata 输入序列实部% qdata 输入序列虚部% iout 输出序列实部 % qout 输出序列虚部 % filter 滤波器的系数%+ iout = conv2(idata,filter); qout = conv2(qdata,filter); %*end of file*% *beginning of file*% sefade.m % % 此函数用于实现信道的频率选择性衰落设计% functioniout,qout,ramp,rcos,rsin=sefade(idata,qdata,itau,dlvl,th,n0,itn,n1,nsamp,tstp,fd,flat) %+variables+ % idata 输入的实部数据 % qdata 输入的虚部数据 % iout 输出的实部数据% qout 输出的虚部数据 % ramp 幅度衰减 % rcos 正交分量衰减% rsin 同相分量衰减 % itau 各径时延% dlvl 各多径衰减量% th 各多径初始相位 % n0 用于产生各径衰落的波数 % itn 各多径衰减计数 % n1 主径和各延迟波形总数 % nsamp 符号数 % tstp 最小时间分辨率 % fd 最大多普勒频移% flat 是否是平坦衰落 % (1-flat (只有幅度衰落),0-nomal(相位和幅度都衰落) %+ iout = zeros(1,nsamp); qout = zeros(1,nsamp); total_attn = sum(10 .( -1.0 .* dlvl ./ 10.0); for k = 1 : n1 atts = 10.( -0.05 .* dlvl(k); if dlvl(k) = 40.0 atts = 0.0; end theta = th(k) .* pi ./ 180.0; itmp,qtmp = delay ( idata , qdata , nsamp , itau(k); itmp3,qtmp3,ramp,rcos,rsin = fade (itmp,qtmp,nsamp,tstp,fd,n0(k),itn(k),flat); iout = iout + atts .* itmp3 ./ sqrt(total_attn); qout = qout + atts .* qtmp3 ./ sqrt(total_attn); end%*end of file*% *beginning of file*% delay.m% 此函数用以实现信号的延迟传输% function iout,qout = delay( idata, qdata , nsamp , idel )%+variables+ % idata 输入序列实部 % qdata 输入序列虚部 % iout 输出序列实部 % qout 输出序列虚部% nsamp 仿真的抽样值数量 % idel 延迟的抽样值数量%+iout=zeros(1,nsamp);qout=zeros(1,nsamp);if idel = 0 iout(1:idel) = zeros(1,idel); qout(1:idel) = zeros(1,idel);endiout(idel+1:nsamp) = idata(1:nsamp-idel);qout(idel+1:nsamp) = qdata(1:nsamp-idel);%*end of file*% *beginning of file*% fade.m % % 此函数实现信道的瑞利衰减设计% function iout,qout,ramp,rcos,rsin=fade(idata,qdata,nsamp,tstp,fd,no,counter,flat) %+variables+ % idata 输入序列实部 % qdata 输入序列虚部 % iout 输出序列实部 % qout 输出序列虚部 % ramp 幅度衰减 % rcos 正交分量衰减% rsin 同相分量衰减 % nsamp 符号数 % tstp 最小时间分辨率 % fd 最大多普勒频移 % no 用于产生衰落的波数 % counter 衰落计数 % flat 是否是平坦衰落 % (1-flat (只有幅度衰落),0-nomal(相位和幅度都衰落) %+ if fd = 0.0 ac0 = sqrt(1.0 ./ (2.0.*(no + 1); as0 = sqrt(1.0 ./ (2.0.*no); ic0 = counter; pai = 3.14159265; wm = 2.0.*pai.*fd; n = 4.*no + 2; ts = tstp; wmts = wm.*ts; paino = pai./no; xc=zeros(1,nsamp); xs=zeros(1,nsamp); ic=1:nsamp+ic0; for nn = 1: no cwn = cos( cos(2.0.*pai.*nn./n).*ic.*wmts ); xc = xc + cos(paino.*nn).*cwn; xs = xs + sin(paino.*nn).*cwn; end cwmt = sqrt(2.0).*cos(ic.*wmts); xc = (2.0.*xc + cwmt).*ac0; xs = 2.0.*xs.*as0; ramp=sqrt(xc.2+xs.2); rcos=xc./ramp; rsin=xs./ramp; if flat =1 iout = sqrt(xc.2+xs.2).*idata(1:nsamp); qout = sqrt(xc.2+xs.2).*qdata(1:nsamp); else iout = xc.*idata(1:nsamp) - xs.*qdata(1:nsamp); qout = xs.*idata(1:nsamp) + xc.*qdata(1:nsamp); end else iout=idata; qout=qdata; end %*end of file*% *beginning of file*% comb2.m % % 此函数实现信道的高斯白噪声% function iout, qout = comb2(idata, qdata, attn) %+variables+% idata 输入序列实部% qdata 输入序列虚部 % iout 输出序列实部 % qout 输出序列虚部% attn 根据信噪比得到的信号衰减水平 %+ v = length(idata); h = length(attn); iout = zeros(h,v); qout = zeros(h,v); for ii=1:h iout(ii,:) = idata + randn(1,v) * attn(ii); qout(ii,:) = qdata + randn(1,v) * attn(ii); end %*end of file*% *beginning of file*% despread.m % % 此函数实现数据的解频% function iout, qout = despread(idata, qdata, code1) %+variables+ % idata 输入序列实部 % qdata 输入序列虚部 % iout 输出序列实部 % qout 输出序列虚部 % code1 扩频码序列% %+ switch nargin case 0 , 1 error(lack of input argument); case 2 code1 = qdata; qdata = idata; end hn,vn = size(idata); hc,vc = size(code1); vn = fix(vn/vc); iout = zeros(hc,vn); qout = zeros(hc,vn); for ii=1:hc iout(ii,:) = rot90(flipud(rot90(reshape(idata(ii

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论