В этом примере показано, как использовать реляционные операции с категориальным массивом.
Создайте 2 4 массив ячеек из символьных векторов.
C = {'blue' 'red' 'green' 'blue';... 'blue' 'green' 'green' 'blue'}; colors = categorical(C)
colors = 2x4 categorical array
blue red green blue
blue green green blue
colors
2 4 категориальный массив.
Перечислите категории категориального массива.
categories(colors)
ans = 3x1 cell array
{'blue' }
{'green'}
{'red' }
Используйте оператор отношения, eq
(==
), чтобы сравнить первые и вторые строки colors
.
colors(1,:) == colors(2,:)
ans = 1x4 logical array
1 0 1 1
Только значения во втором столбце отличаются между строками.
Сравните целый категориальный массив, colors
, к вектору символов 'blue'
найти местоположение всего blue
значения.
colors == 'blue'
ans = 2x4 logical array
1 0 0 1
1 0 0 1
В colors
существует четыре синих записи, один в каждом углу массива.
Добавьте математическое упорядоченное расположение категориям в colors
. Задайте порядок категории, который представляет упорядоченное расположение спектра цветов, red < green < blue
.
colors = categorical(colors,{'red','green' 'blue'},'Ordinal',true)
colors = 2x4 categorical array
blue red green blue
blue green green blue
Элементы в категориальном массиве остаются то же самое.
Перечислите дискретные категории в colors
.
categories(colors)
ans = 3x1 cell array
{'red' }
{'green'}
{'blue' }
Определите если элементы в первом столбце colors
больше элементов во втором столбце.
colors(:,1) > colors(:,2)
ans = 2x1 logical array
1
1
Оба значения в первом столбце, blue
, больше соответствующих значений во втором столбце, red
и green
.
Найдите все элементы в colors
это меньше 'blue'
.
colors < 'blue'
ans = 2x4 logical array
0 1 1 0
0 1 1 0
Функциональный lt
(<
) указывает на местоположение всего green
и red
значения с 1
.