Nested mean function with omitnan

3 次查看(过去 30 天)
Not sure if this behavior is intentional. When I have an array, let's say:
A=[1,NaN;3,4];
And I want to calculate the mean over the second dimension first, then the first one:
m=mean(A,[2,1],'omitnan');
The result is 2.66, which is clearly just (1+3+4)/3, and so it's the same as:
m=mean(A,'all','omitnan');
I'm aware that this is exactly what it says in the documentation, but it's still unexpected. What I would have expected would be the same as:
m=mean(mean(A,2,'omitnan'),1,'omitnan');
Which in this case gives the (imho correct) result of 2.25, so (1+(3+4)/2)/2
Am I missing something?

采纳的回答

Jan
Jan 2023-3-16
The problem is here: "What I would have expected would be the same as". This is not the way mean('omitnan') is working. So if you expect something else, you have to write the code to do it as you want it.
If it is explained in the documentation, there is no reason to expect something else. The behavior you expect would not match my intuition for [NaN, 1; NaN, 2].
  1 个评论
Stefan Th.
Stefan Th. 2023-3-16
Sure, it's in the documentation, so that's fine, I just think 'omitnan' could be misinterpreted in this case.
[NaN, 1; NaN, 2] would always lead to the same result, no matter in what order you calculate the mean or if you just take the mean of all values all together, but it's different in the case I mentioned.

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Logical 的更多信息

标签

产品


版本

R2021b

Community Treasure Hunt

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

Start Hunting!

Translated by