how to sum floating point elements of an array
Mostrar comentarios más antiguos
Hi I have an array which has floating point inputs. I need to sum all the elements to get a single value. The command 'sum' takes only integer inputs and throws error "??? Subscript indices must either be real positive integers or logicals" for double type inputs. Will appreciate any help.
Thanks, Subrat
2 comentarios
Andrei Bobrov
el 11 de Sept. de 2012
a = rand(8,1) % the initial array
out = sum(a)
Yoheena Kotikawatte
el 24 de Mzo. de 2018
Hi! How do i make this work:
k = 25;
v=[1;0];
pvalues=[0:.01:1];
for i1=1:length(pvalues) p=pvalues(i1); A =[(2-p) (0.25*p); p (1.25-0.25*p)]; numbbacteria=(A^k)*v; y(p) = sum(numbbacteria); end
plot(pvalues,y) ylabel('Total number of bacteria'); xlabel('Probability that a bacteria will switch states');
because I get the eror: Subscript indices must either be real positive integers or logicals.
Error in p_file (line 8) y(p) = sum(numbbacteria);
I do understand the eror but how do i make it work with decimals?
Respuesta aceptada
Más respuestas (1)
Oleg Komarov
el 11 de Sept. de 2012
"??? Subscript indices must either be real positive integers or logicals"
It means you're doing something:
a = 1:0.1:2;
b = rand(20,1);
b(a)
You cannot select position 1.1, 1.2... of an array (or -1). The indexing of an array is done with whole positive integers 1, 2, 3...
1 comentario
Subrat kumar sahoo
el 11 de Sept. de 2012
Categorías
Más información sobre Logical en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!