博客
关于我
Algorithm: K-Means
阅读量:373 次
发布时间:2019-03-04

本文共 3098 字,大约阅读时间需要 10 分钟。

K-Means????

K-Means ????

K-Means???????????????????????????????????????????????????????????????????????????????????????????

K-Means ?????

K-Means????????????????????

  • ???????????????????
  • ???????????????????????????????????????
  • ????????????????????????????
  • ?????????????????????????????????????????????
  • K-Means ?????

    K-Means???????????????

  • ??????????????????????????????
  • ?????????????????????????????
  • ???????CRM???????????????????????
  • K-Means ?????

    Python ??????

    # ??????from copy import deepcopyimport numpy as npimport pandas as pdimport matplotlib.pyplot as plt# ????k = 3# ?????????X = np.random.random((200, 2)) * 10# ??????????C_x = np.random.choice(range(0, int(np.max(X[:, 0])), size=k, replace=False))C_y = np.random.choice(range(0, int(np.max(X[:, 1])), size=k, replace=False))C = np.array(list(zip(C_x, C_y)), dtype=np.float32)# ????????print("????????", C)# ????????????plt.scatter(X[:, 0], X[:, 1], c='#050505', s=7)plt.scatter(C[:, 0], C[:, 1], marker='*', s=300, c='g')plt.show()

    ??????

    # ?????C_old = np.zeros(C.shape)clusters = np.zeros(len(X))# ????????def dist(a, b, ax=1):    return np.linalg.norm(a - b, axis=ax)# ???????????error = dist(C, C_old, None)while error != 0:    # ???????    for i in range(len(X)):        distances = dist(X[i], C)        clusters[i] = np.argmin(distances)        # ????????    C_old = deepcopy(C)        # ??????    for i in range(k):        points = [X[j] for j in range(len(X)) if clusters[j] == i]        C[i] = np.mean(points, axis=0)        # ????    error = dist(C, C_old, None)    # ??????    colors = ['r', 'g', 'b', 'y', 'c', 'm']    fig, ax = plt.subplots()    for i in range(k):        points = np.array([X[j] for j in range(len(X)) if clusters[j] == i])        ax.scatter(points[:, 0], points[:, 1], s=7, c=colors[i])    ax.scatter(C[:, 0], C[:, 1], marker='*', s=200, c='#050505')    plt.show()

    K-Means ?????

    1. ????

    K-Means??????????????????????????????????????????????

    2. ?????

    ??K-Means???????????????????????????????????????????????????????????????????????????????

    K-Means ????????

    1. K-Means vs Hard Clustering

    K-Means?????????????????????????????????????????Soft Clustering????GMM?????????????????????

    2. K-Means ????

  • ????????K-Means????????????????????????????
  • ??????K-Means?????????O(n^2k)?????????????????
  • K-Means ?????????

    ??????????????K-Means??????????????????????

  • ??????
    img = imread('Tulips.jpg')imshow(img)show()
  • ??K-Means??
    model = KMeans(n_clusters=3)labels = model.fit_predict(pixel)
  • ??????
    palette = model.cluster_centersfor i in range(len(pixel)):    pixel_new[i, :] = palette[labels[i]]
  • ????????
    imshow(pixel_new.reshape(img.shape[0], img.shape[1], 3))show()
  • K-Means ?????

  • ????????

    K-Means????????????????????????????????????????????

  • ??????

    ??????????????????????????????????????????????????????

  • ?????

    ?????????K-Means????????????????????????????????????????????

  • K-Means ??????

    ??K-Means?????????????????????????

  • ??????????????????????????
  • ????????????????K-Means??????????????????
  • ???????K-Means??????????????????????????
  • ??

    K-Means??????????????????????????????????????????????????????????????????K-Means?????????

    转载地址:http://cvbg.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现2D变换算法(附完整源码)
    查看>>
    Objective-C实现3n+1猜想(附完整源码)
    查看>>
    Objective-C实现3n+1猜想(附完整源码)
    查看>>
    Objective-C实现9x9乘法表算法(附完整源码)
    查看>>
    Objective-C实现9×9二维数组数独算法(附完整源码)
    查看>>
    Objective-C实现A*(A-Star)算法(附完整源码)
    查看>>
    Objective-C实现A-Star算法(附完整源码)
    查看>>
    Objective-C实现abbreviation缩写算法(附完整源码)
    查看>>
    Objective-C实现ABC人工蜂群算法(附完整源码)
    查看>>
    Objective-C实现activity selection活动选择问题算法(附完整源码)
    查看>>
    Objective-C实现AC算法(Aho-Corasick) 算法(附完整源码)
    查看>>
    Objective-C实现adaboost算法(附完整源码)
    查看>>
    Objective-C实现Adler32算法(附完整源码)
    查看>>
    Objective-C实现AES算法(附完整源码)
    查看>>
    Objective-C实现AffineCipher仿射密码算法(附完整源码)
    查看>>
    Objective-C实现aliquot sum等分求和算法(附完整源码)
    查看>>
    Objective-C实现all combinations所有组合算法(附完整源码)
    查看>>
    Objective-C实现all permutations所有排列算法(附完整源码)
    查看>>
    Objective-C实现all subsequences所有子序列算法(附完整源码)
    查看>>
    Objective-C实现AlphaNumericalSort字母数字排序算法(附完整源码)
    查看>>