在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

MATLAB殘差神經網絡設計

冬至子 ? 來源:matlab學習之家 ? 作者:matlab學習之家 ? 2023-06-02 16:39 ? 次閱讀

我們都知道在CNN網絡中,輸入的是圖片的矩陣,也是最基本的特征,整個CNN網絡就是一個信息提取的過程,從底層的特征逐漸抽取到高度抽象的特征,網絡的層數越多也就意味這能夠提取到的不同級別的抽象特征更加豐富,并且越深的網絡提取的特征越抽象,就越具有語義信息。但神經網絡越深真的越好嗎?我們可以看下面一張圖片,圖中描述了不同深度的傳統神經網絡效果對比圖,顯然神經網絡越深效果不一定好。

圖片

對于傳統CNN網絡,網絡深度的增加,容易導致梯度消失和爆炸。針對梯度消失和爆炸的解決方法一般是正則初始化和中間的正則化層,但是這會導致另一個問題,退化問題,隨著網絡層數的增加,在訓練集上的準確率卻飽和甚至下降了。為此,殘差神經網絡應運而生。

一、算法原理

殘差網絡通過加入 shortcut connections,變得更加容易被優化。包含一個 shortcut connection 的幾層網絡被稱為一個殘差塊(residual block),如下圖所示。

圖片

普通的平原網絡與深度殘差網絡的最大區別在于,深度殘差網絡有很多旁路的支線將輸入直接連到后面的層,使得后面的層可以直接學習殘差,這些支路就叫做shortcut。傳統的卷積層或全連接層在信息傳遞時,或多或少會存在信息丟失、損耗等問題。ResNet 在某種程度上解決了這個問題,通過直接將輸入信息繞道傳到輸出,保護信息的完整性,整個網絡則只需要學習輸入、輸出差別的那一部分,簡化學習目標和難度。

二、代碼實戰

構建19層ResNet網絡,以負荷預測為例
%%
clc
clear


close all
load Train.mat
% load Test.mat
Train.weekend = dummyvar(Train.weekend);
Train.month = dummyvar(Train.month);
Train = movevars(Train,{'weekend','month'},'After','demandLag');
Train.ts = [];




Train(1,:) =[];
y = Train.demand;
x = Train{:,2:5};
[xnorm,xopt] = mapminmax(x',0,1);
[ynorm,yopt] = mapminmax(y',0,1);


xnorm = xnorm(:,1:1000);
ynorm = ynorm(1:1000);


k = 24;           % 滯后長度


% 轉換成2-D image
for i = 1:length(ynorm)-k


    Train_xNorm{:,i} = xnorm(:,i:i+k-1);
    Train_yNorm(i) = ynorm(i+k-1);
    Train_y{i} = y(i+k-1);
end
Train_x = Train_xNorm';


ytest = Train.demand(1001:1170);
xtest = Train{1001:1170,2:5};
[xtestnorm] = mapminmax('apply', xtest',xopt);
[ytestnorm] = mapminmax('apply',ytest',yopt);
% xtestnorm = [xtestnorm; Train.weekend(1001:1170,:)'; Train.month(1001:1170,:)'];
xtest = xtest';
for i = 1:length(ytestnorm)-k
    Test_xNorm{:,i} = xtestnorm(:,i:i+k-1);
    Test_yNorm(i) = ytestnorm(i+k-1);
    Test_y(i) = ytest(i+k-1);
end
Test_x = Test_xNorm';
x_train = table(Train_x,Train_y');
x_test = table(Test_x);
%% 訓練集和驗證集劃分
% TrainSampleLength = length(Train_yNorm);
% validatasize = floor(TrainSampleLength * 0.1);
% Validata_xNorm = Train_xNorm(:,end - validatasize:end,:);
% Validata_yNorm = Train_yNorm(:,TrainSampleLength-validatasize:end);
% Validata_y = Train_y(TrainSampleLength-validatasize:end);
% 
% Train_xNorm = Train_xNorm(:,1:end-validatasize,:);
% Train_yNorm = Train_yNorm(:,1:end-validatasize);
% Train_y = Train_y(1:end-validatasize);
%% 構建殘差神經網絡
lgraph = layerGraph();
tempLayers = [
    imageInputLayer([4 24],"Name","imageinput")
    convolution2dLayer([3 3],32,"Name","conv","Padding","same")];
lgraph = addLayers(lgraph,tempLayers);


tempLayers = [
    batchNormalizationLayer("Name","batchnorm")
    reluLayer("Name","relu")];
lgraph = addLayers(lgraph,tempLayers);


tempLayers = [
    additionLayer(2,"Name","addition")
    convolution2dLayer([3 3],32,"Name","conv_1","Padding","same")];
lgraph = addLayers(lgraph,tempLayers);


tempLayers = [
    batchNormalizationLayer("Name","batchnorm_1")
    reluLayer("Name","relu_1")];
lgraph = addLayers(lgraph,tempLayers);


tempLayers = [
    additionLayer(2,"Name","addition_1")
    convolution2dLayer([3 3],32,"Name","conv_2","Padding","same")];
lgraph = addLayers(lgraph,tempLayers);


tempLayers = [
    batchNormalizationLayer("Name","batchnorm_2")
    reluLayer("Name","relu_2")];
lgraph = addLayers(lgraph,tempLayers);


tempLayers = [
    additionLayer(2,"Name","addition_2")
    convolution2dLayer([3 3],32,"Name","conv_3","Padding","same")];
lgraph = addLayers(lgraph,tempLayers);


tempLayers = [
    batchNormalizationLayer("Name","batchnorm_3")
    reluLayer("Name","relu_3")];
lgraph = addLayers(lgraph,tempLayers);


tempLayers = [
    additionLayer(2,"Name","addition_3")
    fullyConnectedLayer(1,"Name","fc")
    regressionLayer("Name","regressionoutput")];
lgraph = addLayers(lgraph,tempLayers);


% 清理輔助變量
clear tempLayers;


lgraph = connectLayers(lgraph,"conv","batchnorm");
lgraph = connectLayers(lgraph,"conv","addition/in2");
lgraph = connectLayers(lgraph,"relu","addition/in1");
lgraph = connectLayers(lgraph,"conv_1","batchnorm_1");
lgraph = connectLayers(lgraph,"conv_1","addition_1/in2");
lgraph = connectLayers(lgraph,"relu_1","addition_1/in1");
lgraph = connectLayers(lgraph,"conv_2","batchnorm_2");
lgraph = connectLayers(lgraph,"conv_2","addition_2/in2");
lgraph = connectLayers(lgraph,"relu_2","addition_2/in1");
lgraph = connectLayers(lgraph,"conv_3","batchnorm_3");
lgraph = connectLayers(lgraph,"conv_3","addition_3/in2");
lgraph = connectLayers(lgraph,"relu_3","addition_3/in1");


plot(lgraph);
analyzeNetwork(lgraph);
%% 設置網絡參數
maxEpochs = 60;
miniBatchSize = 20;
options = trainingOptions('adam', ...
 'MaxEpochs',maxEpochs, ...
 'MiniBatchSize',miniBatchSize, ...
 'InitialLearnRate',0.01, ...
 'GradientThreshold',1, ...
 'Shuffle','never', ...
 'Plots','training-progress',...
 'Verbose',0);


net = trainNetwork(x_train,lgraph ,options);


Predict_yNorm = predict(net,x_test);
Predict_y = double(Predict_yNorm)
plot(Test_y)
hold on 
plot(Predict_y)
legend('真實值','預測值')

網絡框架:

圖片

網絡分析:

圖片

網絡訓練:

圖片

預測結果:

圖片

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 神經網絡
    +關注

    關注

    42

    文章

    4774

    瀏覽量

    100912
  • MATLAB仿真
    +關注

    關注

    4

    文章

    176

    瀏覽量

    19945
  • cnn
    cnn
    +關注

    關注

    3

    文章

    353

    瀏覽量

    22254
  • resnet
    +關注

    關注

    0

    文章

    12

    瀏覽量

    3173
收藏 人收藏

    評論

    相關推薦

    matlab 神經網絡 數學建模數值分析

    matlab神經網絡 數學建模數值分析 精通的可以討論下
    發表于 09-18 15:14

    神經網絡Matlab程序

    神經網絡Matlab程序
    發表于 09-15 12:52

    matlab小波神經網絡源程序下載

    基于MATLAB的有關小波與神經網絡緊致結合的源程序[hide] [/hide]
    發表于 02-22 15:50

    matlab神經網絡30個案例分析源碼

    matlab神經網絡30個案例分析源碼
    發表于 12-19 14:51

    MATLAB神經網絡

    MATLAB神經網絡
    發表于 07-08 15:17

    什么是深度收縮網絡?

    ?! ≡谝欢ǔ潭壬?,深度收縮網絡的工作原理,可以理解為:通過注意力機制注意到不重要的特征,然后通過軟閾值化將它們置為零;或者說,通過注意力機制注意到重要的特征,將它們保留下來,從而加強深度
    發表于 11-26 06:33

    Matlab神經網絡工具箱是什么? 它在同步中的應用有哪些?

    Matlab神經網絡工具箱是什么?Matlab神經網絡工具箱在同步中的應用有哪些?
    發表于 04-26 06:42

    卷積神經網絡模型發展及應用

    地介紹了卷積 神經網絡的發展歷史,然后分析了典型的卷積神經 網絡模型通過堆疊結構、網中網結構、結構以及 注意力機制提升模型性能的方法,并
    發表于 08-02 10:39

    matlab神經網絡應用設計

    matlab神經網絡應用設計詳細的介紹了matlab神經網絡的結合
    發表于 02-23 10:47 ?0次下載

    matlab神經網絡應用設計》pdf下載

    matlab神經網絡應用設計》電子資料下載
    發表于 01-13 10:07 ?0次下載

    基于深度神經網絡的遠程監督關系抽取模型

    基于卷積神經網絡的遠程監督關系抽取方法提取的特征單一,且標準交叉熵損失函數未能較好處理數據集中正負樣本比例不均衡的情況。為此,提出一種基于深度神經網絡的遠程監督關系抽取模型,通過改
    發表于 05-24 17:06 ?3次下載

    基于神經網絡的微型電機轉子焊點圖像檢測

    基于神經網絡的微型電機轉子焊點圖像檢測
    發表于 07-02 14:56 ?23次下載

    如何使用MATLAB神經網絡工具箱

    神經網絡是一種模擬人腦神經元網絡的計算模型,廣泛應用于各種領域,如圖像識別、語音識別、自然語言處理等。在MATLAB中,可以使用神經網絡工具箱(Neural Network Toolb
    的頭像 發表于 07-03 10:34 ?2563次閱讀

    如何利用Matlab進行神經網絡訓練

    Matlab作為一款強大的數學計算軟件,廣泛應用于科學計算、數據分析、算法開發等領域。其中,Matlab神經網絡工具箱(Neural Network Toolbox)為用戶提供了豐富的函數和工具
    的頭像 發表于 07-08 18:26 ?1933次閱讀

    網絡是深度神經網絡

    網絡(Residual Network,通常簡稱為ResNet) 是深度神經網絡的一種 ,其獨特的結構設計在解決深層網絡訓練中的梯度消失
    的頭像 發表于 07-11 18:13 ?1127次閱讀
    主站蜘蛛池模板: 亚洲激情四射| 国产成人三级经典中文| 福利视频免费观看| 午夜影视网| 国模绪| 四虎a456tncom| 久操操操| 午夜激情福利| 国产高清在线免费| 免费在线黄色网| 色多多官网| 亚洲综合色婷婷| 精品一区二区三区三区| 91av视频网站| 最新黄色在线| 狠狠操狠狠摸| 日本加勒比官网| 天天干天天色综合| 午夜精品福利影院| 免费观看一级一片| 日日添天天做天天爱| 天天射天天射| 天天做天天爱天天综合网| 欧美午夜在线观看| 免费观看老外特级毛片| 爱操综合网| www.射射| 亚洲a网站| 中文字幕在线一区| 妇女交性大片| 国产热re99久久6国产精品| 亚洲第一成人影院| 亚洲天堂婷婷| 一卡二卡卡四卡无人区中文| 国产成人精品系列在线观看| 婷婷亚洲综合| 四虎网站| 国产一线在线观看| 日日日日人人人夜夜夜2017| 国产h在线播放| 欧美区亚洲区|