繁体   English   中英

计算每列的特定阈值以上的平均值

[英]Calculate mean above certain threshold for each column

我的数据位于名为x的nxm数组中。 我想要做的是计算高于某个阈值的每列中的值的平均值。 所以输出应该是1xm向量。

mean(x)显然没有指定阈值。 mean(x>70)执行真值检查,基本上返回每列高于阈值的值的百分比

您可以这样定义一个新变量

y = x > 70

接着

mean(x(y))

但是这会返回x的所有列的平均值。

通过为每列提供一行代码,这是一种非常麻烦的方法。

mean(x(y(1:end,1)))

等等,但这显然是丑陋的。

我觉得我在这里缺少一些简单的东西。 希望有人能够提供帮助。

你已经忘记了你可以通过元素来增加掩码

threshold = []; %define threshold here; it can be a 1xm vector or a scalar.
output = sum(x.*(x>threshold))./sum(x>threshold);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM