假设我有一个长数据向量y,加上一些索引。我想在每个索引周围提取一个简短的片段或窗口。
例如,假设我想构建一个包含64个样本的矩阵,并且在每个低于3的值之后构建64个样本。在for循环中这很简单:
WIN_SIZE = 64;
% Sample data with padding
data = [nan(WIN_SIZE,1); randn(1e6,1); nan(WIN_SIZE,1)];
% Sample events, could be anything
index = find(data < 3);
snippets = nan(length(index), 2*WIN_SIZE + 1);
for ii=1:length(index)
snippets(ii,:) = data((index(ii)-WIN_SIZE):(index(ii)+WIN_SIZE));
end
但是,这并不是非常快。有没有办法对这个操作进行矢量化(或以其他方式加速)?
(如果不清楚,索引可能是任何东西,可能不一定是数据的属性;我只想简单地说明这个想法。)