光谱矩阵Xdata为M✖️N(每行代表一个样本,即一共M个样本),浓度矩阵Ydata为M×1(即每个样本对应一个浓度),现在对Ydata矩阵进行排序并且做差(tol<0.02)把相近的剔除掉,对应的Xdata中的行也删掉。我现在的思路是把Xdata和Ydata放在一起组成一个矩阵(M×(N+1)),在对最后一列进行差值剔除,所对应的行也删掉即可。
光谱矩阵Xdata为M✖️N(每行代表一个样本,即一共M个样本),浓度矩阵Ydata为M×1(即每个样本对应一个浓度),现在对Ydata矩阵进行排序并且做差(tol<0.02)把相近的剔除掉,对应的Xdata中的行也删掉。我现在的思路是把Xdata和Ydata放在一起组成一个矩阵(M×(N+1)),在对最后一列进行差值剔除,所对应的行也删掉即可。
收起
建议先删除,再排列
%先删除
[Y, ia] = uniquetol(Ydata, 0.02, 'ByRows',true);
X = Xdata(ia,:); % 对应的Xdata中的行也删掉
% 再排列
[Y, idx] = sort(Y);%Y从小到大排列
X = X(idx,:); %对应X也排列好了
XY = [X,Y]; %组合好的矩阵
报告相同问题?