Bug with mean() on floating point vector elements
조회 수: 1 (최근 30일)
이전 댓글 표시
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
Stephen23
2017년 12월 13일
"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.
채택된 답변
Jan
2017년 12월 13일
편집: Jan
2017년 12월 13일
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
Steven Lord
2017년 12월 13일
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
2017년 12월 13일
@Viktor: it does not try to calculate along the singleton dimension, it actually does calculate along the singleton dimension.
추가 답변 (0개)
참고 항목
카테고리
Help Center 및 File Exchange에서 Logical에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!