Using accumarray to do sum with duplicate indicies

5 views (last 30 days)
Hi folks, Let f and A be arrays with size(f) = [N,1] and size(A) = [M,1] with N > M. Let J be a list of indices for f with size(J) = size(A). I wish to compute the for loop
for k = 1:M,
f(J(k)) = f(J(k)) + A(k);
end
However, due to time constraints I need to do this computation without the for loop. If all the indices J were unique I would simply say f(J) = f(J) + A. However, I will need to consider the case where there are many duplicate indices in J. I suspect this can be accomplished with accumarray, but its not clear to me how to do this. Does anybody have any suggestions?
Thanks, Paul
  1 Comment
the cyclist
the cyclist on 24 Sep 2017
It would be helpful to include a small example that is general enough for your use case, showing what the input and expected output are.

Sign in to comment.

Accepted Answer

Matt J
Matt J on 24 Sep 2017
Edited: Matt J on 24 Sep 2017
Yes, it is a direct application of accumarray,
f=f+accumarray(J,A,size(f));

More Answers (0)

Categories

Find more on Loops and Conditional Statements in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!