python 중 K-means 알고리즘 기초 지식점

프로그래밍을 배우고 파악할 수 있는 가장 좋은 학습 방식은 기본적인 사용 기교를 파악하는 것이다. 아무리 개념적 의미가 많아도 결국은 서비스를 사용하기 위한 것이다. K-means 알고리즘은 K-균일치 알고리즘이라고도 하는데 비감독 학습 중의 분류 알고리즘이다.주로 세 개의 원소가 있는데 그 중에서 N은 원소의 개수이고 x는 원소를 나타내며 c(j)는 제j족의 질심을 나타낸다. 다음은 사용 방식을 간단하게 실례를 소개한다.
K-Means 알고리즘으로 분류 분석

km = KMeans(n_clusters = 3)
km.fit(X)
centers = km.cluster_centers_
print(centers)
세 클러스터의 중심점 좌표는 다음과 같습니다.
[[5.006 3.428 ]
[6.81276596 3.07446809]
[5.77358491 2.69245283]]
K-Means 컬렉션 결과와 실제 샘플 간의 차이점을 비교합니다.

predicted_labels = km.labels_
fig, axes = plt.subplots(1, 2, figsize=(16,8))
axes[0].scatter(X[:, 0], X[:, 1], c=y, cmap=plt.cm.Set1, 
        edgecolor='k', s=150)
axes[1].scatter(X[:, 0], X[:, 1], c=predicted_labels, cmap=plt.cm.Set1,
        edgecolor='k', s=150)
axes[0].set_xlabel('Sepal length', fontsize=16)
axes[0].set_ylabel('Sepal width', fontsize=16)
axes[1].set_xlabel('Sepal length', fontsize=16)
axes[1].set_ylabel('Sepal width', fontsize=16)
axes[0].tick_params(direction='in', length=10, width=5, colors='k', labelsize=20)
axes[1].tick_params(direction='in', length=10, width=5, colors='k', labelsize=20)
axes[0].set_title('Actual', fontsize=18)
axes[1].set_title('Predicted', fontsize=18)
k-means 알고리즘 인스턴스 확장 내용:

# -*- coding: utf-8 -*- 
"""Excercise 9.4"""
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import sys
import random

data = pd.read_csv(filepath_or_buffer = '../dataset/watermelon4.0.csv', sep = ',')[[" "," "]].values

########################################## K-means ####################################### 
k = int(sys.argv[1])
#Randomly choose k samples from data as mean vectors
mean_vectors = random.sample(data,k)

def dist(p1,p2):
 return np.sqrt(sum((p1-p2)*(p1-p2)))
while True:
 print mean_vectors
 clusters = map ((lambda x:[x]), mean_vectors) 
 for sample in data:
  distances = map((lambda m: dist(sample,m)), mean_vectors) 
  min_index = distances.index(min(distances))
  clusters[min_index].append(sample)
 new_mean_vectors = []
 for c,v in zip(clusters,mean_vectors):
  new_mean_vector = sum(c)/len(c)
  #If the difference betweenthe new mean vector and the old mean vector is less than 0.0001
  #then do not updata the mean vector
  if all(np.divide((new_mean_vector-v),v) < np.array([0.0001,0.0001]) ):
   new_mean_vectors.append(v) 
  else:
   new_mean_vectors.append(new_mean_vector) 
 if np.array_equal(mean_vectors,new_mean_vectors):
  break
 else:
  mean_vectors = new_mean_vectors 

#Show the clustering result
total_colors = ['r','y','g','b','c','m','k']
colors = random.sample(total_colors,k)
for cluster,color in zip(clusters,colors):
 density = map(lambda arr:arr[0],cluster)
 sugar_content = map(lambda arr:arr[1],cluster)
 plt.scatter(density,sugar_content,c = color)
plt.show()
이는python에서 K-means 알고리즘의 기초 지식에 관한 글을 소개합니다. 더 많은 관련python에서 K-means 알고리즘이 어떤 내용인지 저희 이전의 글을 검색하거나 아래의 관련 글을 계속 찾아보세요. 앞으로 많은 응원 부탁드립니다!

좋은 웹페이지 즐겨찾기