Bug with mean() on floating point vector elements
5 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Victor
el 13 de Dic. de 2017
Comentada: Stephen23
el 13 de Dic. de 2017
Can someone explain this bug?
a = rand(100,1);
mean(a(4), a(6))
Output:
Error using sum
Dimension argument must be a positive integer scalar within indexing range.
Error in mean (line 117)
y = sum(x, dim, flag)/size(x,dim);
1 comentario
Stephen23
el 13 de Dic. de 2017
"Can someone explain this bug?"
What bug? The fact that you are using mean in a way that is not supported by MATLAB just means that you need to read the documentation.
Respuesta aceptada
Jan
el 13 de Dic. de 2017
Editada: Jan
el 13 de Dic. de 2017
This is not a bug. Please read the documentation, if you have a problem with a command:
doc mean
The 2nd argument of mean must be the dimension to operate on. Then a floating point number between 0 and 1 will not work. See:
a = magic(3)
mean(a, 1)
mean(a, 2)
You forgot to mention, what you want to calculate. Maybe you mean:
a = rand(100, 1);
mean(a([4,6]))
% or
mean(a(4:6))
3 comentarios
Steven Lord
el 13 de Dic. de 2017
Looking at your a vector, what is a(4)? It's 5. Can you take the mean of a two-dimensional array in the fifth dimension? Sure. While a(3) doesn't look like it has a fifth dimension, if you ask for the size of a(3) in the fifth dimension what does MATLAB return?
size(a(3), 5) % returns 1
The reason your original attempt didn't work is that arrays in MATLAB don't have (for example) a 0.25th dimension.
Stephen23
el 13 de Dic. de 2017
@Viktor: it does not try to calculate along the singleton dimension, it actually does calculate along the singleton dimension.
Más respuestas (0)
Ver también
Categorías
Más información sobre Logical en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!