Why I can't use trainetwork for the CNN3D using convolution3DLayer
조회 수: 4 (최근 30일)
이전 댓글 표시
Here is my code:
clc;clear all;
%%
X_train = zeros(9,9,4,20);
Y_train = categorical(randi(2,[20,1]));
%%
trainD=X_train;
targetD=Y_train;
[row collum di]=size(trainD(:,:,:,1));
%% Define Network Architecture
% Define the convolutional neural network architecture.
lgraph = layerGraph;
layers = [
image3dInputLayer([row collum di 1],'Name','input') % 9x9x4x1 refers to number of features per sample
convolution3dLayer([2 2 2],5,'stride',[1 1 1],'padding','same','Name','conv_1')
batchNormalizationLayer('Name','BN_1')
reluLayer('Name','Relu_1')
dropoutLayer(0.5,'Name','Dropout1')
fullyConnectedLayer(1024,'Name','Fc1')
fullyConnectedLayer(2,'Name','Fc2')
softmaxLayer('Name','Softmax')
classificationLayer('Name','ClassOutput')];
options = trainingOptions('adam',...
'MaxEpochs',1000, ...
'Shuffle','every-epoch', ...
'InitialLearnRate',1.0000e-04, ...
'L2Regularization',0.5,...
'Verbose',true,...
'VerboseFrequency',5,...
'Plots','training-progress',...
'OutputFcn',@(info)stopIfAccuracyNotImproving(info,3));
%%
net = trainNetwork(trainD,targetD,layers,options);
predictedLabels = classify(net,trainD)';
%%
%caculate accuracy (need change code a litte (do later))
YPred = classify(net,valD);%fix this add our eeg
YValidation = vallab;%fix this add our label
accuracy = sum(YPred == YValidation)/numel(YValidation)*100
The error is:
Error using trainNetwork (line 165)
Number of observations in X and Y disagree.
Error in test_CNN3D (line 48)
net = trainNetwork(trainD,targetD,layers,options);
I need some help as soon as possible please.
Thanks
댓글 수: 3
Jyothis Gireesh
2019년 11월 21일
According to the documentation on “image3dInputLayer()”, the layer expects an input data of the form
where h, w, d and c correspond to the height, width, depth and number of channels respectively.
Here the “X_train" is initialized to have a size of 9x9x4X20 and I am assuming that your input data is a 3-D grayscale image. So the “trainNetwork()”function expects each sample of the training data to be of the format
or
(depending on grayscale or color images) and the training data to be of the form
With the original initializations, the no. of channels would be treated as 20 which may trigger the internal input argument validation processes. Adding a singleton dimension as the fourth index and shifting the number of samples to the fifth index changes the training data into the appropriate format and thereby removes the error message.
답변 (0개)
참고 항목
카테고리
Help Center 및 File Exchange에서 Deep Learning Toolbox에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!