Info

Diese Frage ist geschlossen. Öffnen Sie sie erneut, um sie zu bearbeiten oder zu beantworten.

index exceeds matrix dimension

1 Ansicht (letzte 30 Tage)
AMAL targhi
AMAL targhi am 9 Jun. 2016
Geschlossen: MATLAB Answer Bot am 20 Aug. 2021
| This is my code i get the error index matrix dimensions in this line: network.meansqrerr {n} = plus( network.meansqrerr {n}, mse( network.error));|
function network = BUILD(inputs, targets, iterations)
% regle pour determiner le noombre des neurones dans la couche caheée
% source: stackoverflow
% Determiner hidden neuroness ( dans la couche caché couche2)
% round pour les virgules
nhidden = round((size(inputs, 1) + size(targets, 1)) * 2 / 3);
% %
% fprintf(' le nombre des couches cachés est: ')
disp(nhidden) ;
a= size(inputs, 1);
b= size(inputs, 1);
disp (a);
disp(b);
% Create a neural network
% on determine le nombre des neurones dans chaque couche
% couche1: le nombre des entrées
% couche 3 (output) le nombre des classe
network = Create(size(inputs, 1), nhidden, size(targets, 1));
% Iteration variables
% SOMME Des erreurs quadratique
n = 1;
% Train network jusk le max des iterations
%zeros_quat(zeros (10,1));
while n <= iterations
network.meansqrerr{n} = [ 0 0 0 0 ];
% Training epoch
% nombre des colonnes : size(inputs, 2)
for i=1:size(inputs, 2)
% Train network with inputs and target value
network = traine(network, inputs(:,i), targets(:,i));
% % Update sum squared error
network.meansqrerr {n} = plus( network.meansqrerr {n}, mse( network.error));
disp(['Iteration: ', num2str(n), ' / ' 'Error: ', num2str(double(network.meansqrerr{n}) )]);
%
%
% % afficher les erreurs dans chaque iteration
% disp(['Iteration: ', num2str(n), ' / ' 'Error: ', num2str(network.meansqrerr(n) )]);
% %
%
% Update iteration number
n = n + 1;
end
% afficher les poids
end

Antworten (1)

Walter Roberson
Walter Roberson am 9 Jun. 2016
You initialize
network.meansqrerr{n} = [ 0 0 0 0 ];
but you iterate
while n <= iterations
When your n exceeds 4, then network.meansqrerr{n} does not exist in the statement
network.meansqrerr {n} = plus( network.meansqrerr {n}, mse( network.error));
By the way: it is confusing that you do
a= size(inputs, 1);
b= size(inputs, 1);
If you intend both variables to be the same then why not use
b = a;
??
  7 Kommentare
Walter Roberson
Walter Roberson am 9 Jun. 2016
Which mse routine are you using?
Please post the complete error message, everything in red, including the part where it says which array the problem is with.
AMAL targhi
AMAL targhi am 10 Jun. 2016
this is my code
% network.meansqrerr (n) = network.meansqrerr (n)+ quattoral( mse( network.error)) ;
%
% % disp(['Iteration: ', num2str(n), ' / ' 'Error: ', num2str(double(network.meansqrerr{n}) )]);
function network = BUILD(inputs, targets, iterations)
% regle pour determiner le noombre des neurones dans la couche caheée
% source: stackoverflow
% Determiner hidden neuroness ( dans la couche caché couche2)
% round pour les virgules
nhidden = round((size(inputs, 1) + size(targets, 1)) * 2 / 3);
% fprintf(' le nombre des couches cachés est: ')
disp(nhidden)
% Create a neural network
% on determine le nombre des neurones dans chaque couche
% couche1: le nombre des entrées
% couche 3 (output) le nombre des classe
network = Create(size(inputs, 1), nhidden, size(targets, 1));
% Iteration variables
% SOMME Des erreurs quadratique
n = 1;
% network.meansqrerr = [];
% Train network jusk le max des iterations
while n <= iterations
network.meansqrerr{n} = [0 0 0 0];
% % Training epoch
% nombre des colonnes : size(inputs, 2)
for i=1:size(inputs, 2)
% Train network with inputs and target value
network = traine(network, inputs(:,i), targets(:,i));
% Update sum squared error
% network.meansqrerr (n) = network.meansqrerr (n)+ quattoral( mse( network.error)) ;
network.meansqrerr {n} = times(n^-1,(matric_plus(network.meansqrerr{n}, mse( network.error))))
size(network.meansqrerr);
end
% afficher les erreurs dans chaque iteration
% disp(['Iteration: ', num2str(n), ' / ' 'Error: ', num2str(network.meansqrerr(n) / size(inputs, 2))]);
disp(['Iteration: ', num2str(n), ' / ' 'Error: ', num2str(cell(network.meansqrerr(n)) / size(inputs, 2))]);
num2str(double(network.sumsqrerr(n)) / size(inputs, 2))
% num2str(double(network.sumsqrerr(n)) / size(inputs, 2))
% Update iteration number
n = n + 1;
end
% afficher les poids
% for i = 1:3
% disp(['Couche' num2str(i)]);
% for j = 1:1: [1458,59,7] % Counting neurons in each layer
% disp(['Neuron ' num2str(i)]);
% for k = 1:1: nhidden % Counting input to each layer (= # of neurons in the previous layer)
% disp(['w[' num2str(i) '][' num2str(j) '][' num2str(k) ']=' num2str(network.couches{i}(j,k))]);
% end
%
% end
% end
end
mse is a fucntion for mean square error ( my function)
the error is:
Cell contents reference from a non-cell array object.
Error in matric_plus (line 15) s= plus(a{i,j},b{i,j});
Error in BUILD2 (line 41) network.meansqrerr {n} = times(n^-1,(matric_plus(network.meansqrerr{n}, mse( network.error))))

Diese Frage ist geschlossen.

Produkte

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by