How to find the 12th highest value for every year
1 view (last 30 days)
Show older comments
Nicky Benedict
on 7 Jun 2021
Answered: Nicky Benedict
on 9 Jun 2021
I have a data set that I have made into a table and used the sort funtion to make it into descending order based on the year followed by the 2nd column values i.e.
2014 3.98 10.34
2014 3.93 10.24
2014 3.90 10.18
.
.
.
2006 0.61 5.05
2006 0.54 5.01
2006 0.52 4.98
2006 0.50 4.89
2006 0.50 4.79
I want to find the 12th highest value for each year (the 12th row for every year).
The number of data measurements for each year are not equal. For example, in year 2014 there might be 12000 rows but in year 2010 there may only be 11500 rows of data
Thank you in advance.
0 Comments
Accepted Answer
More Answers (1)
SALAH ALRABEEI
on 7 Jun 2021
Since you already sorted them, what you need to do now is call the first highest 12 as follows
% Assuming the matrix is A where the 1st col is the years.
B = [];
years = unique(A(:,1));
for i = 1: length(years)
B= [B,(A(A(:,1)==years(i),12))];
end
3 Comments
SALAH ALRABEEI
on 9 Jun 2021
Sorry that was my mistake. Please add replace this wth what is inside the loop
%
btemp = A(A(:,1)==years(i),:);
B = [B ; btemp(12,:) ];
See Also
Categories
Find more on Matrix Indexing in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!