Sort a matrix according to the index of a vector

3 views (last 30 days)
zeu
zeu on 20 Nov 2017
Commented: zeu on 21 Nov 2017
I have following labels for the rows and columns of a square matrix:
labels = {'dog', 'car', 'fish'}'
The corresponding matrix that expresses the semantic similarity between the terms is
D = [[0 0.8 0.2];
[0.8 0 0.7];
[0.2 0.7 0]];
I want to sort matrix and labels after following index
idx = [1 2 1];
Sorting the labels is easy:
[values,isort]=sort(idx);
labels_sort = labels(isort)
labels_sort =
3×1 cell array
{'dog' }
{'fish'}
{'car' }
But how can i sort the matrix D accordingly?
  2 Comments
KL
KL on 20 Nov 2017
Edited: KL on 20 Nov 2017
You have created the very same question 3 times. You haven't replied to the comments on your previous posts but just deleted them entirely. Please do not spam the forum, if the answer below is not what you are looking for, provide more information (such as the expected result) and ask follow-up questions.
zeu
zeu on 21 Nov 2017
You are absolutly right. It was my first time a postet a question here. Next time I ll think more before!

Sign in to comment.

Answers (1)

KL
KL on 20 Nov 2017
Edited: KL on 20 Nov 2017
if you want to sort the rows of D according to isort, try
newD = D(isort,:)
newD =
0 0.8000 0.2000
0.2000 0.7000 0
0.8000 0 0.7000
  8 Comments
zeu
zeu on 21 Nov 2017
Edited: zeu on 21 Nov 2017
Your answer is unfortunatley not what I m looking for. The indexing array means that the words with the same index belong to the same category. E.g. "dog" and "fish" belong to category 1 (animals), thats why they have the index 1."Car" belongs to category 2 (man-made objects) and has index 2. In the end there will be around 6 different categories and a few hundred terms to sort after them.
zeu
zeu on 21 Nov 2017
Is it possible to solve it by uniting the matrix and the labels into a table and then sorting the table after the labels? Or maybe by using a name-value pair?

Sign in to comment.

Categories

Find more on Just for fun 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!