我有一系列文件,我在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
答案 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
值的数量是可变的,并将yvalues
和yqvalues
保留为单元格数组。但是,由于xq
取决于double
的大小,因此它是常量,因此我们可以为yqvalues
使用简单的interp1
数组,并且无需将它放在一起找到每行的平均值的each row,循环或其他相关方法。
除了一般情况,我建议谨慎使用这种xq
方法,因为它可能会导致超出数据边界的public GraphRequest getRequestForPagedResults(PagingDirection direction)
值的结果非常糟糕。