ISBN :
Возрастное ограничение : 12
Дата обновления : 20.03.2024
– Иерархическая кластеризация
– DBSCAN
Рассмотрим их подробнее.
Метод k-Means (k-средних) – это один из наиболее распространенных методов кластеризации. Он основан на простой идее разделения набора данных на k кластеров, где каждый кластер представляет собой группу объектов, близких по среднему расстоянию до центроидов кластеров. Алгоритм k-Means состоит из нескольких шагов. Сначала случайным образом выбираются k центроидов. Затем каждый объект присваивается ближайшему центроиду, после чего центроиды перемещаются в центры объектов, принадлежащих кластерам. Этот процесс повторяется до тех пор, пока центроиды и кластеры не стабилизируются или не будет достигнуто максимальное количество итераций.
Преимущества метода k-Means включают его простоту реализации, эффективность на больших объемах данных и масштабируемость. Однако у метода также есть недостатки. В частности, требуется заранее знать количество кластеров, а также алгоритм чувствителен к начальному расположению центроидов и неустойчив к выбросам.
Метод k-Means является широко используемым инструментом для кластеризации данных благодаря своей простоте и эффективности, но при его использовании следует учитывать его ограничения и подходить к выбору количества кластеров с осторожностью.
Пример 1
Для этого примера давайте использовать набор данных Iris, который содержит информацию о различных видах ирисов. Наша задача будет состоять в кластеризации этих ирисов на основе их характеристик.
Описание задачи:
Набор данных Iris содержит четыре признака: длину и ширину чашелистиков и лепестков ирисов. Мы будем использовать эти признаки для кластеризации ирисов на несколько групп.
Описание хода решения:
1. Загрузка данных: Мы загрузим данные и посмотрим на них, чтобы понять их структуру.
2. Предварительная обработка данных: Если потребуется, мы выполним предварительную обработку данных, такую как масштабирование функций.
3. Кластеризация: Мы применим выбранный метод кластеризации (например, k-средних или иерархическую кластеризацию) к данным.
4. Визуализация результатов: Для лучшего понимания кластеризации мы визуализируем результаты, используя графики.
Давайте перейдем к коду.
Для начала нам нужно загрузить набор данных Iris. Мы будем использовать библиотеку `scikit-learn`, которая предоставляет доступ к этому набору данных. Загрузим данные и посмотрим на них.
```python
from sklearn.datasets import load_iris
# Загрузка данных Iris
iris = load_iris()
# Просмотр информации о данных
print(iris.DESCR)
```
Этот код загружает данные Iris и выводит их описание, чтобы мы могли понять структуру набора данных и его признаки.
После того, как мы ознакомились с данными, мы можем приступить к кластеризации. Для этого давайте выберем метод кластеризации, например, метод k-средних.
```python
from sklearn.cluster import KMeans
# Инициализация модели k-средних
kmeans = KMeans(n_clusters=3, random_state=42)
# Обучение модели на данных
kmeans.fit(iris.data)
# Получение меток кластеров для каждого объекта
labels = kmeans.labels_
```
Здесь мы инициализируем модель k-средних с 3 кластерами и обучаем её на данных Iris. Затем мы получаем метки кластеров для каждого объекта.
Наконец, мы можем визуализировать результаты кластеризации, чтобы лучше понять структуру данных.
```python
import matplotlib.pyplot as plt
# Визуализация кластеров
plt.scatter(iris.data[:, 0], iris.data[:, 1], c=labels, cmap='viridis')
plt.xlabel('Sepal length')
plt.ylabel('Sepal width')
plt.title('Clusters')
plt.show()
```
Этот код создает график, на котором каждый объект данных представлен точкой, а цвет точек указывает на принадлежность к кластеру. Таким образом, мы можем визуально оценить результаты кластеризации.
Таким образом, мы можем выполнить кластеризацию набора данных Iris с помощью метода k-средних и визуализировать результаты, чтобы лучше понять структуру данных.
Пример 2
Давайте рассмотрим другую задачу кластеризации с использованием набора данных "Mall Customer Segmentation", который содержит информацию о клиентах торгового центра. Наша цель будет состоять в кластеризации клиентов на основе их характеристик для выделения различных сегментов клиентов.
Описание задачи:
Набор данных "Mall Customer Segmentation" содержит информацию о клиентах торгового центра, такую как пол, возраст, доход и оценка расходов. Наша задача – разбить клиентов на кластеры на основе этих характеристик.
Описание хода решения:
1. Загрузка данных: Мы загрузим набор данных и посмотрим на его структуру и характеристики.
2. Предварительная обработка данных: Если необходимо, мы выполним предварительную обработку данных, такую как масштабирование функций или заполнение пропущенных значений.
3. Кластеризация: Мы применим выбранный метод кластеризации (например, k-средних или иерархическую кластеризацию) к данным о клиентах.
4. Визуализация результатов: Мы визуализируем результаты кластеризации, чтобы лучше понять структуру различных сегментов клиентов.
Давайте приступим к кодированию.
Для начала давайте загрузим набор данных "Mall Customer Segmentation" и изучим его структуру:
```python
import pandas as pd
# Загрузка данных
data = pd.read_csv('mall_customers.csv')
# Вывод первых нескольких строк данных для ознакомления
print(data.head())
```
После загрузки данных мы можем выполнить предварительную обработку, если это необходимо. В данном случае данные уже предобработаны и готовы к кластеризации.
Теперь давайте приступим к кластеризации. Для этого воспользуемся методом кластеризации k-средних:
```python
from sklearn.cluster import KMeans
# Инициализация модели k-средних
kmeans = KMeans(n_clusters=5, random_state=42)
# Обучение модели на данных
kmeans.fit(data)
# Получение меток кластеров для каждого клиента
labels = kmeans.labels_
```
Теперь у нас есть метки кластеров для каждого клиента. Мы можем визуализировать результаты кластеризации, чтобы лучше понять структуру различных сегментов клиентов:
```python
import matplotlib.pyplot as plt
# Визуализация кластеров
plt.scatter(data['Age'], data['Annual Income (k$)'], c=labels, cmap='viridis')
plt.xlabel('Age')
plt.ylabel('Annual Income (k$)')
plt.title('Clusters of Mall Customers')
plt.show()
```
Этот код создает график, на котором каждый клиент представлен точкой, а цвет точек указывает на принадлежность к кластеру. Таким образом, мы можем визуально оценить результаты кластеризации и выделить различные сегменты клиентов в торговом центре.
Иерархическая кластеризация
Это метод, который строит иерархию кластеров, представляющую собой древовидную структуру, называемую дендрограммой. Принцип работы этого метода заключается в постепенном объединении ближайших кластеров до тех пор, пока все объекты не окажутся в единственном кластере.
На первом шаге каждый объект представляет собой отдельный кластер. Затем на каждом последующем шаге два ближайших кластера объединяются в один. Этот процесс повторяется до тех пор, пока все объекты не соберутся в одном кластере.
Иерархическая кластеризация имеет ряд преимуществ. В отличие от метода k-средних, она не требует знания количества кластеров заранее, что делает ее более удобной в использовании. Кроме того, возможность визуализации дендрограммы позволяет анализировать иерархию кластеров и принимать более обоснованные решения.
Однако у этого метода есть и недостатки. Иерархическая кластеризация может быть неэффективной на больших наборах данных из-за сложности вычислений, особенно при использовании полной матрицы расстояний между объектами. Кроме того, этот метод может быть неустойчивым к выбросам, что может привести к нежелательным результатам.
Пример 1
Давайте рассмотрим пример использования иерархической кластеризации на наборе данных о потреблении энергии в различных странах. Допустим, у нас есть данные о потреблении энергии по разным источникам в нескольких странах. Наша задача – провести кластеризацию этих стран на группы с похожими паттернами потребления энергии.
1. Подготовка данных: Загрузим данные о потреблении энергии в разных странах.
Все книги на сайте предоставены для ознакомления и защищены авторским правом