Sum of following elements in array

4 views (last 30 days)
Is there a faster way to do the following
s = rand(1, 10);
sum_following = zeros(length(s), 1);
for i = 1:length(s)-1
sum_following(i) = sum(s(i+1:end), 'all');
end
without doing
sum_following = sum(s,"all") - cumsum(s);
?
  9 Comments
Walter Roberson
Walter Roberson on 9 Dec 2023
The point is that doing this is fast but not numerically stable if the last entries of s are close to zero.
The loop with
sum(s(i+1:end), 'all');
is not numerically stable either. The trailing suffix [... A B -B -A] is going to come out as -A if abs(A) < eps(B)
Side note: You are using linear indexing. Linear indexing of anything always gives a vector result, and for a vector being added together, 'all' as a parameter does not provide any value.
Linear indexing of row vector: gives a row vector
Linear indexing of column ector: gives a column vector
Linear indexing of non-vectors: gives a result that is the same shape as the indices. Which, for i+1:end would be a row vector.

Sign in to comment.

Accepted Answer

Matt J
Matt J on 9 Dec 2023
Edited: Matt J on 9 Dec 2023
sum_following = cumsum([s(2:end),0],"reverse");

More Answers (0)

Community Treasure Hunt

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

Start Hunting!