m基于OFDM+QPSK和DNN深度学习信道估计的无线图像传输matlab仿真,输出误码率曲线,并用实际图片进行测试

简介: m基于OFDM+QPSK和DNN深度学习信道估计的无线图像传输matlab仿真,输出误码率曲线,并用实际图片进行测试

1.算法仿真效果
matlab2022a仿真结果如下:

75ae6cfbcde758ab104c94db55dc0bcf_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.jpg
2662a2fde973ef92b0036844c3987587_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.jpg
f05bb99ed027a3505ede1b921ad1994b_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.jpg
dc94a04661dc9d20130ebc0a9d92832d_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.jpg

2.算法涉及理论知识概要
基于OFDM+QPSK和DNN深度学习信道估计的无线图像传输"是一种无线通信系统,它利用正交频分复用(OFDM)和四相位偏移键控(QPSK)技术来传输图像数据,并借助深度神经网络(DNN)来进行信道估计,从而提高信号传输的可靠性和效率。

   OFDM是一种常用的多载波调制技术,它将高速数据流分为多个低速子载波,并使每个子载波之间正交,从而提高频谱利用率和抗干扰能力。QPSK是一种常见的调制方式,它将每两个比特映射为一个复数信号点,每个信号点对应四个相位(0°、90°、180°、270°)。无线图像传输系统由发送端和接收端组成。发送端将图像数据转换为比特流,然后采用QPSK调制和OFDM技术将比特流映射到不同的子载波上,生成OFDM符号序列。接收端接收OFDM符号序列,并利用DNN进行信道估计,根据估计得到的信道状态信息对接收信号进行解调和解调制,最终恢复出原始图像数据。

c08d2b0283a4c44e97cb2a1426ce1df0_watermark,size_14,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_20,type_ZmFuZ3poZW5naGVpdGk=.png

   DNN是一种深度学习模型,用于从接收信号中学习信道特征。DNN的输入是接收信号的采样值,输出是对应的信道状态信息。训练DNN需要使用已知信道状态信息的样本,通过梯度下降等优化算法来调整DNN的参数,使其能够准确地估计信道状态信息。 

实现过程

图像编码:将图像数据转换为比特流。

QPSK调制:将比特流映射为QPSK符号。

OFDM调制:将QPSK符号映射到不同的OFDM子载波上,生成OFDM符号序列。

信道传输:通过无线信道传输OFDM符号序列,引入噪声和衰落。

接收和采样:接收端对信号进行采样,得到接收信号的采样值。

DNN信道估计:使用已知信道状态信息的样本训练DNN模型,得到信道估计模型。

信道估计:利用DNN模型对接收信号进行信道估计,得到信道状态信息。

解调和解码:根据信道状态信息对接收信号进行解调和解码,恢复出原始图像数据。

3.MATLAB核心程序

clear;
close all;
warning off;
addpath 'func\'
Ttrain  = load('T_train.mat'); 

Ptrain2 = [];
Ttrain2 = [];

for i = 1
    for j = 1:1
        Ptrain = load(['P_train',num2str(i),'_',num2str(j),'.mat']);   
        Ptrain2 = [Ptrain2;Ptrain.Ch_feature  ];
        Ttrain2 = [Ttrain2;Ttrain.Ch_feature  ];
    end
end

%输入层权值和偏移值
WI     = rand(size(Ttrain2))/1000;
BI     = rand(size(Ttrain2))/1000;
%定义4个隐含层
W1     = rand(size(Ttrain2));
BI1    = rand(size(Ttrain2));
W2     = rand(size(Ttrain2)/2);
BI2    = rand(size(Ttrain2)/2);
%输出层
WO     = rand(size(Ttrain2)/2);
BO     = rand(size(Ttrain2)/2);
%学习率
Lr     = 0.0005;
%迭代次数
Iter   = 2000;

for  it = 1:Iter
     it
     %训练
     tmps1  = Ptrain2.*WI+BI;
     tmps2  = tmps1.*W1+BI1;  
     %激活的
     tmps2_ = [];
     tmps2_ = func_ReLu(tmps2);

     tmps3  = tmps2_(1:2:end,1:2:end).*W2+BI2; 
     tmps4  = tmps3.*WO+BO;             
     error  = (Ttrain2(1:2:end,1:2:end)-tmps4);

     %更新权值
     W1     = W1 + Lr*repmat(error,2,2);
     BI1    = BI1+ Lr*repmat(error,2,2);
     W2     = W2 + Lr*error;
     BI2    = BI2+ Lr*error;
     %输出层
     WO     = WO + Lr*error;
     BO     = BO + Lr*error;
     errors(it) = mean2(abs(error));
end

figure;
plot(errors,'b','linewidth',2);
grid on
xlabel('训练次数');
ylabel('训练误差');

save dl0.mat errors WI BI W1 BI1 W2 BI2 WO BO
相关文章
|
6天前
|
算法 5G 数据安全/隐私保护
大规模MIMO通信系统信道估计matlab性能仿真,对比LS,OMP,MOMP以及CoSaMP
本文介绍了大规模MIMO系统中的信道估计方法,包括最小二乘法(LS)、正交匹配追踪(OMP)、多正交匹配追踪(MOMP)和压缩感知算法CoSaMP。展示了MATLAB 2022a仿真的结果,验证了不同算法在信道估计中的表现。最小二乘法适用于非稀疏信道,而OMP、MOMP和CoSaMP更适合稀疏信道。MATLAB核心程序实现了这些算法并进行了性能对比。以下是部分
152 84
|
5天前
|
算法
基于GA遗传优化的TSP问题最优路线规划matlab仿真
本项目使用遗传算法(GA)解决旅行商问题(TSP),目标是在访问一系列城市后返回起点的最短路径。TSP属于NP-难问题,启发式方法尤其GA在此类问题上表现出色。项目在MATLAB 2022a中实现,通过编码、初始化种群、适应度评估、选择、交叉与变异等步骤,最终展示适应度收敛曲线及最优路径。
|
6天前
|
算法 BI Serverless
基于鱼群算法的散热片形状优化matlab仿真
本研究利用浴盆曲线模拟空隙外形,并通过鱼群算法(FSA)优化浴盆曲线参数,以获得最佳孔隙度值及对应的R值。FSA通过模拟鱼群的聚群、避障和觅食行为,实现高效全局搜索。具体步骤包括初始化鱼群、计算适应度值、更新位置及判断终止条件。最终确定散热片的最佳形状参数。仿真结果显示该方法能显著提高优化效率。相关代码使用MATLAB 2022a实现。
|
6天前
|
算法 数据可视化
基于SSA奇异谱分析算法的时间序列趋势线提取matlab仿真
奇异谱分析(SSA)是一种基于奇异值分解(SVD)和轨迹矩阵的非线性、非参数时间序列分析方法,适用于提取趋势、周期性和噪声成分。本项目使用MATLAB 2022a版本实现从强干扰序列中提取趋势线,并通过可视化展示了原时间序列与提取的趋势分量。代码实现了滑动窗口下的奇异值分解和分组重构,适用于非线性和非平稳时间序列分析。此方法在气候变化、金融市场和生物医学信号处理等领域有广泛应用。
|
5天前
|
监控 算法 数据安全/隐私保护
基于视觉工具箱和背景差法的行人检测,行走轨迹跟踪,人员行走习惯统计matlab仿真
该算法基于Matlab 2022a,利用视觉工具箱和背景差法实现行人检测与轨迹跟踪,通过构建背景模型(如GMM),对比当前帧与模型差异,识别运动物体并统计行走习惯,包括轨迹、速度及停留时间等特征。演示三维图中幅度越大代表更常走的路线。完整代码含中文注释及操作视频。
|
16天前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
18天前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
18天前
|
SQL Java 测试技术
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
|
20天前
|
XML Web App开发 数据挖掘
Postman接口测试工具全解析:功能、脚本编写及优缺点探讨
文章详细分析了Postman接口测试工具的功能、脚本编写、使用场景以及优缺点,强调了其在接口自动化测试中的强大能力,同时指出了其在性能分析方面的不足,并建议根据项目需求和个人偏好选择合适的接口测试工具。
29 1
|
2月前
|
存储
Postman 接口测试配置 Pre-request Script
Postman 接口测试配置 Pre-request Script
99 5
Postman 接口测试配置 Pre-request Script