Sort matrix in specific order
10 views (last 30 days)
Show older comments
Hello everyone,
I have created a 288:4 matrix in which the third column consists of the numbers 1,2 and 3. I would like to sort the matrix so that each number in column three is repeated 6 times for 16 times in total while also making sure that
- there will be no 6-digit-blocks of the same number twice in a row (i.e. 1 1 1 1 1 1 ; 2 2 2 2 2 2 ; 1 1 1 1 1 1 and NOT 1 1 1 1 1 1 ; 1 1 1 1 1 1 ; 2 2 2 2 2 2)
- each column is moved with the corresponding content of the other columns in that row (this is why I cannot just create a new matrix with the order I need and replace it with the third column)
I would really appreciate your help!
Thanks a lot in advance Letizia
1 Comment
Image Analyst
on 20 Feb 2018
"I have created a 288:4 matrix" Please attach this matrix in a .mat file with the paper clip icon. Also, you have not actually asked an actual question, just made an announcement. Do you have a question?
You say "each column is moved with the corresponding content of the other columns in that row" Well, I have no idea what that means. Tell me again exactly where do you want to move the column? Or do you just want to move all rows together, in synchrony, so that each column is sorted identically to all the other columns?
Answers (1)
letizia533
on 20 Feb 2018
1 Comment
Walter Roberson
on 20 Feb 2018
Generally speaking
[~, sort_order] = sort(A(:,appropriate_column_number));
A2 = A(sort_order, :);
See Also
Categories
Find more on Shifting and Sorting Matrices 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!