Множество — первичное понятие математики, не имеющее четкого определения. Под множеством подразумевается совокупность некоторых объектов, например книг в библиотеке, людей в зале или элементов вектора. Рассмотрим некоторые функции для обработки множеств, представленных векторами. Они широко используются при анализе и обработке данных.
- intersect(а,b) — возвращает пересечение множеств для двух векторов а и b, т. е., общие элементы векторов а и b. Результирующий вектор отсортирован по возрастанию. Если входные массивы не являются векторами, то они рассматриваются как совокупность векторов-столбцов а=а(:) или b=b(:);
- intersect(a,b, 'rows') — возвращает строки, общие для а и b, когда а и b представляют собой матрицы с одинаковым числом столбцов;
- [c,ia,lb] = intersect(a,b) — также возвращает вектор-столбец индексов ia и ib, но так, что с = a(ia) и с = b(ib) (или с = a(ia,:) и с = b(ib,:)). Пример:
» А = [1 7 2 6 ]; В - [7 2 3 4 6 1];
» [c,la,ib] = intersect(A,В)
с = 1 2 6 7
ia = 1 3 4 2
ib = 6 2 5 1
- ismember(a,S) — возвращает вектор той же длины, что и исходный а, содержащий логические единицы на месте тех элементов вектора а, которые принадлежат множеству S, и логические нули на месте тех элементов вектора а, которые не принадлежат множеству S;
|
|
- ismember(A,S, 'rows') — возвращает вектор, содержащий логические единицы там, где строки матрицы А являются также строками матрицы S, и логические нули в остальных позициях. А и S должны быть матрицами с одним числом столбцов.
Пример:
» set = [0 1 3 5 7 9 11 15 17 19];
» а = [1 2 3 4 5 6 7 8];
» k = ismember(a,set)
k = 1 0 1 0 1 0 1 0
- setdiff(a,b) — возвращает разность множеств, т. е., те элементы вектора а, которые не содержатся в векторе b. Результирующий вектор сортируется по возрастанию;
- setdiff(a,b, 'rows') — возвращает те строки из матрицы а, которые не содержатся в матрице b. Матрицы а и b должны иметь одинаковое число столбцов;
- [c,i] = setdiff(…) — возвращает также вектор индексов i, такой что с = a(i) или с = a(i,:).
Если входной массив а является матрицей, то он расценивается как вектор-столбец а(:).
Пример:
» а = [2 3 5 7 8 9 10 13 20];
» b = [1 4 5 6 8 9 4]
» с = setdiff(a,b)
с = 2 3 7 10 13 20
- setxor(a,b) — исключающее ИЛИ для векторов а и b. Результирующий вектор отсортирован;
- setxor(a,b, 'rows') — возвращает строки, которые не являются пересечениями матриц а и b. Матрицы а и b должны иметь одинаковое число столбцов;
- [c,ia,ib] = setxor(...) — возвращает также векторы индексов ia и 1b так, что с является отсортированной комбинацией элементов с = a(ia) и с = b(ib) или для комбинаций строк с = a(ia,:) и с = b(ib.:).
Если массив а является матрицей, то он расценивается как вектор-столбец а(:).
Пример:
» а = [-1 0 1 Inf - Inf NaN];
» b = [-2 pi 0 Inf];
» с = setxor(a,b)
с = -Inf -2.0000 -1.0000 1.0000 3.1416 NaN
- union(a, b) — возвращает вектор объединенных значений из а и b без повторяющихся элементов. Результирующий вектор сортируется в порядке возрастания;
|
|
- union (a, b,' rows') — возвращает объединенные строки из а и b, не содержащие повторений (а и b — это матрицы с одинаковым числом столбцов);
- [c,ia,ib] = union(...)— дополнительно возвращает iа и ib — векторы индексов, такие что с = a(ia) и c=b(ib), или, для объединенных строк, с = a(ia,:) и с = b(ib.:).
Невекторный массив а расценивается как вектор-столбец а(:). Пример:
» а = [2,4,-4,9,0]: b=[2,5,4];
» [c,ia,ib]=union(a,b)
с = -4 0 2 4 5 9
ia = 3 5 4
ib = 1 3 2
- unique(a) — возвращает значения элементов из а, не содержащие повторений. Результирующий вектор сортируется в порядке возрастания. Невекторный массив расценивается как вектор-столбец а=а(:);
- unique(a, 'rows') — возвращает уникальные строки а;
- [b,i,j] = unique (...) — дополнительно возвращает i и j — векторы индексов,
такие что b = a(i) и а = b(j) (или b = a(i,:) и а = b(j,:)).
Примеры:
» b=[-2,3,5,4,1,-6,2,2,7]
b = -2 3 5 4 1 -6 2 2 7
» [c,i,j] = unique(b)
с = -6 -2 1 2 3 4 5 7
I = 6 1 5 8 2 4 3 9
J = 2 5 7 6 3 1 4 4 8
» а=[-2,3,5;4,1,-6;2,2,7;-2,3,5]
а = -2 3 5
4 1 -6
2 2 7
-2 3 5
» c = unique(a,'rows')
с = -2 3 5
2 2 7
4 1 -6