我有以下代码从数据集(“DATA”)计算百分位数非常慢,因为输入矩阵很大(“Data”大约长 500.000,从“Indices”分配了 10080 个唯一值) .
是否有可能/建议使这段代码更高效?例如,我可以以某种方式省略 for 循环吗?
k = 1;
for i = 0:0.5:100; % in 0.5 fractile-steps
FRACTILE(:,k) = accumarray(Indices,Data,[], @(x) prctile(x,i));
k = k+1;
end