基于BP神经网络的16QAM解调算法matlab性能仿真

举报
简简单单做算法 发表于 2024/05/24 23:07:16 2024/05/24
【摘要】 1.算法运行效果图预览 2.算法运行软件版本MATLAB2022a 3.算法理论概述      16QAM(Quadrature Amplitude Modulation,正交幅度调制)是一种高效的数字调制技术,能够在相同的带宽内传输比传统调制方式更多的信息。解调是通信系统中从接收到的信号中恢复原始信息的关键步骤。基于BP(Back Propagation,反向传播)神经网络的16QAM解调...

1.算法运行效果图预览

1.jpeg

2.jpeg

3.jpeg

 

2.算法运行软件版本

MATLAB2022a

 

3.算法理论概述

      16QAMQuadrature Amplitude Modulation,正交幅度调制)是一种高效的数字调制技术,能够在相同的带宽内传输比传统调制方式更多的信息。解调是通信系统中从接收到的信号中恢复原始信息的关键步骤。基于BPBack Propagation,反向传播)神经网络的16QAM解调算法,是利用人工神经网络强大的非线性映射和学习能力,直接从接收到的复数信号中估计出发送的16QAM符号,具有良好的抗噪性能和灵活性。

 

      BP神经网络是一种多层前馈网络,它包括输入层、隐藏层和输出层。在解调16QAM信号的应用中,输入层接收接收到的复数信号样本,输出层则输出对应的最可能的16QAM符号估计。训练过程中,通过调整网络权重和偏置,使得网络输出尽可能接近实际的符号标签,以此达到解调的目的。

 

4.png

 

      训练阶段:利用大量已知的16QAM符号及其对应的接收信号样本,通过反向传播算法不断调整网络参数,直至网络输出误差收敛到一个可接受的范围。

 

      测试阶段:在训练完成后,将未参与训练的测试集信号输入网络,评估网络的解调性能,包括误码率(BER)、符号错误率(SER)等指标。

 

 

 

4.部分核心程序

% 第一部分:加载并可视化数据
 
real1 = [-3 -3 -3 -3 -1 -1 -1 -1 +3 +3 +3 +3 +1 +1 +1 +1]./sqrt(10);
imag1 = [-3 -1 +3 +1 -3 -1 +3 +1 -3 -1 +3 +1 -3 -1 +3 +1]./sqrt(10);
 
IQmap = real1'+sqrt(-1)*imag1';
 
for ij = 1:length(SNR)
    ij
    for j = 1:20
        signal= round(rand(1,60000));
        Stx   = Modulator(signal,K);  
        Srx   = awgn(Stx,SNR(ij),'measured');
..................................................................
        
        %为每个神经网络寻找最佳超参数组合
        [accuracy,yfit] = func_ANN_qpsk(Si, Sh, Nlabel, lambda, IQmap, SrxT, StxT, SrxV, StxV);
        err(ij,j)=1-accuracy/100;
    end
end
 
 
% 调用函数绘制星座图,展示数据的10%
func_constellation(Srx,Stx,0.5)  
 
figure;
semilogy(SNR,mean(err,2),'b-o');
grid on
xlabel('SNR');
ylabel('误码率');
legend('16QAM误码率');
 
 
figure
plot(yfit,'-r>',...
    'LineWidth',1,...
    'MarkerSize',6,...
    'MarkerEdgeColor','k',...
    'MarkerFaceColor',[0.9,0.9,0.0]);
xlabel('训练迭代次数');
ylabel('神经网络训练曲线');
【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。