【问题标题】:Taking hourly Averages Matlab with Vector用向量取每小时平均值 Matlab
【发布时间】:2014-12-29 02:14:51
【问题描述】:

我有一个格式为

的向量
     0   21.3400
     0   22.3000
     1   22.3000

左栏是小时,右栏是数值。我需要计算每小时的平均值。问题是我的样本运行时间超过 24 小时(多天),因此它会再次从 0-23 循环回到 0-23。另一个问题是,有时我会在某个小时内丢失样本。例如;

   12.0000   29.5000
   14.0000   35.7400

关于如何解决这个问题的任何想法?

【问题讨论】:

  • 所以你想汇总不同日期的值吗?在这种情况下,举一个具有所需输出的示例

标签: matlab average


【解决方案1】:

我不清楚“所以它会再次从 0-23 循环回到 0-23”部分。也许您正在寻找模函数mod()。但是在你解决了这个特殊问题之后,你的平均问题可以使用accumarray 来解决。这就像这个功能的完美用例。

%// your data
data = [
     0   21.3400
     0   22.3000
     1   22.3000
     12.0000   29.5000
     14.0000   35.7400];
 %// group (find subs)
 [hours, b, subs] = unique(data(:,1));

 %// apply function mean to grouped data
 avg = accumarray(subs, data(:,2), [], @mean);
 result = [hours, avg]

result 中,结果以表格形式存储,第一列是唯一小时数,第二列是这些小时数的平均数据值。

result =

     0    21.8200
1.0000    22.3000
12.0000   29.5000
14.0000   35.7400

例如:对于小时 0,数据值 21.340022.300 的平均值被正确计算为 (21.3400 + 22.300)/2,等于 21.8200

【讨论】:

  • 是的,做了一些搜索,accumarray 比我尝试做的要好得多。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-11-12
相关资源
最近更新 更多