目录

一、理论基础

二、核心程序

三、测试结果


一、理论基础

空间调制技术因其具备更高的数据传输效率、更高的频谱效率和更低的功率损耗而受到学术界和工业界的广泛关注。空间调制技术通过控制发射天线的激活状态传输附加的比特信息,从而实现在不增加无线通信资源的前提下提高通信的效率。另一方面,正交频分复用技术作为4g通信系统的关键技术之一,被广泛应用到各种通信协议和场景中。不幸的是正交频分复用技术存在峰均比过高的问题。单载波系统可以很好地解决峰均比问题,将空间调制技术应用到单载波系统是一种可行的方案。

 

 

多输入多输出(MIMO)的(ML)性能侦查作为低复杂度MIMO解码算法KSE被证明适用于超大规模集成电路(VLSI)并且能够支持软输出。进一步提出了改进的KSE(MKSE)译码算法提高软输出KSE的性能修改。此外,还提出了一种VLSI体系结构,用于这两种算法。有几个低复杂性和低功耗所提出的算法和VLSI中包含的特征建筑学提出的硬输出KSE解码器和软输出MKSE解码器是在0.35μ以及0.13 m CMOS技术。已实施的硬输出KSE芯片芯为5.76mm2,具有91K栅极。这个KSE解码吞吐量高达53.3Mb/s,核心功率在100 MHz时钟频率和2.8 V下消耗626 mW供给所实现的软输出MKSE芯片可以实现解码吞吐量超过100 Mb/s,0.56 mm2核心区和97K门。实施结果表明实现接近ML的性能和高检测是可行的4 4 16-QAM MIMO系统的吞吐量算法和具有合理复杂性的VLSI结构.

 

 

二、核心程序

…………………………………………………………..
%设置调制方式
Mode_Type1 = 4;
Mode_Map1 = [-(Mode_Type1-1):2:Mode_Type1-1];
Mode_Type2 = 16;
Mode_Map2 = [-(Mode_Type2-1):2:Mode_Type2-1];
Mode_Type3 = 64;
Mode_Map3 = [-(Mode_Type3-1):2:Mode_Type3-1];
Mode_Type4 = 256;
Mode_Map4 = [-(Mode_Type4-1):2:Mode_Type4-1];
Sim_EbN0 = [0:5:25];
Ntant = 4;
Nrant = 4;
Bers = zeros(1,length(Sim_EbN0));
K = 16;%14,5,12
Tj = [2000,1000,500,500,400,200];
for j = 1:length(Sim_EbN0)
Eb_N0 = Sim_EbN0(j);
sigma = 10^(-Eb_N0/20);
Nerr = 0;
Num = 0;
%根据误码率判决门限进行误码率统计
while Nerr <= Tj(j)
Nerr
%产生信道
Nt = Ntant;
Nr = Nrant;
H(1:Nt ,1:Nr) = randn(Nt ,Nr);
H(Nt+1:2*Nt,1:Nr) = randn(Nt ,Nr);
H(1:Nt ,Nr+1:2*Nr) =-H(Nt+1:2*Nt,1:Nr);
H(Nt+1:2*Nt,Nr+1:2*Nr) = H(1:Nt ,1:Nr);
H = 1/sqrt(2)*H;
%QR分解
[Q,R] = qr(H);
%产生噪声大小
N = sigma*randn(Nr*2,1);

SignalTx = [];
for jj = 1:Ntant
%发送信号
%四个天线,四种调制方法
SignalTx1 = Mode_Map1(unidrnd(Mode_Type1,2*Ntant/4,1))’;%天线1
SignalTx2 = Mode_Map2(unidrnd(Mode_Type2,2*Ntant/4,1))’;%天线2
SignalTx3 = Mode_Map3(unidrnd(Mode_Type3,2*Ntant/4,1))’;%天线3
SignalTx4 = Mode_Map4(unidrnd(Mode_Type4,2*Ntant/4,1))’;%天线4
if mod(Num,Ntant) == 0
SignalTx = [SignalTx;SignalTx1];
end
if mod(Num,Ntant) == 1
SignalTx = [SignalTx;SignalTx2];
end
if mod(Num,Ntant) == 2
SignalTx = [SignalTx;SignalTx3];
end
if mod(Num,Ntant) == 3
SignalTx = [SignalTx;SignalTx4];
end
end
%最后发送的信号
if mod(Num,Ntant) == 0
%接收信号
SignalRx = H*SignalTx + N;
%最终接收到的信号%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
NQ = Q’*N;
RN = R*SignalTx+NQ;
SignalRX_rec = func_KSE(R,RN,K,Mode_Map1,Mode_Type1);
end
%最后发送的信号
if mod(Num,Ntant) == 1
%接收信号
SignalRx = H*SignalTx + N;
%最终接收到的信号%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
NQ = Q’*N;
RN = R*SignalTx+NQ;
SignalRX_rec = func_KSE(R,RN,K,Mode_Map2,Mode_Type2);
end
%最后发送的信号
if mod(Num,Ntant) == 2
%接收信号
SignalRx = H*SignalTx + N;
%最终接收到的信号%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
NQ = Q’*N;
RN = R*SignalTx+NQ;
SignalRX_rec = func_KSE(R,RN,K,Mode_Map3,Mode_Type3);
end
%最后发送的信号
if mod(Num,Ntant) == 3
%接收信号
SignalRx = H*SignalTx + N;
%最终接收到的信号%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
NQ = Q’*N;
RN = R*SignalTx+NQ;
SignalRX_rec = func_KSE(R,RN,K,Mode_Map4,Mode_Type4);
end
%KSE
Nerr = Nerr + sum(SignalRX_rec(:,1)~=SignalTx);
Num = Num + 1;
end
Bers(j) = Nerr/Num/Ntant/2;
end
A01-100

三、测试结果

 

  a01-100

 

原文地址:http://www.cnblogs.com/matlabfpga/p/16905710.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性