How do I efficiently iterate over subvectors of a given vector?

3 次查看(过去 30 天)
I have a vector of length N, which I want to generate all possible subvectors of of length n and sum over the subvectors. At the minute I have written
for val = 1:(N-n)
sums(val) = sum(vector(val:(val+n)))
end.
For example, if vector = [1, 2, 3, 4] and n=2, then this would return
sums = [3, 5, 7].
However, this code isn't very efficient. I'm aware of the buffer function in the Signal Processing toolbox, and using this speeds up my code by around a factor of 4, but I'm trying to avoid toolbox functions as I'm aiming to use Matlab Coder to translate into C code, which doesn't understand toolbox functions as far as I'm aware.
Is there a more efficient way to do this, possibly without using the for loop? I've done as much as I can with my knowledge, for example preallocating the sums vector, but I'm not sure how else to improve it.

采纳的回答

Walter Roberson
Walter Roberson 2020-12-4
  1 个评论
Daniel Pollard
Daniel Pollard 2020-12-4
That's worked perfectly. Exactly what I was after, but couldn't find the right Google phrase to find it. Thank you!

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Numeric Types 的更多信息

产品


版本

R2020a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by