Clear Filters
Clear Filters

error using unique function

34 views (last 30 days)
Danielle Leblanc
Danielle Leblanc on 26 Jul 2012
s is a cell matrix (178000x9) I want to find the unique values of s in the first column. ID=unique(s(:,1));
I received the following error. Error using cell/unique (line 95) Input A must be a cell array of string
what could be the reason?
  1 Comment
Sean de Wolski
Sean de Wolski on 26 Jul 2012
If the first column is all non-numeric it would not be throwing that error. What is returned from:
iscellstr(s(:,1))

Sign in to comment.

Accepted Answer

Mike Hosea
Mike Hosea on 26 Jul 2012
Edited: Mike Hosea on 26 Jul 2012
What type of data is in the cell array? When you use UNIQUE on a cell array, the only case that's supported is when the elements of the cell array are strings. Is that case not working for you?
>> c = {'abc','abc','def','defg'}';
>> unique(c(:,1))
ans =
'abc'
'def'
'defg'
  7 Comments
Mike Hosea
Mike Hosea on 26 Jul 2012
Yes, this is what we expected. You do not have a cell array of only strings. You can find the non-strings with
find(cellfun(@(x)~ischar(x),s))
You do not mention where this data came from. If it began as a
s = cell(m,n);
and was later partially populated, then you might resolve the problem by changing that to
s = repmat({''},m,n);
Danielle Leblanc
Danielle Leblanc on 26 Jul 2012
Thanks this solved the problem

Sign in to comment.

More Answers (1)

Wayne King
Wayne King on 26 Jul 2012
Edited: Wayne King on 26 Jul 2012
Is it a cell array of numeric values?
You can use cell2mat()
A = {1 5 9 ; 2 3 4; 2 4 5};
B = unique(cell2mat(A(:,1)));
  1 Comment
Danielle Leblanc
Danielle Leblanc on 26 Jul 2012
column 1 contains names . it is non-numeric

Sign in to comment.

Categories

Find more on Cell Arrays in Help Center and File Exchange

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!