Finding the average of every nth row but n is not fixed.
3 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Hello,
Consider a nx2 matrix M with
M= [
1 10
1 11
1 20
2 4
2 9
2 8
2 7
.
.
.
];
How to find the average of the second column when the first column change values, i.e. "1 rows" have 3
values while "2 rows" have 4, etc. so we need the average of the 3 first values, then the next four, etc.
Thank you.
Réponse acceptée
Stephen23
le 23 Juil 2019
Modifié(e) : Stephen23
le 23 Juil 2019
>> M = [1,10;1,11;1,20;2,4;2,9;2,8;2,8];
>> V = accumarray(M(:,1),M(:,2),[],@mean)
V =
13.667
7.25
>> V = splitapply(@mean,M(:,2),M(:,1))
V =
13.667
7.25
And if you want those values back in the matrix:
>> M(:,3) = V(M(:,1))
M =
1 10 13.667
1 11 13.667
1 20 13.667
2 4 7.25
2 9 7.25
2 8 7.25
2 8 7.25
2 commentaires
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur Matrix Indexing dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!