How to average a column based on another column?
    8 visualizaciones (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
    Leon
      
 el 20 de Feb. de 2014
  
    
    
    
    
    Comentada: Leon
      
 el 20 de Feb. de 2014
            For example, I have a two column data as below:
1945   23.5
1952   25.6
1952   25.9
1952   23.5
1957   26.7
1957   31.2
How do I get a two column data as below, with the left column being the unique numbers: 1945, 1952, 1957, and the second column being the average values of that year:
1945   23.5
1952   25.0
1957   28.95
I can write a loop to do this, but think it must have an easier way to do this.
Thank you@
0 comentarios
Respuesta aceptada
  Matt Kindig
      
 el 20 de Feb. de 2014
        This is a good use of accumarray():
[ud,ix,iy]=unique( data(:,1));  
output = [ud, accumarray(iy,data(:,2),[],@mean)];
Más respuestas (0)
Ver también
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

