毫米波MIMO系统中的空间稀疏预编码附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信       无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机 

⛄ 内容介绍

​在满足未来5G网络的容量要求方面,毫米波(mmWave)通信系统引起了极大的兴趣。毫米波系统的频率范围在30到300GHz之间,总共有大约250GHz的带宽可用。与微波信号相比,它们的路径损耗要多出几个数量级。幸运的是,毫米波频率的小波长使大量的天线元件可以部署在相同的外形尺寸中,从而提供高空间处理收益。带有多个数据流的波束成形,即所谓的预编码,可用于进一步提高毫米波的频谱效率。由于对高成本和复杂性的关注,对射频处理的关注有所增加。关于硬件限制的解决方案投射到双方的预编码和组合器的可行集上。在本文中,我们考虑了大型天线阵列和设计这种符合实际限制的系统。我们将该问题表述为稀疏重建问题,并使用众所周知的匹配追求算法来寻找接近最优无约束解决方案的解决方案。我们介绍了在中等和大型天线阵列、不同角度传播和集群环境中的性能。我们将我们的发现与波束转向方案和最佳无约束方案进行了比较。

⛄ 部分代码

clear all

snrValuesDB = -40:5:0; %in Figures

snrValues = 10.^(snrValuesDB./10);

tryNumber = 100; 

%% Fig3 Parameters

parameters_Fig3 = containers.Map('KeyType','char','ValueType','any');

parameters_Fig3("numberTransmitAntennas") = 64; % Number of transmit antennas

parameters_Fig3("numberRecieveAntennas") = 16; % Number of receive antennas

parameters_Fig3("numberDataStreams") = 1; % Number of data streams

parameters_Fig3("numberRFChains") = 4; % Number of RF chains for precoding and combining

parameters_Fig3("numberCluster") = 8; % Number of clusters

parameters_Fig3("numberRayPerCluster") = 10; % Number of rays per cluster

parameters_Fig3("angularSpread") = 7.5; % Angular spread of 7.5 degree

spectralEffOptimal = zeros(tryNumber,length(snrValues));

spectralEffHybrid = zeros(tryNumber,length(snrValues));

spectralEffBeam = zeros(tryNumber,length(snrValues));

for s = 1:length(snrValues)

    SNR = snrValues(s);

    for i = 1:tryNumber

        channel = ChannelGeneration(parameters_Fig3);

        tempObj = OptimalUnconstraint(SNR,channel);

        spectralEffOptimal(i,s) = tempObj.spectralEfficiency;

        tempObj = HybridSparsePrecoding(SNR,channel);

        spectralEffHybrid(i,s) = tempObj.spectralEfficiency;

        tempObj = BeamSteering(SNR,channel);

        spectralEffBeam(i,s) = tempObj.spectralEfficiency;

        

    end

end

% Averaging Tries

spectralEffOptimalSNR = mean(spectralEffOptimal,1); 

spectralEffHybridSNR = mean(spectralEffHybrid,1);

spectralEffBeamSNR = mean(spectralEffBeam,1); 

% figure(); 

hold on

l1 = plot(snrValuesDB,spectralEffOptimalSNR,'-s','Color',[0 0.5 0],'LineWidth',2.0,'MarkerSize',8.0);

l2 = plot(snrValuesDB,spectralEffHybridSNR,'-o','Color',[0 0.45 0.74],'LineWidth',2.0,'MarkerSize',8.0);hold on;

l3 = plot(snrValuesDB,spectralEffBeamSNR,'-d','Color',[0.85 0.33 0.1],'LineWidth',2.0,'MarkerSize',8.0);hold on;

%% Data stream

parameters_Fig3("numberDataStreams") = 2; % Number of data streams

spectralEffOptimal = zeros(tryNumber,length(snrValues));

spectralEffHybrid = zeros(tryNumber,length(snrValues));

for s = 1:length(snrValues)

    SNR = snrValues(s);

    for i = 1:tryNumber

        channel = ChannelGeneration(parameters_Fig3);

        tempObj = OptimalUnconstraint(SNR,channel);

        spectralEffOptimal(i,s) = tempObj.spectralEfficiency;

        tempObj = HybridSparsePrecoding(SNR,channel);

        spectralEffHybrid(i,s) = tempObj.spectralEfficiency;

        

    end

end

% Averaging Tries

spectralEffOptimalSNR = mean(spectralEffOptimal,1); 

spectralEffHybridSNR = mean(spectralEffHybrid,1);

spectralEffBeamSNR = mean(spectralEffBeam,1); 

% figure(); 

l4 = plot(snrValuesDB,spectralEffOptimalSNR,'-s','LineWidth',2.0,'MarkerSize',8.0);

l5 = plot(snrValuesDB,spectralEffHybridSNR,'-o','LineWidth',2.0,'MarkerSize',8.0);hold on;

legend([l1 l2 l3 l4 l5],'Optimal unconstrained precoding N_s = 1','Hybrid precoding and combining N_s = 1','Beam steering N_s = 1','Optimal unconstrained precoding N_s = 2','Hybrid precoding and combining N_s = 2','Location','northwest','FontSize',15);

xlabel("SNR (dB)",'FontSize', 20)

ylabel("Spectral Efficiency(bits/s/Hz)",'FontSize', 20)

⛄ 运行结果

⛄ 参考文献

O. E. Ayach, S. Rajagopal, S. Abu-Surra, Z. Pi and R. W. Heath, "Spatially Sparse Precoding in Millimeter Wave MIMO Systems," in IEEE Transactions on Wireless Communications, vol. 13, no. 3, pp. 1499-1513, March 2014, doi: 10.1109/TWC.2014.011714.130846.

⛳️ 完整代码

❤️部分理论引用网络文献,若有侵权联系博主删除

❤️ 关注我领取海量matlab电子书和数学建模资料

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MIMO (多输入多输出) 预编码算法在无线通信领域起着重要的作用,它利用多个天线进行信号的传输和接收,提高了无线通信系统的容量和可靠性。MATLAB 是一个常用的数学计算和科学编程工具,可以用来实现和分析MIMO预编码算法MIMO预编码算法的主要目标是通过优化发送矩阵的选择,使得接收端能够更好地恢复出发送的信号。预编码技术可以通过最小化误差、最大化信噪比或最小化发送功率等方式来实现。MATLAB提供了强大的矩阵和向量计算功能,可以方便地进行MIMO预编码算法的实现。 在MATLAB,可以使用矩阵运算和线性代数运算函数来实现MIMO预编码算法。首先,我们需要定义发送矩阵、接收矩阵和噪声矩阵。然后,使用预编码矩阵对发送矩阵进行变换,以便在接收端能够更好地恢复出原始信号。根据具体的预编码算法,可以使用MATLAB的矩阵运算函数,如乘法、转置等操作,来实现预编码的过程。 例如,当使用零预编码算法时,预编码矩阵的每个元素都为零。使用MATLAB,可以通过创建一个全零的矩阵来实现零预编码。另外,我们还可以使用MATLAB的奇异值分解函数来实现其他预编码算法,如ZF预编码和MMSE预编码等。 总之,MIMO预编码算法MATLAB的实现可以通过使用矩阵运算和线性代数运算函数来实现。MATLAB提供了丰富的工具和函数,可以方便地进行信号处理和矩阵计算,所以它是一个很好的工具来实现MIMO预编码算法

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

matlab科研助手

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值