What is the problem in simple matrix operation.?

1 view (last 30 days)
clear all;clc
names = {'A'; 'B'; 'C'; 'D'};
marks = [27; 48; 84; 22];
in_st = {names marks};
in_st = [names num2cell(marks)];
function [op_st1,op_st2] = print_Data(in_st)
in_st = in_st;
[~,idx] = sort(in_st(:,1));
op_st1 = in_st(idx,:)
[~,idx] = sort(in_st(:,2),'descend');
op_st2 = in_st(idx,:)
I want op_st1 in ascending order, and op_st2 in descending order. It works well upto half program, what is the problem in remaining..?
  2 Comments
Nimisha
Nimisha on 23 Nov 2014
Error using sort
DIM and MODE arguments not supported for cell arrays.
Error in print_Data (line 6)
[~,idx] = sort(in_st(:,2),'descend');
The above error message i am getting

Sign in to comment.

Accepted Answer

Guillaume
Guillaume on 23 Nov 2014
As the error message says and the documentation of sort states, you can't use the DIM and MODE arguments when sorting cell arrays.
However, since the descending order is just the reverse of the ascending order, why don't you just flip your first sort?
[~, idx] = sort(in_st(:, 1));
op_st1 = in_st(idx, :);
op_st2 = in_st(flipud(idx), :);
  2 Comments
Nimisha
Nimisha on 23 Nov 2014
ITS true what you understand. In my program, i mean to say that, as a fisrt
op_st1
i want to ascend names, that is true in program, BUT in
op_st2
i want to descend marks, means second column..! Still not working.""
Guillaume
Guillaume on 23 Nov 2014
Oh, yes, sorry, I missed that. You can still reverse do what I said but on column 2:
[~, idx] = sort(in_st(:, 2));
op_st2 = in_st(flipud(indx), :);
Or you could convert column 2 to matrix:
[~, idx] = sort(cell2mat(in_st(:, 2)), 'descend');

Sign in to comment.

More Answers (1)

Azzi Abdelmalek
Azzi Abdelmalek on 23 Nov 2014
Edited: Azzi Abdelmalek on 23 Nov 2014
Use curly brackets { }
[~,idx] = sort(in_st{:,2},'descend')
  3 Comments
Nimisha
Nimisha on 23 Nov 2014
Error using sort
Too many input arguments.
Error in print_Data (line 6)
[~,idx] = sort(in_st{:,2},'descend')

Sign in to comment.

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!