将元素从数组复制到 Matlab 中的其他数组中



在Matlab中,我有一个数组"latencies"(大小为1x11(和一个单元格数组"Latencies_ms"(大小为1x298(。latenciesLatencies_ms的一小部分,即latencies中的值存在于Latencies_ms中。我希望能够在Latencies_ms中找到latencies中的每个值,然后将1000添加到该值并在Latencies_ms内重复 8 次。

举个例子,

latencies = [62626  176578  284690  397708  503278  614724  722466] 

和(Latencies_ms的一小部分样本(

Latencies_ms = {3458, 62626, 123456, 7891011, 121341, 222112, 176578}

我希望输出是

out = {3458, 62626, 63626,  64626,  65626,  66626,  67626,  68626,  69626,  70626, 123456, 7891011, 121341, 222112, 176578, 177578, 178578, 179578, 180578, 181578, 182578, 183578, 184578,}

作为起点,我决定看看我是否可以在不添加 1000 的情况下复制每个元素,并且我在repmat中使用以下代码:

out = arrayfun( @(x,b)[x; repmat({latencies},8,1)],... 
Latencies_ms, ismember(cell2mat(Latencies_ms),latencies), 'uni', 0 );
out = vertcat(out4{:});

我将延迟元素与Latencies_ms匹配,然后使用repmat但是像这样使用它会在正确的位置插入整个latencies数组,而不是重复元素。

然后,如果我尝试使用这样的 for 循环:

for i=1:length(latencies)
out = arrayfun( @(x,b)[x; repmat({latencies(i)},8,1)],... 
Latencies_ms, ismember(cell2mat(Latencies_ms),latencies), 'uni', 0 );
out = vertcat(out4{:});
end

它只重复延迟的最后一个元素,因此它正确地执行复制,而不是正确的元素。

我对arrayfun不太精通,我认为它的全部意义在于避免使用 for 循环,所以我确定这无论如何都不是正确的方式,但我觉得我快到了......有谁知道我错过了什么???

我不必使用 arrayfun,我尝试使用 for 循环来做到这一点,但它有点混乱,但只使用 arrayfun 没有限制,我只想获得正确的输出!

这是一个无循环的方法:

ind = ismember([Latencies_ms{:}] , latencies);      %Indices of the values to be repeated
repvals = bsxfun(@plus, repmat([Latencies_ms{ind}], 9, 1).', 0:1000:8000); %Rep+increment
out = Latencies_ms;
out(ind) = mat2cell(repvals, ones(1, sum(ind)), 9); %Replacing with repeated+inc elements
out = [out{:}]; %Converting to comma-separated list and then concatenating horizontally

第 2 行和第 4 行中9因子存在,因为匹配的元素将保留一次并以增量重复 8 次(总计 = 9 次(。第二行可以在 ≥ R2016b 中使用隐式扩展编写为:

repvals  = repmat([Latencies_ms{ind}], 9, 1).' + (0:1000:8000);

arrayfun是循环的单行包装器。它仍然是一个循环。但是循环在较新版本(从 R2015b 开始(中得到了显着改进,有时它们的性能甚至超过了矢量化代码。因此,无需避免简单的循环,您可以理解复杂的矢量化,除非它是一个瓶颈。

相关内容

  • 没有找到相关文章

最新更新