matlab代码--基于注水法的MIMO信道容量实现

今天接触一个简单的注水法程序,搞懂数学原理即可看懂代码。

1 注水法简介

详细原理可以参考:
MIMO的信道容量以及实现
大致理论就是利用拉格朗日乘子法,求解信道容量的最大化问题,得到的解形如往水池中注水的形式,最后根据公式敲代码即可。

2 代码及结果

信道可以替换多种:
如常用的复高斯信道,正交信道,对角信道,获得相应的特征值进行信道容量计算

1 正交信道
B=randn(Nt,Nt)+i*randn(Nt,Nt); %产生信道
h1=orth(B); %获得正交信道
lambda = sort(eig(h1*h1'),'descend')'; %信道降序排序

2 对角信道
h_v = 1/sqrt(2)*(randn(1,Nt)+1j*randn(1,Nt)); %产生信道矩阵中对角线的值
h1 = diag(h_v,0); %产生对角信道矩阵
lambda = sort(eig(h1*h1'),'descend')'; %信道降序排序
3 常用的iid信道
h1 = 1/sqrt(2)*(randn(Nr(1),Nt(1))+1j*randn(Nr(1),Nt(1)));%添加iid信道
lambda = sort(eig(h1*h1'),'descend')'; %信道降序排序

完整仿真代码如下:

clc;
clear all;
close all;
Nr = 6; %接收天线
Nt = 6; %发送天线
snrdb = -5:1:10; %信噪比变化趋势,单位瓦特
snr = 10.^(snrdb/10); % 单位dB
Niterr = 1000; % 蒙特卡罗仿真次数
c = zeros(length(snr),1);%变量用于存储
mu = zeros(1,length(snr));%变量用于存储
p_opt = zeros(length(snr),2);%变量用于存储
for q =1:Niterr
h1 = 1/sqrt(2)*(randn(Nr(1),Nt(1))+1j*randn(Nr(1),Nt(1)));%添加iid信道
lambda = sort(eig(h1*h1'),'descend')'; %信道降序排序
for j = 1:length(snr)
%% 使用注水法
r = rank(h1);
    niter=0;
    while 1
        mu(j) = 1/(r-niter)*(1+1/snr(j)*sum(1./lambda(1:(r-niter))));  %功率门限值
        p_opt(j,1:(r-niter)) = mu(j)- 1./(snr(j)*lambda(1:(r-niter))); %注水法公式
    if abs(p_opt(j,:))== p_opt(j,:)
        break
    else
        p_opt(j,end-niter:end) = 0;        
        niter = niter+1;
    end
    end
    c(j,1) = c(j,1)+ sum(log2(1+snr(j)*p_opt(j,:).*lambda(1:rank(h1))));%信道容量公式
end
end
grid on;
plot(snrdb,c(:,1)/Niterr,'r-*');
xlabel('SNR(dB)');
ylabel('Channel Capacity (bits/sec)');
hold on;


%%%%%%%
clc;
Nr = 12; %接收天线
Nt = 12; %发送天线
snrdb = -5:1:10; %信噪比变化趋势,单位瓦特
snr = 10.^(snrdb/10); % 单位dB
Niterr = 1000; % 蒙特卡罗仿真次数
c = zeros(length(snr),1);%变量用于存储
mu = zeros(1,length(snr));%变量用于存储
p_opt = zeros(length(snr),2);%变量用于存储
for q =1:Niterr
h1 = 1/sqrt(2)*(randn(Nr(1),Nt(1))+1j*randn(Nr(1),Nt(1)));%添加复信道
lambda = sort(eig(h1*h1'),'descend')'; %信道降序排序
for j = 1:length(snr)
%% 使用注水法
r = rank(h1);
    niter=0;
    while 1
        mu(j) = 1/(r-niter)*(1+1/snr(j)*sum(1./lambda(1:(r-niter))));
        p_opt(j,1:(r-niter)) = mu(j)- 1./(snr(j)*lambda(1:(r-niter))); %注水法公式
    if abs(p_opt(j,:))== p_opt(j,:)
        break
    else
        p_opt(j,end-niter:end) = 0;        
        niter = niter+1;
    end
    end
    c(j,1) = c(j,1)+ sum(log2(1+snr(j)*p_opt(j,:).*lambda(1:rank(h1))));
end
end
grid on;
plot(snrdb,c(:,1)/Niterr,'k-s');
xlabel('SNR(dB)');
ylabel('Channel Capacity (bits/sec)');
hold on;

%%
clc;
Nr = 24; %接收天线
Nt = 24; %发送天线
snrdb = -5:1:10; %信噪比变化趋势,单位瓦特
snr = 10.^(snrdb/10); % 单位dB
Niterr = 1000; % 蒙特卡罗仿真次数
c = zeros(length(snr),1);%变量用于存储
mu = zeros(1,length(snr));%变量用于存储
p_opt = zeros(length(snr),2);%变量用于存储
for q =1:Niterr
h1 = 1/sqrt(2)*(randn(Nr(1),Nt(1))+1j*randn(Nr(1),Nt(1)));%添加复信道
lambda = sort(eig(h1*h1'),'descend')'; %信道降序排序
for j = 1:length(snr)
%% 使用注水法
r = rank(h1);
    niter=0;
    while 1
        mu(j) = 1/(r-niter)*(1+1/snr(j)*sum(1./lambda(1:(r-niter))));
        p_opt(j,1:(r-niter)) = mu(j)- 1./(snr(j)*lambda(1:(r-niter))); %注水法公式
    if abs(p_opt(j,:))== p_opt(j,:)
        break
    else
        p_opt(j,end-niter:end) = 0;        
        niter = niter+1;
    end
    end
    c(j,1) = c(j,1)+ sum(log2(1+snr(j)*p_opt(j,:).*lambda(1:rank(h1))));
end
end
%%画图 
grid on;
plot(snrdb,c(:,1)/Niterr,'g-o');
xlabel('SNR(dB)');
ylabel('Channel Capacity (bits/sec)');
hold on;
xticks([-5:1:10])
legend("Nt=6 Nr=6 MIMO", "Nt=12 Nr=12 MIMO", "Nt=24 Nr=24 MIMO")

在这里插入图片描述

可以看到,mimo技术可以提高信道容量。初次接触的朋友可以关注下蒙特卡洛仿真的写法(即为了克服信道每次的随机性,多次计算取平均)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/394090.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

RCS系统之:冲突解决

在RCS系统中,避免碰撞是至关重要的。以下是一些常见的方法和技术用于避免碰撞: 障碍物检测:机器人可以配备各种传感器,如激光雷达、超声波传感器、摄像头等,用于检测周围的障碍物和环境。通过实时监测周围情况&#xf…

32、IO/对文件读写操作相关练习20240218

一、使用fgets统计给定文件的行数 代码&#xff1a; #include<stdlib.h> #include<string.h> #include<stdio.h>int main(int argc, const char *argv[]) {FILE *fpNULL;if((fpfopen("./1.txt","r"))NULL)//只读形式打开1.txt文件{per…

【算法学习】简单多状态-动态规划

前言 本篇博客记录动态规划中的简单多状态问题。 在之前的动态规划类型的题中&#xff0c;我们每次分析的都只是一种或者某一类的状态&#xff0c;定义的dp表也是围绕着一种状态来的。 现在可能对于一种状态&#xff0c;存在几种不同的子状态&#xff0c;在状态转移过程中相互影…

面试经验分享 | 通关某公司面试靶场

本文由掌控安全学院 - 冰封小天堂 投稿 0x00:探测IP 首先打开时候长这个样&#xff0c;一开始感觉是迷惑行为&#xff0c;试了试/admin&#xff0c;/login这些发现都没有 随后F12查看网络&#xff0c;看到几个js文件带有传参&#xff0c;就丢sqlmap跑了一下无果 随后也反查了…

网络模型及传输基本流程

1.OSI 七层模型 OSI &#xff08; Open System Interconnection &#xff0c;开放系统互连&#xff09;七层网络模型称为开放式系统互联参考模型&#xff0c;是一个逻辑上的定义和规范; 把网络从逻辑上分为了 7 层 . 每一层都有相关、相对应的物理设备&#xff0c;比如路由器…

【C语言】Debian安装并编译内核源码

在Debian 10中安装并编译内核源码的过程如下&#xff1a; 1. 安装依赖包 首先需要确保有足够的权限来安装包。为了编译内核&#xff0c;需要有一些基础的工具和库。 sudo apt update sudo apt upgrade sudo apt install build-essential libncurses-dev bison flex libssl-d…

【分享】windows11 vmware centos7 搭建k8s完整实验

概述 开年第一天&#xff0c;补充下自己的技术栈。 参考文章: k8s安装 - 知乎 【Kubernetes部署篇】K8s图形化管理工具Dasboard部署及使用_k8s可视化管理工具-CSDN博客 centos7环境下安装k8s 1.18.0版本带dashboard界面全记录&#xff08;纯命令版&#xff09;_sysconfig1.…

Keras可以使用的现有模型

官网&#xff1a;https://keras.io/api/applications/ 一些使用的列子&#xff1a; ResNet50&#xff1a;分类预测 import keras from keras.applications.resnet50 import ResNet50 from keras.applications.resnet50 import preprocess_input, decode_predictions import nu…

基于scrapy框架的单机爬虫与分布式爬虫

我们知道&#xff0c;对于scrapy框架来说&#xff0c;不仅可以单机构建复杂的爬虫项目&#xff0c;还可以通过简单的修改&#xff0c;将单机版爬虫改为分布式的&#xff0c;大大提高爬取效率。下面我就以一个简单的爬虫案例&#xff0c;介绍一下如何构建一个单机版的爬虫&#…

修改vue-layer中title

左侧目录树点击时同步目录树名称 试了很多方法 layer.title(新标题&#xff0c;index)不知道为啥不行 最后用了获取html树来修改了 watch: {$store.state.nowTreePath: function(newVal, oldVal) {if (document.querySelectorAll(".lv-title") && document.q…

AD高速板常见问题和过流自锁

可以使用电机减速器来增大电机的扭矩&#xff0c;低速运行的步进电机更要加上减速机 减速电机就是普通电机加上了减速箱&#xff0c;这样便降低了转速增大了扭矩 HDMI布线要求&#xff1a; 如要蛇形使其等长&#xff0c;不要在HDMI的一端绕线。 HDMI走线时两边拉线&#xff0…

见智未来:数据可视化引领智慧城市之潮

在数字时代的浪潮中&#xff0c;数据可视化崭露头角&#xff0c;为打造智慧城市注入了强大的活力。不再被深奥的数据所束缚&#xff0c;我们通过数据可视化这一工具&#xff0c;可以更加接近智慧城市的未来。下面我就以可视化从业者的角度来简单聊聊这个话题。 数据可视化首先为…

wps快速生成目录及页码设置(自备)

目录 第一步目录整理 标题格式设置 插入页码&#xff08;罗马和数字&#xff09; 目录生成&#xff08;从罗马尾页开始&#xff09; ​编辑目录格式修改 第一步目录整理 1罗马标题 2罗马标题1一级标题 1.1 二级标题 1.2二级标题2一级标题 2.1 二级标题 2.2二级标题3一级标…

HTML5+CSS3+JS小实例:锥形渐变彩虹按钮

实例:锥形渐变彩虹按钮 技术栈:HTML+CSS+JS 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /…

【ansible】认识ansible,了解常用的模块

目录 一、ansible是什么&#xff1f; 二、ansible的特点&#xff1f; 三、ansible与其他运维工具的对比 四、ansible的环境部署 第一步&#xff1a;配置主机清单 第二步&#xff1a;完成密钥对免密登录 五、ansible基于命令行完成常用的模块学习 模块1&#xff1a;comma…

huggingface库LocalTokenNotFoundError:需要提供token

今天刚开始学习huggingface&#xff0c;跑示例的时候出了不少错&#xff0c;在此记录一下&#xff1a; (gpu) F:\transformer\transformers\examples\pytorch\image-classification>.\run.bat Traceback (most recent call last):File "F:\transformer\transformers\e…

6.s081 学习实验记录(七)Multithreading

文章目录 一、Uthread: switching between threads简介提示实验代码实验结果 二、Using threads简介实验代码 三、Barrier简介实验代码实验结果 一、Uthread: switching between threads 简介 切换到 thread 分支 git fetchgit checkout threadmake clean 实现用户态线程的…

SHOT特征描述符、对应关系可视化以及ICP配准

一、SHOT特征描述符可视化 C #include <pcl/point_types.h> #include <pcl/point_cloud.h> #include <pcl/search/kdtree.h> #include <pcl/io/pcd_io.h> #include <pcl/features/normal_3d_omp.h>//使用OMP需要添加的头文件 #include <boo…

考完PMP如何让学习价值最大化?考PRINCE2!

01什么是PRINCE2 PRINCE2的全称是Project IN Controlled Environment。也就是受控环境下的项目管理&#xff0c;国际项目管理师认证&#xff0c;在国际上被称为王者认证。PRINCE2描述了如何以一种逻辑性的、有组织的方法&#xff0c;按照明确的步骤对项目进行管理。 95%以上全…

软件实例分享,酒店酒水寄存管理系统软件教程

软件实例分享&#xff0c;酒店酒水寄存管理系统软件教程 一、前言 以下软件教程以 佳易王酒水寄存管理系统软件V16.0为例说明 软件文件下载可以点击最下方官网卡片——软件下载——试用版软件下载 1、寄存的商品名称可以预先设置 2、寄存人可以使用手.机号识别 3、会员充值…