Matlab信号处理——基于BP神经网络的调制信号分类与识别

2024-04-29 14:44

本文主要是介绍Matlab信号处理——基于BP神经网络的调制信号分类与识别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 信号生成

我们首先生成了包括8种调制方式的调制信号,具体为:

clc
clear
fc=1000; %载波频率
fs=5000; %采样速率
t0=10; %信号长度
fd=100; %符号速率
ts=1/fs; %采样周期
M=t0*fd; %码元个数
ti=1/fd; %码元间隔
N=ti/ts;
t=0:ts:t0;
titles = {'2ASK', '2FSK', '2PSK', '4ASK', '4FSK', '4PSK', '8PSK', '16QAM'}; % 标题数组
for i = 1:8y = signal(i, M, fc, t, N, fs); % 生成信号subplot(4, 2, i)plot(abs(fft(y))) % 生成信号频谱title(titles{i}) % 设置标题
end

 

2. 特征提取

对信号进行采样和处理,得到了一系列特征参数,包括幅度均值、频率峰值、频率平方均值以及相位标准差、修正后的相位标准差。最后生成了一共480条数据,如下所示,前五列为特征值,最后一列为调制信号的类别(1-8):

3. BP网络训练

clear
clc
warning off
load("datasets.mat");
%% BP神经网络进行训练
P_train = datasets(1:400,1:end-1)'; %训练集特征
T_train = datasets(1:400,end)';    %训练集标签P_test = datasets(401:end,1:end-1)'; %测试集特征
T_test = datasets(401:end,end)';    %测试集标签% 数据归一化
P_train_normalized = mat2gray(P_train); % 将数据归一化到 [0, 1] 范围
P_test_normalized = mat2gray(P_test);% 设置神经网络参数
hiddenLayerSize = [100 600]; % 隐藏层
outputLayerSize = 8; % 输出层神经元数量
net = patternnet([hiddenLayerSize, outputLayerSize]);
net.trainParam.goal=1e-6; % 训练目标最小误差,这里设置为0.1
net.trainParam.mc=0.95; % 附加动量因子
net.trainParam.lr=0.05; % 学习速率,这里设置为0.05
net.trainParam.min_grad=1e-6; % 最小性能梯度
net.trainParam.min_fail=5; % 最大确认失败次数
net.trainParam.epochs = 150; % 最大轮数% 转换标签为独热编码
T_train_onehot = ind2vec(T_train);
T_test_onehot = ind2vec(T_test);% 训练神经网络
[net, tr] = train(net, P_train_normalized, T_train_onehot);
% 保存神经网络和训练信息
save('model_BP.mat', 'net', 'tr');
%% 使用训练好的神经网络进行预测
Y_train_pred = net(P_train_normalized);
Y_test_pred = net(P_test_normalized);% 反归一化预测结果
Y_train_pred_denormalized = vec2ind(Y_train_pred);
Y_test_pred_denormalized = vec2ind(Y_test_pred);% 计算训练集和测试集的准确率
train_accuracy = sum(T_train == Y_train_pred_denormalized) / numel(T_train);
disp(['训练集准确度:' num2str(train_accuracy)])
test_accuracy = sum(T_test == Y_test_pred_denormalized) / numel(T_test);
disp(['测试集准确度:' num2str(test_accuracy)])% 计算混淆矩阵
C = confusionmat(T_test, Y_test_pred_denormalized);
% 绘制混淆矩阵
figure
heatmap(C);
title(['测试集准确度:' num2str(test_accuracy)])

结果如下:

完整代码链接获取:Matlab信号处理——基于BP神经网络的调制信号分类与识别 (qq.com)

如果你想要进一步了解更多的相关知识,可以关注下面公众号联系~会不定期发布相关设计内容包括但不限于如下内容:信号处理、通信仿真、算法设计、matlab appdesigner,gui设计、simulink仿真......希望能帮到你!

这篇关于Matlab信号处理——基于BP神经网络的调制信号分类与识别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/946379

相关文章

无线路由器哪个品牌好用信号强? 口碑最好的三个路由器大比拼

《无线路由器哪个品牌好用信号强?口碑最好的三个路由器大比拼》不同品牌在信号覆盖、稳定性和易用性等方面各有特色,如何在众多选择中找到最适合自己的那款无线路由器呢?今天推荐三款路由器让你的网速起飞... 今天我们来聊聊那些让网速飞起来的路由器。在这个信息爆炸的时代,一个好路由器简直就是家庭网编程络的心脏。无论你

电脑显示hdmi无信号怎么办? 电脑显示器无信号的终极解决指南

《电脑显示hdmi无信号怎么办?电脑显示器无信号的终极解决指南》HDMI无信号的问题却让人头疼不已,遇到这种情况该怎么办?针对这种情况,我们可以采取一系列步骤来逐一排查并解决问题,以下是详细的方法... 无论你是试图为笔记本电脑设置多个显示器还是使用外部显示器,都可能会弹出“无HDMI信号”错误。此消息可能

Go信号处理如何优雅地关闭你的应用

《Go信号处理如何优雅地关闭你的应用》Go中的优雅关闭机制使得在应用程序接收到终止信号时,能够进行平滑的资源清理,通过使用context来管理goroutine的生命周期,结合signal... 目录1. 什么是信号处理?2. 如何优雅地关闭 Go 应用?3. 代码实现3.1 基本的信号捕获和优雅关闭3.2

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

matlab读取NC文件(含group)

matlab读取NC文件(含group): NC文件数据结构: 代码: % 打开 NetCDF 文件filename = 'your_file.nc'; % 替换为你的文件名% 使用 netcdf.open 函数打开文件ncid = netcdf.open(filename, 'NC_NOWRITE');% 查看文件中的组% 假设我们想读取名为 "group1" 的组groupName

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };