Azzera filtri
Azzera filtri

Sum of following elements in array

1 visualizzazione (ultimi 30 giorni)
Ivan Bioli
Ivan Bioli il 9 Dic 2023
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 Commenti
Matt J
Matt J il 9 Dic 2023
Because
1+eps^2 == 1
ans = logical
1
Walter Roberson
Walter Roberson il 9 Dic 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.

Accedi per commentare.

Risposta accettata

Matt J
Matt J il 9 Dic 2023
Modificato: Matt J il 9 Dic 2023
sum_following = cumsum([s(2:end),0],"reverse");

Più risposte (0)

Categorie

Scopri di più su Loops and Conditional Statements in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by