Sum of following elements in array

조회 수: 4 (최근 30일)
Ivan Bioli
Ivan Bioli 2023년 12월 9일
댓글: Walter Roberson 2023년 12월 9일
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
Matt J
Matt J 2023년 12월 9일
Because
1+eps^2 == 1
ans = logical
1
Walter Roberson
Walter Roberson 2023년 12월 9일
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.

댓글을 달려면 로그인하십시오.

채택된 답변

Matt J
Matt J 2023년 12월 9일
편집: Matt J 2023년 12월 9일
sum_following = cumsum([s(2:end),0],"reverse");

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Matrix Indexing에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by