DBSCAN聚類

#!/usr/bin/python
# coding=utf-8
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from sklearn import datasets
from sklearn.cluster import KMeans, DBSCAN
# 畫圖支持中文顯示
from pylab import *
mpl.rcParams['font.sans-serif'] = ['SimHei']
# 負號
plt.rcParams['axes.unicode_minus'] = False

# 顯示所有列
pd.set_option('display.max_columns', None)
# 顯示所有行
pd.set_option('display.max_rows', None)
# 設(shè)置value的顯示長度為10000,默認為50
pd.set_option('display.width',10000)
pd.set_option('display.unicode.ambiguous_as_wide', True)
pd.set_option('display.unicode.east_asian_width', True)
#
np.set_printoptions(linewidth=1000)

# %matplotlib inline

# 造數(shù)據(jù)
X1, y1 = datasets.make_circles(n_samples=5000, factor=.6, noise=.05, random_state=9) # 非凸
X2, y2 = datasets.make_blobs(n_samples=1000, n_features=2, centers=[[1.2,1.2]], cluster_std=[[.1]], random_state=9) # 凸
'''DBSCAN在非凸數(shù)據(jù)聚類上有優(yōu)勢'''
print(type(X1), type(y2))
print('X1:\n', X1[0:3], '\ny1:\n', y1[0:3], '\nX2:\n', X2[0:3], '\ny2:\n', y2[0:3])

X = np.concatenate((X1, X2))
Y = np.concatenate((y1, y2))
print('X:\n', X[0:3], '\nY:\n', Y[0:3])
plt.scatter(X[:, 0], X[:, 1], marker='o')
plt.show()

# k-means
y_pred = KMeans(n_clusters=3, random_state=9).fit_predict(X)
plt.figure()
plt.title('k-means聚類')
plt.scatter(X[:, 0], X[:, 1], c=y_pred)
plt.savefig('G:\\rnn\k-means聚類.png')
plt.show()

# DBSCAN
y_pred = DBSCAN(eps=0.1, min_samples=10).fit_predict(X) # 減少?-鄰域的大小猪钮,默認是0.5罚舱,減到0.1
plt.figure()
plt.title('DBSCAN聚類')
plt.scatter(X[:, 0], X[:, 1], c=y_pred)
plt.savefig('G:\\rnn\DBSCAN聚類.png')
plt.show()
G:\rasa_demo\decision_tree\venv\Scripts\python.exe G:/rasa_demo/decision_tree/dbscan.py
<class 'numpy.ndarray'> <class 'numpy.ndarray'>
X1:
 [[-0.86315295  0.47850988]
 [ 0.7739279  -0.72241513]
 [ 0.60629645  0.24250833]] 
y1:
 [0 0 1] 
X2:
 [[1.23974288 1.36597036]
 [1.19910822 1.35391397]
 [1.11447743 1.20255205]] 
y2:
 [0 0 0]
X:
 [[-0.86315295  0.47850988]
 [ 0.7739279  -0.72241513]
 [ 0.60629645  0.24250833]] 
Y:
 [0 0 1]

Process finished with exit code 0
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市链沼,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖季俩,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件栅组,死亡現(xiàn)場離奇詭異雀瓢,居然都是意外死亡,警方通過查閱死者的電腦和手機玉掸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進店門刃麸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人司浪,你說我怎么就攤上這事泊业“颜樱” “怎么了?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵吁伺,是天一觀的道長饮睬。 經(jīng)常有香客問我,道長篮奄,這世上最難降的妖魔是什么捆愁? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮窟却,結(jié)果婚禮上昼丑,老公的妹妹穿的比我還像新娘。我一直安慰自己夸赫,他們只是感情好菩帝,可當(dāng)我...
    茶點故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著憔足,像睡著了一般胁附。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上滓彰,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天控妻,我揣著相機與錄音,去河邊找鬼揭绑。 笑死弓候,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的他匪。 我是一名探鬼主播菇存,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼邦蜜!你這毒婦竟也來了依鸥?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤悼沈,失蹤者是張志新(化名)和其女友劉穎贱迟,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體絮供,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡衣吠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了壤靶。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片缚俏。...
    茶點故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出忧换,到底是詐尸還是另有隱情恬惯,我是刑警寧澤,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布包雀,位于F島的核電站宿崭,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏才写。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一奖蔓、第九天 我趴在偏房一處隱蔽的房頂上張望赞草。 院中可真熱鬧,春花似錦吆鹤、人聲如沸厨疙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽沾凄。三九已至,卻和暖如春知允,著一層夾襖步出監(jiān)牢的瞬間撒蟀,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工温鸽, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留保屯,地道東北人。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓涤垫,卻偏偏與公主長得像姑尺,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蝠猬,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,055評論 2 355