您好,欢迎访问三七文档
当前位置:首页 > 电子/通信 > 综合/其它 > 实验五-CDMA原理的matlab仿真
实验二CDMA原理的程序仿真实验目的:了解3G移动通信网中关键技术CDMA的实现原理掌握matlab编程,实现CDMA原理仿真实验要求:掌握CDMA原理掌握matlab语言对于码分复用技术仿真的功能实验场景:现有8个用户,通过信令两两建立连接通道,分别为发送方A、B、C、D,对应的接收方为A’、B’、C’、D’,A和A’的通信内容为-1,B和B’的通信内容为-1,C和C’的通信内容为1,D和D’的通信内容为1。系统内具备以下条件:A和A’通信的正交码为H1:1111B和B’通信的正交码为H2:1-11-1C和C’通信的正交码为H3:11-1-1D和D’通信的正交码为H4:1-1-11H1~H4具有正交性,比如[1111]和[1-11-1]向量乘一下,为0,每两个不同的向量都这样,只有本身相乘是有值的。发送过程信道ABCD-1-111相乘-1,-1,-1,-11,1,1,11111码数据1-11-111-1-11-1-11-1,-1,-1,-1-1,-1,-1,-11,-1,1,-1-1,1,-1,11,1,1,11,1,-1,-11,1,-1,-11,1,1,11,-1,-1,11,-1,-1,10,0,-4,0扩展相加每一个人对接收到的数据用自己的码进行译码,得到不同的结果,和发送的数据相同。也就是说拥有不同的码,即使在同频率下相互干扰,信号叠加在一起,也能正确的得到各自想要的信息,这样很多人的都可以使用相同的频率,大大增加了通信容量实验参考知识:(1)哈达马正交矩阵方法为:hadamard(n)例如:运行hadamard(4),得到4*4矩阵:[1111;1-11-1;1-1-1;1-1-11](2)整体代码%发送部分d_o=round(rand(1,4))';d=2*d_o-1;%发送数据a-a':-1,b-b':-1...%正交码阵H=[1111;1-11-1;11-1-1;1-1-11]H=hadamard(4);d_t=repmat(d,1,4);%扩展数据c_t=H.*d_t;%对应相乘c=sum(c_t);%形成码字%接收部分c_r=repmat(c,4,1).*H;%码字e=mean(c_r,2);%接受数据figure(1)%显示发送和接受数据,比较是否相同subplot(2,1,1);stem(d);subplot(2,1,2);stem(e);任务:(1)修改发送数据,运行程序,观察发送数据和接受数据是否相同;给出过程。A’B’C’D’1111码1-11-111-1-11-1-110,0,-4,00,0,-4,00,0,-4,00,0,4,00,0,4,0平均-1-111接收过程相乘数据(2)将人数扩展到16人,两队8人对应通信,修改代码,完成这个任。%发送部分d_o=round(rand(1,8))';d=2*d_o-1;%发送数据a-a':-1,b-b':-1...%正交码阵H=[1111;1-11-1;11-1-1;1-1-11]H=hadamard(8);d_t=repmat(d,1,8);%扩展数据c_t=H.*d_t;%对应相乘c=sum(c_t);%形成码字%接收部分c_r=repmat(c,8,1).*H;%码字e=mean(c_r,2);%接受数据figure(1)%显示发送和接受数据,比较是否相同subplot(2,1,1);stem(d);subplot(2,1,2);stem(e);(3)完成任务2后,现在每对用户要通信5个数据,请完成这个任务,并检查发送数据序列和接受序列是否相同。fori=1:5%发送部分d_o=round(rand(1,4))';d=2*d_o-1;%发送数据a-a':-1,b-b':-1...%正交码阵H=[1111;1-11-1;11-1-1;1-1-11]H=hadamard(4);d_t=repmat(d,1,4);%扩展数据c_t=H.*d_t;%对应相乘c=sum(c_t);%形成码字%接收部分c_r=repmat(c,4,1).*H;%码字e=mean(c_r,2);%接受数据A(:,i)=d;B(:,i)=e;endfigure(1)%显示发送和接受数据,比较是否相同subplot(2,1,1);stem(d);subplot(2,1,2);stem(e);AA=-1-1-1-11-1-1-1111-1-1-1-1-111-11BB=-1-1-1-11-1-1-1111-1-1-1-1-111-11
本文标题:实验五-CDMA原理的matlab仿真
链接地址:https://www.777doc.com/doc-7194189 .html