当前位置:首页 » 《随便一记》 » 正文

基于MATLAB计算MIMO信道容量(附完整代码与分析)

13 人参与  2023年05月03日 09:21  分类 : 《随便一记》  评论

点击全文阅读


目录

一.介绍

二. 代码

三. 运行结果及分析

3.1  MIMO信道容量:固定发射天线数为4

3.2 MIMO信道容量:固定接收天线数为4

3.3 AWGN信道与瑞利信道容量

四. 总结


一.介绍

本文章将在MATLAB环境中分析MIMO信道容量,AWGN信道容量,瑞利信道容量和Alamouti码(空时块码)信道容量。

AWGN: Additive White Gaussian Noise 加性高斯白噪声

有关MIMO信道容量的具体解释,可参看此文章:

MIMO系统信道容量分析_mimo信道容量_唠嗑!的博客-CSDN博客

​​​​​​​

 

二. 代码

本节代码包含一个主运行文件;四个计算信道容量文件;两个函数文件

(1)main.m文件

主运行文件

clear;clc;close all;%--------------Main--------------%c_3d = zeros(10,10);%--------------接收天线变化--------------%N = 4;%发射天线cap = zeros(1,20);%SNR为5dBSNR = 5; %SNR in dBfor i = 1:1:20    cap(1,i) = mimo_capacity(N,i,SNR);endfigureplot(1:1:20,cap,'b')title('发射天线数目为4的情况')xlabel('接收天线数目')ylabel('信道容量 bits/s/Hz')hold on%SNR为10dBSNR = 10;for i = 1:1:20    cap(1,i) = mimo_capacity(N,i,SNR);end%figureplot(1:1:20,cap,'r')hold on%SNR为15dBSNR = 15;for i = 1:1:20    cap(1,i) = mimo_capacity(N,i,SNR);end%figureplot(1:1:20,cap,'g')hold onSNR = 20;for i = 1:1:20    cap(1,i) = mimo_capacity(N,i,SNR);end%figureplot(1:1:20,cap,'m')legend('5db','10dB','15dB','20db')%--------------发射天线变化--------------%M = 4;%发射天线cap = zeros(1,20);%SNR为5dBSNR = 5; %SNR in dBfor i = 1:1:20    cap(1,i) = mimo_capacity(i,M,SNR);endfigureplot(1:1:20,cap,'b')title('接收天线数目为4的情况')xlabel('发射天线数目')ylabel('信道容量 bits/s/Hz')hold on%SNR为10dBSNR = 10;for i = 1:1:20    cap(1,i) = mimo_capacity(i,M,SNR);end%figureplot(1:1:20,cap,'r')hold on%SNR为15dBSNR = 15;for i = 1:1:20    cap(1,i) = mimo_capacity(i,M,SNR);endplot(1:1:20,cap,'g')hold onSNR = 20;for i = 1:1:20    cap(1,i) = mimo_capacity(i,M,SNR);end%figureplot(1:1:20,cap,'m')legend('5db','10dB','15dB','20db')%--------------三维图展示MIMO----------------%SNR = 15;for i = 1:1:10    for j = 1:1:10        c_3d(i,j) = mimo_capacity(i,j,SNR);    endendfiguremesh(1:1:10,1:1:10,c_3d)title('3-dimension visual')%---------------AWGN SISO信道--------------%cap_awgn = zeros(1,31);for SNR = -10:1:20    cap_awgn(1,SNR+11) = awgn_capacity(SNR);endfigureplot(1:1:31,cap_awgn)title('awgn信道容量')xlabel('SNR in dB')ylabel('信道容量 bits/s/Hz')%---------------Raly SISO信道--------------%c = zeros(1,31);for SNR = 0:1:30    c(1,SNR+1) = ralychannel(SNR);endfigureplot(1:1:31,c)title('瑞利信道容量')xlabel('SNR in dB')ylabel('信道容量 bits/s/Hz')%--------------Alamouti---------------%c = zeros(1,31);for SNR = 0:1:30    c(1,SNR+1) = alamouti(SNR);endfigureplot(1:1:31,c)title('Alamouti码 2发1收')xlabel('SNR in dB')ylabel('信道容量 bits/s/Hz')

(2)awgn_capacity.m文件

AWGN信道容量

function capacity = awgn_capacity(SNR)SNR_D = 10^(0.1*SNR);capacity = log2(1+SNR_D);end

(3)ralychannel.m文件

瑞利衰落信道容量

function capacity = ralychannel(SNR)h = raylrnd(1/sqrt(2),[1,1000000]);c = zeros(1,length(h));%SNR = 20;for i = 1:1:length(h)    c(1,i) = log2(1+h(1,i)*SNR);endcapacity = mean(c);end

(4)mimo_capacity.m文件

MIMO信道容量

function cap = mimo_capacity(N,M,SNR)SNR_D = 10^(SNR*0.1); %SNR in decimalC = zeros(1,3000);for i = 1:1:3000    H = generate_channel_matrix(N,M);    [U,S,V] = svd(H);    d = diag(S);    C_temp = zeros(1,length(d));    for j = 1:1:length(d)        C_temp(1,j) = log2(1+d(j,1)^2*SNR_D/N);    end    C(1,i) = sum(C_temp);endcap = mean(C);

(5)generate_channel_matrix.m文件

产生信道矩阵的文件

function H = generate_channel_matrix(N,M)%N:发射天线个数%M:接收天线个数H = raylrnd(1/sqrt(2),M,N);end

(6)demo.m

实验文件

c = zeros(1,31);for SNR = 0:1:30    c(1,SNR+1) = alamouti(SNR);endplot(1:1:31,c)

三. 运行结果及分析

代码运行后一共有六个图,其中一个3D图,没什么好解释的,这里省去。重点分析其他五个跟信道容量相关的图。

3.1  MIMO信道容量:固定发射天线数为4

横向对比:当接收天线数增加时,信道容量整体呈现增加趋势;拆分对比:固定发射天线数为4,接收天线数从1-4增加,信道容量显著增加。接收天线数继续增加时,信道容量增加的趋势相对降低;纵向对比:同一组收发天线数时,当信噪比从5dB,10dB,15dB,20dB不断增加时,信道容量也会增加。

3.2 MIMO信道容量:固定接收天线数为4

横向对比 :当接收天线数增加时,信道容量整体呈现增加趋势; • 拆分对比 :固定发射天线数为 4 ,接收天线数从 1-4 增加,信道容量显著增加。接收天线数继续增加时,信道容量增加的趋势相对降低; • 纵向对比 :同一组收发天线数时,当信噪比从 5dB,10dB,15dB,20dB 不断增加时,信道容量也会增加。 • 区别性:固定接收天线数为4,当发射天线数超过4以后,信道容量增加的幅度相比前一个3.1更加缓慢(图形更加接近一条水平线); • 解释 :该模拟信道环境下,接收天线相比发射天线变化,对信道容量的影响稍微大一些;

3.3 AWGN信道与瑞利信道容量

普通的AWGN信道模型

• 单收发天线; • 当信噪比 SNR 从 1 增加到 31dB 时,信道容量也从 0.1375 增加到 6.658 bits/s/Hz 。

普通的瑞利信道模型

• 单收发天线; • 当信噪比 SNR 从 1 增加到 31dB 时,信道容量也从 0 增加到 4.57 bits/s/Hz 。 在该模拟环境下,同一个SNR信噪比下,AWGN信道容量更高,AWGN信道模型优于瑞利信道模型。 3.4 空时编码信道容量
 

空时编码分为空时块码空时格码。哈佛大学教授Tarokh率先提出空时格码,结构复杂度很高。随后Alamouti提出空时块码,结构复杂度很低,但却性能也更好,该文章也被评为近50年最优秀的57篇文章之一,极大影响了MIMO技术。

空时块码(Alamouti 码):

• 2 根发射天线, 1 根接收天线的 MIMO (最简单的空时块码模型); • 当信噪比 SNR 从 1 增加到 31dB 时,信道容量也从 0.9261 增加到 9.55 bits/s/Hz; • 空时块码信道模型优于 AWGN 和瑞利信道模型。

四. 总结

依据经典信息论, SISO 信道的自由度只有时间和频率两个维度, MIMO 引入多天线,扩展信道的自由度,包含时间、频率和空间三个维度,从而提升了 MIMO 的容量。

SISO:Single Input Single Output 单输入单输出系统


点击全文阅读


本文链接:http://m.zhangshiyu.com/post/60337.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1