%% 清空环境变量
warning off % 关闭报警信息
close all % 关闭开启的图窗
clear % 清空变量
clc % 清空命令行
%% 读取数据
res = xlsread('data.xlsx');
%% 分析数据
num_class = length(unique(res(:, end))); % 类别数(Excel最后一列放类别)
num_dim = size(res, 2) - 1; % 特征维度
num_res = size(res, 1); % 样本数(每一行,是一个样本)
num_size = 0.7; % 训练集占数据集的比例
res = res(randperm(num_res), :); % 打乱数据集(不打乱数据时,注释该行)
flag_conusion = 1; % 标志位为1,打开混淆矩阵(要求2018版本及以上)
%% 设置变量存储数据
P_train = []; P_test = [];
T_train = []; T_test = [];
%% 划分数据集
for i = 1 : num_class
mid_res = res((res(:, end) == i), :); % 循环取出不同类别的样本
mid_size = size(mid_res, 1); % 得到不同类别样本个数
mid_tiran = round(num_size * mid_size); % 得到该类别的训练样本个数
P_train = [P_train; mid_res(1: mid_tiran, 1: end - 1)]; % 训练集输入
T_train = [T_train; mid_res(1: mid_tiran, end)]; % 训练集输出
P_test = [P_test; mid_res(mid_tiran + 1: end, 1: end - 1)]; % 测试集输入
T_test = [T_test; mid_res(mid_tiran + 1: end, end)]; % 测试集输出
end
%% 数据转置
P_train = P_train'; P_test = P_test';
T_train = T_train'; T_test = T_test';
%% 得到训练集和测试样本个数
M = size(P_train, 2);
N = size(P_test , 2);
%% 数据归一化
[P_train, ps_input] = mapminmax(P_train, 0, 1);
P_test = mapminmax('apply', P_test, ps_input);
t_train = categorical(T_train)';
t_test = categorical(T_test )';
%% 数据平铺
% 将数据平铺成1维数据只是一种处理方式
% 也可以平铺成2维数据,以及3维数据,需要修改对应模型结构
% 但是应该始终和输入层数据结构保持一致
P_train = double(reshape(P_train, num_dim, 1, 1, M));
P_test = double(reshape(P_test , num_dim, 1, 1, N));
%% 数据格式转换
for i = 1 : M
p_train{i, 1} = P_train(:, :, 1, i);
end
for i = 1 : N
p_test{i, 1} = P_test( :, :, 1, i);
end
%% 建立模型
lgraph = layerGraph(); % 建立空白网络结构
tempLayers = [
sequenceInputLayer([num_dim, 1, 1], "Name", "input") % 建立输入层,输入数据结构为[num_dim, 1, 1]
sequenceFoldingLayer("Name", "seqfold")]; % 建立序列折叠层
lgraph = addLayers(lgraph, tempLayers); % 将上述网络结构加入空白结构中
tempLayers = [
convolution2dLayer([3, 1], 16, "Name", "conv_1", "Padding", "same") % 建立卷积层,卷积核大小[3, 1],16个特征图
reluLayer("Name", "relu_1") % Relu 激活层
convolution2dLayer([3, 1], 32, "Name", "conv_2", "Padding", "same") % 建立卷积层,卷积核大小[3, 1],32个特征图
reluLayer("Name", "relu_2")]; % Relu 激活层
lgraph = addLayers(lgraph, tempLayers); % 将上述网络结构加入空白结构中
numHiddenUnits = 64; % 隐含层神经元个数
tempLayers = [
sequenceUnfoldingLayer("Name", "sequnfold") % 建立序列反折叠层
flattenLayer("Name", "flatten1") % 网络铺平层
gruLayer( numHiddenUnits, 'OutputMode', 'sequence',"Name", "bigru1")% BiGRU层
concatenationLayer(1, 2, "Name", "cat1")
gruLayer( numHiddenUnits, 'OutputMode', 'last', "Name", "bigru3")
concatenationLayer(1, 2, "Name", "cat2")
fullyConnectedLayer(num_class, "Name", "fc") % 全连接层
softmaxLayer("Name", "softmax") % softmax激活层
classificationLayer("Name", "classification")]; % 分类层
lgraph = addLayers(lgraph, tempLayers); % 将上述网络结构加入空白结构中
lgraph = addLayers( lgraph, [
FlipLayer("flip1")
flattenLayer("Name", "flatten2") % 网络铺平层
gruLayer( numHiddenUnits, 'OutputMode', 'sequence',"Name", "bigru2" )
FlipLayer("flip2")] );
lgraph = addLayers(lgraph, [
FlipLayer("flip3")
gruLayer( numHiddenUnits, 'OutputMode', 'last',"Name", "bigru4" )] );
lgraph = connectLayers(lgraph, "seqfold/out", "conv_1"); % 折叠层输出 连接 卷积层输入
lgraph = connectLayers(lgraph, "seqfold/miniBatchSize", "sequnfold/miniBatchSize");
% 折叠层输出连接反折叠层输入
lgraph = connectLayers(lgraph, "relu_2", "sequnfold/in"); % 激活层输出 连接 反折叠层输入
lgraph = connectLayers(lgraph, "input", "flip1");
lgraph = connectLayers(lgraph, "flip2", "cat1/in2");
lgraph = connectLayers(lgraph, "cat1", "flip3");
lgraph = connectLayers(lgraph, "bigru4", "cat2/in2");
%% 参数设置
options = trainingOptions('adam', ... % Adam 梯度下降算法
'MaxEpochs', 500,... % 最大训练次数 1000
'InitialLearnRate', 0.001,... % 初始学习率为0.001
'L2Regularization', 0.001,... % L2正则化参数
'LearnRateSchedule', 'piecewise',... % 学习率下降
'LearnRateDropFactor', 0.1,... % 学习率下降因子 0.1
'LearnRateDropPeriod', 400,... % 经过800次训练后 学习率为 0.001*0.1
'Shuffle', 'every-epoch',... % 每次训练打乱数据集
'ValidationPatience', Inf,... % 关闭验证
'Plots', 'training-progress',... % 画出曲线
'Verbose', false);
%% 训练
net = trainNetwork(p_train, t_train, lgraph, options);
%% 预测
t_sim1 = predict(net, p_train);
t_sim2 = predict(net, p_test );
%% 反归一化
T_sim1 = vec2ind(t_sim1');
T_sim2 = vec2ind(t_sim2');
%% 混淆矩阵
figure
cm = confusionchart(T_train, T_sim1);
cm.Title = 'Confusion Matrix for Train Data';
cm.ColumnSummary = 'column-normalized';
cm.RowSummary = 'row-normalized';
figure
cm = confusionchart(T_test, T_sim2);
cm.Title = 'Confusion Matrix for Test Data';
cm.ColumnSummary = 'column-normalized';
cm.RowSummary = 'row-normalized';
前程算法屋
- 粉丝: 6006
- 资源: 834
最新资源
- 全桥变器,可以实现零电压开关和零电流开关ZVS和ZCS 波形好,和仿真详细对应说明
- 三相桥式全控整流器及其详细的说明等
- No.825 基于S7-200 PLC和组态王自动扶梯控制系统 带解释的梯形图程序,接线图原理图图纸,io分配,组态画面
- STM32+AD7124+热电偶方案+Pt100冷端补偿解析工程源码,源码包含Pt100、NTC热敏、热电偶处理驱动源码, 支持热电偶类型T、J、E、N、K、B、如果用于别的R、S 8种类型,并有Pt
- 暂态稳定性仿真分析 基于MATLAB Simulink的单机无穷大系统 可仿真、分析不同故障切除时间下,三相短路、两相短路接地、两相短路、单相接地短路故障状态下的暂态稳定性 可任意调节故障切除时间
- 带负载转矩前馈补偿的永磁同步电机FOC 1.采用滑模负载转矩观测器,可快速准确观测到负载转矩 赠送龙伯格负载转矩观测器用于对比分析 2.将观测到的负载转矩用作前馈补偿,可提高系统抗负载扰动能力;
- 双边工作自动裁断机全套设计资料100%好用.zip
- 基于STM32F4核心板的经典项目程序,远比网上搜索的开发板例程更有价值,历时2年时间打造 适合学生学习,工程师提高技术等等 项目内容为:用stm32f407单片机核心板和gy-91模块做一个功能
- 基于FAST与MATLAB SIMULINK联合仿真模型非线性风力发电机的PID独立变桨和统一变桨控制下仿真模型+参考文献,对于5WM非线性风机风机进行控制 链接simulink的scope出转速对比
- 永磁同步电机调速控制软件工程PMSM,该工程主要基于DSP28335硬件控制平台,两电平IPM模块主回路,DSP控制器控制, 配过压和过流保护,小功率电机调速控制,工程软件配注释,提供对应硬件原理图
- 汇川MD500E变频器开发方案 源码+解析, MD500E代码方案和解析文档+仿真资料 资料全 包含pmsm的foc控制算法,电阻、电感、磁链等参数的辩识算法,死区补偿算法过调制处理算法
- 超值福利 关键词:场景生成 缩减 微网优化调度,综合能源优化,matlab cplex等优化程序,全部打包带走,神经网络光伏预测,可提供优化学习资料 火火 运行环境:matlab 欢迎咨询
- Java项目:基于servlet+jsp+tomcat实现的网上点餐系统分享给需要的同学【完整源码+数据库】
- droop下垂并网控制,采用电压电流双环spwm控制.2018b版本
- 西门子1200PLC控制加KPT1200触摸屏,污水处理厂自控项目实例,含一台200SMART200加触摸屏泵站程序画面 内涵全套电气控制图纸 改建成已运行项目,所有应用均经过实际验证 应用包括
- 全套S7-1200一拖三恒压供水程序样例+PID样例+触摸屏样例 34 1、此程序采用S7-1200PLC和KTP1000PN触摸屏人机执行PID控制变频器实现恒压供水. 包括plc程序,触摸屏
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
- 1
- 2
- 3
前往页