我想创建一个 MATLAB 函数来从另一个目录中的文件导入数据并将它们拟合到给定模型,但是因为需要过滤数据(文件中的不同位置有“thrash”数据,例如之前没有测量分析的运动开始)。
因此,包含用于拟合的数据的向量最终具有不同的长度,因此我无法在矩阵中返回它们(例如,下面的函数中的 x)。我该如何解决这个问题?
我有很多数据文件,所以我不想使用“手动”方法。我的功能如下。欢迎所有和建议。
数据拟合.m
function [p, x, y_c, y_func] = datafit(pattern, xcol, ycol, xfilter, calib, p_calib, func, p_0, nhl)
datafiles = dir(pattern);
path = fileparts(pattern);
p = NaN(length(datafiles));
y_func = [];
for i = 1:length(datafiles)
exist(strcat(path, '/', datafiles(i).name));
filename = datafiles(i).name;
data = importdata(strcat(path, '/', datafiles(i).name), '\t', nhl);
filedata = data.data/1e3;
xdata = filedata(:,xcol);
ydata = filedata(:,ycol);
filter = filedata(:,xcol) > xfilter(i);
x(i,:) = xdata(filter);
y(i,:) = ydata(filter);
y_c(i,:) = calib(y(i,:), p_calib);
error = @(par) sum(power(y_c(i,:) - func(x(i,:), par),2));
p(i,:) = fminsearch(error, p_0);
y_func = [y_func; func(x(i,:), p(i,:))];
end
end