处理Matlab中加载的一系列文件

时间:2015-12-28 13:11:45

标签: matlab mean multiple-files

我有一系列文件,我在matlab中加载,我正在尝试进行如下插值:

numfiles = 10;
data = cell(1, numfiles);
xvalues=[];
yvalues=[];
yqvalues=[];
xq=linspace(-10,10,1000);
for k = 1:numfiles
   file = sprintf('filename_%d', k);
   data{k} = importdata(file);
   xvalues{k} = data{k}(:,1);
   yvalues{k} = data{k}(:,2);
   yqvalues{k}= interp1(xvalues{k},yvalues{k},xq,'spline');
end

到目前为止,每件事情都很好,我得到了正确的尺寸。

  [1x1000 double]    [1x1000 double]    [1x1000 double]    [1x1000 double]    [1x1000 double]    [1x1000 double]    [1x1000 double]    [1x1000 double]    [1x1000 double]    [1x1000 double]

现在我想计算每个xq的平均值。所以我应该有一个1 * 1000值的数组。我该怎么办?使用这个循环是否正确

for i=1:length(xq)
      m(i)=mean(yqvalues{k}(i));
end

在第一个循环中的yqvalues {k} = ...行之后?

我尝试了这个但是我得到了不同的平均值,相比之下我逐个加载文件并插入每个和其余的过程。

有人可以帮我解决这个问题吗?!

由于

文件示例: file_1

-14.7812 0.25
-14.7712 0.36
-14.7612 0.20
-14.7512 0.14
-14.7412 0.05
-14.7312 0.05
-14.7212 0.1
-14.7112 0
-14.7012 0.25
-14.6912 0.23

file_2

-14.8289 0.34
-14.8189 0
-14.8089 0.1
-14.7989 0.08
-14.7889 0.15
-14.7789 0.22
-14.7689 0
-14.7589 0
-14.7489 0.28
-14.7389 0.36

file_3

-14.7813 0.05
-14.7713 0.25
-14.7613 0.17
-14.7513 0
-14.7413 0
-14.7313 0.09
-14.7213 0.02
-14.7113 0.18
-14.7013 0.30
-14.6913 0.04

使用这些文件我希望平均值为:

 D5_1 =

   1.0e+09 *

  Columns 1 through 13

   -0.0000   -0.0002   -0.0022   -0.0082   -0.0203   -0.0408   -0.0718   -0.1156   -0.1743   -0.2501   -0.3453   -0.4619   -0.6022

  Columns 14 through 20

   -0.7684   -0.9627   -1.1872   -1.4441   -1.7357   -2.0641   -2.4315

但我得到的是:

D_5 =

   1.0e+04 *

  Columns 1 through 13

   -0.0381   -0.0184   -0.0070   -0.0016   -0.0000    0.0000   -0.0001   -0.0026   -0.0120   -0.0325   -0.0686   -0.1245   -0.2047

  Columns 14 through 20

   -0.3135   -0.4552   -0.6343   -0.8549   -1.1217   -1.4387   -1.8105

1 个答案:

答案 0 :(得分:0)

您当前的实现将单个值(yqvalues{k}(i))传递给mean,而不是您希望传递的多个值。我对代码进行了一些更改,以便利用mean查找yqvalues numfiles = 3; xvalues = cell(1, numfiles); yvalues = cell(1, numfiles); xq = linspace(-10,10,1000); yqvalues = zeros(length(xq), numfiles); for k = 1:numfiles file = sprintf('file_%u.txt', k); data = importdata(file); xvalues{k} = data(:,1); yvalues{k} = data(:,2); yqvalues(:,k) = interp1(xvalues{k}, yvalues{k}, xq, 'spline'); end m = mean(yqvalues, 2); 的平均值:

XY

我将假设每个文件中xvalues值的数量是可变的,并将yvaluesyqvalues保留为单元格数组。但是,由于xq取决于double的大小,因此它是常量,因此我们可以为yqvalues使用简单的interp1数组,并且无需将它放在一起找到每行的平均值的each row,循环或其他相关方法。

除了一般情况,我建议谨慎使用这种xq方法,因为它可能会导致超出数据边界的public GraphRequest getRequestForPagedResults(PagingDirection direction)值的结果非常糟糕。