Python 分类和聚类结果的可视化 绘制出点的外接多边形 ConvexHull函数

以iris为例,最终画出来的图在最下面,真的很好看。

########################################################################
#Call required libraries
from sklearn import datasets
import numpy as np            # Data manipulation
import pandas as pd           # Dataframe manipulatio
import matplotlib.pyplot as plt              # For graphics
import seaborn as sns
from sklearn.cluster import KMeans, AgglomerativeClustering
from sklearn.mixture import GaussianMixture #For GMM clustering
from sklearn import metrics
from sklearn.decomposition import PCA
from scipy.spatial import ConvexHull


# 导入数据
iris = datasets.load_iris() 
data = pd.DataFrame(iris.data)
pca=PCA().fit(data) #降维后的数据只用于最后画图
print('方差累计贡献率为{}'.format(np.cumsum(pca.explained_variance_ratio_))) #取前两个
data_pca = pca.fit_transform(data)
y = iris.target


#Scaling of data
data_scaled = data.apply(lambda x: (x - np.min(x)) / (np.max(x) - np.min(x)))
#K means Clustering
ncluster = np.unique(y).shape[0]
Kmeans = KMeans(ncluster)
Kmeans.fit(data_scaled)
data.insert(0,'kmeans',pd.DataFrame(Kmeans.predict(data_scaled)))
# Agglomerative Clustering
agg = AgglomerativeClustering(ncluster, affinity = 'euclidean', linkage = 'ward')
data.insert(0,'agglomerative',pd.DataFrame(agg.fit_predict(data_scaled)))

#Guassian Mixture 
ModellingGuassian = GaussianMixture(n_components=ncluster,init_params='kmeans')
data.insert(0,'Guassian',pd.DataFrame(Guassian.fit_predict(data_scaled)))

#orignal
data.insert(0,'label',pd.DataFrame(y))


#Plot the clusters 
def ScatterWithBoundries(thecol,subplot):
    ax = fig.add_subplot(2,2,subplot)
    colors = ['red', 'black', 'blue', 'green', 'orange', 'pink']    
    scatter = plt.scatter(data_pca[:,0], data_pca[:,1], c=data[thecol], s=2, cmap='rainbow')    
    plt.title(thecol)        
    for i in np.unique(data[thecol]):    
        points = np.array(data_pca[:,:2][data[thecol] == i])        
        hull = ConvexHull(points)    
            for simplex in hull.simplices:            
            	plt.plot(points[simplex, 0], points[simplex, 1], 'k-', color=colors[i], linewidth=1.5)
            	
fig = plt.figure()
ScatterWithBoundries('label',1)
ScatterWithBoundries('Guassian',2)
ScatterWithBoundries('agglomerative',3)
ScatterWithBoundries('kmeans',4)
plt.show()



在这里插入图片描述
如果换个复杂些的数据,最后画出来的图会更漂亮:
在这里插入图片描述

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值