Borrar filtros
Borrar filtros

How to obtain total sum by group

35 visualizaciones (últimos 30 días)
Siying Liu
Siying Liu el 18 de Dic. de 2015
Comentada: Geoff Hayes el 22 de Dic. de 2015
Hi, Could someone explain how to compute the total sum by group (without using for loop)?
A example is: groupid = [1; 1; 1; 2; 2; 3; 3;3]; value=[1;2;3;4;5;6;7;8]. the desired result is: runsum = [6;6;6;9;9; 21;21;21].
I am trying to get the result without using loop. Can "accumarray" do this?
Thanks a lot
Siying

Respuesta aceptada

Geoff Hayes
Geoff Hayes el 18 de Dic. de 2015
Siying - yes, accumarray can be used to sum elements of the same group. For example, we can do
groupSums = accumarray(groupid,value);
which gives us
groupSums =
6
9
21
with your runsum as
runsum = groupSums(groupid);
  3 comentarios
Siying Liu
Siying Liu el 22 de Dic. de 2015
I have one more following up question. The last line seems to work only if the groupSums is a vector, is there a way I can expand this method to a matrix? Thank you in advance!
Geoff Hayes
Geoff Hayes el 22 de Dic. de 2015
Which is the matrix: the group ids or values, or both? Please provide an example.

Iniciar sesión para comentar.

Más respuestas (2)

jgg
jgg el 18 de Dic. de 2015
Yes. This should work; it's probably not the shortest way to do it, but it avoids looping.
key = unique(groupid);
tsum = accumarray(groupid,value);
[~,idx] = ismember(groupid,key);
runsum = tsum(idx);

Walter Roberson
Walter Roberson el 18 de Dic. de 2015
group_sum = accumarray(groupid, value);
runsum = group_sum(A);
  1 comentario
Siying Liu
Siying Liu el 18 de Dic. de 2015
Yes! I did read that thread! The problem I have is don't know how to covert the group sum to the matrix I need without using a loop.
Thanks!

Iniciar sesión para comentar.

Categorías

Más información sobre Entering Commands en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by