<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          如何利用K-Means將文件夾中圖像進(jìn)行分類?

          共 3016字,需瀏覽 7分鐘

           ·

          2021-02-22 10:14

          點(diǎn)擊上方小白學(xué)視覺(jué)”,選擇加"星標(biāo)"或“置頂

          重磅干貨,第一時(shí)間送達(dá)

          K-Means聚類是最常用的無(wú)監(jiān)督機(jī)器學(xué)習(xí)算法之一。顧名思義,它可用于創(chuàng)建數(shù)據(jù)集群,從本質(zhì)上將它們隔離。

          現(xiàn)在,我們將做一個(gè)簡(jiǎn)單的示例,將文件夾中的圖像進(jìn)行分離,該文件夾既有貓也有狗的圖像。并且將創(chuàng)建兩個(gè)單獨(dú)的文件夾(群集),我們將介紹如何自動(dòng)確定K的最佳值。


          貓和狗的圖像數(shù)據(jù)集

          首先,我們將從導(dǎo)入所需的庫(kù)開(kāi)始。

          import numpy as npimport tensorflow as tfimport matplotlib.pyplot as pltfrom sklearn.cluster import KMeansfrom sklearn.metrics import silhouette_scoreimport cv2import os, glob, shutil
          然后我們會(huì)從文件夾中的圖像讀取所有的圖像并對(duì)其進(jìn)行處理,以提取特征提取。我們將圖像大小調(diào)整為224x224,以匹配模型輸入層的大小以進(jìn)行特征提取。
          input_dir = 'pets'glob_dir = input_dir + '/*.jpg'images = [cv2.resize(cv2.imread(file), (224, 224)) for file in glob.glob(glob_dir)]paths = [file for file in glob.glob(glob_dir)]images = np.array(np.float32(images).reshape(len(images), -1)/255)

          現(xiàn)在,我們將在MobileNetV2(傳輸學(xué)習(xí))的幫助下進(jìn)行特征提取。當(dāng)然我們可以使用ResNet50,InceptionV3等,但是MobileNetV2速度很快,而且資源也不是很多。

          model = tf.keras.applications.MobileNetV2(include_top=False,weights=’imagenet’, input_shape=(224, 224, 3))predictions = model.predict(images.reshape(-1, 224, 224, 3))pred_images = predictions.reshape(images.shape[0], -1)

          現(xiàn)在,我們已經(jīng)實(shí)現(xiàn)了提取功能,現(xiàn)在可以使用KMeans進(jìn)行聚類了。

          k = 2kmodel = KMeans(n_clusters = k, n_jobs=-1, random_state=728)kmodel.fit(pred_images)kpredictions = kmodel.predict(pred_images)shutil.rmtree(‘output’)for i in range(k):    os.makedirs(“output\cluster” + str(i))for i in range(len(paths)):    shutil.copy2(paths[i], “output\cluster”+str(kpredictions[i]))

          輸出結(jié)果如下:

          小狗:

          貓:

          另外我們?nèi)绾未_定數(shù)據(jù)集的K值?我們可以使用輪廓法或肘部法確定它。我們將在這里使用輪廓法,當(dāng)然這兩種方法都可獲得最可靠的結(jié)果,所以能直接確定K。


          當(dāng)我們將馬的圖像添加到原始數(shù)據(jù)集中時(shí),我們來(lái)確定K的值。

          sil = []kl = []kmax = 10for k in range(2, kmax+1):    kmeans2 = KMeans(n_clusters = k).fit(pred_images)    labels = kmeans2.labels_    sil.append(silhouette_score(pred_images, labels, metric =   ‘euclidean’))    kl.append(k)
          現(xiàn)在,我們將繪制圖像:
          plt.plot(kl, sil)plt.ylabel(‘Silhoutte Score’)plt.ylabel(‘K’)plt.show()


          如我們所見(jiàn),K的最佳值為3,我們還成功創(chuàng)建了第三個(gè)集群:



          結(jié)論

              

          如我們所見(jiàn),K-Means聚類是用于圖像分離的出色算法。在某些時(shí)候,我們使用的方法可能無(wú)法提供準(zhǔn)確的結(jié)果,我們可以嘗試使用其他卷積神經(jīng)網(wǎng)絡(luò)對(duì)其進(jìn)行修復(fù),或者嘗試將圖像從BGR轉(zhuǎn)換為RGB,然后進(jìn)行處理。


          下載1:OpenCV-Contrib擴(kuò)展模塊中文版教程
          在「小白學(xué)視覺(jué)」公眾號(hào)后臺(tái)回復(fù):擴(kuò)展模塊中文教程,即可下載全網(wǎng)第一份OpenCV擴(kuò)展模塊教程中文版,涵蓋擴(kuò)展模塊安裝、SFM算法、立體視覺(jué)、目標(biāo)跟蹤、生物視覺(jué)、超分辨率處理等二十多章內(nèi)容。

          下載2:Python視覺(jué)實(shí)戰(zhàn)項(xiàng)目52講
          小白學(xué)視覺(jué)公眾號(hào)后臺(tái)回復(fù):Python視覺(jué)實(shí)戰(zhàn)項(xiàng)目,即可下載包括圖像分割、口罩檢測(cè)、車道線檢測(cè)、車輛計(jì)數(shù)、添加眼線、車牌識(shí)別、字符識(shí)別、情緒檢測(cè)、文本內(nèi)容提取、面部識(shí)別等31個(gè)視覺(jué)實(shí)戰(zhàn)項(xiàng)目,助力快速學(xué)校計(jì)算機(jī)視覺(jué)。

          下載3:OpenCV實(shí)戰(zhàn)項(xiàng)目20講
          小白學(xué)視覺(jué)公眾號(hào)后臺(tái)回復(fù):OpenCV實(shí)戰(zhàn)項(xiàng)目20講,即可下載含有20個(gè)基于OpenCV實(shí)現(xiàn)20個(gè)實(shí)戰(zhàn)項(xiàng)目,實(shí)現(xiàn)OpenCV學(xué)習(xí)進(jìn)階。

          交流群


          歡迎加入公眾號(hào)讀者群一起和同行交流,目前有SLAM、三維視覺(jué)、傳感器、自動(dòng)駕駛、計(jì)算攝影、檢測(cè)、分割、識(shí)別、醫(yī)學(xué)影像、GAN、算法競(jìng)賽等微信群(以后會(huì)逐漸細(xì)分),請(qǐng)掃描下面微信號(hào)加群,備注:”昵稱+學(xué)校/公司+研究方向“,例如:”張三 + 上海交大 + 視覺(jué)SLAM“。請(qǐng)按照格式備注,否則不予通過(guò)。添加成功后會(huì)根據(jù)研究方向邀請(qǐng)進(jìn)入相關(guān)微信群。請(qǐng)勿在群內(nèi)發(fā)送廣告,否則會(huì)請(qǐng)出群,謝謝理解~


          瀏覽 63
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評(píng)論
          圖片
          表情
          推薦
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  午夜性爱网 | 91性爱| www草逼| 国产成人黄色毛片不卡在线看 | 日韩丝袜足交视频网站 |