博客
关于我
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/

    你可能感兴趣的文章
    nodejs模块——fs模块
    查看>>
    Nodejs模块、自定义模块、CommonJs的概念和使用
    查看>>
    nodejs生成多层目录和生成文件的通用方法
    查看>>
    nodejs端口被占用原因及解决方案
    查看>>
    Nodejs简介以及Windows上安装Nodejs
    查看>>
    nodejs系列之express
    查看>>
    nodejs系列之Koa2
    查看>>
    Nodejs连接mysql
    查看>>
    nodejs连接mysql
    查看>>
    NodeJs连接Oracle数据库
    查看>>
    nodejs配置express服务器,运行自动打开浏览器
    查看>>
    NodeMCU教程 http请求获取Json中文乱码解决方案
    查看>>
    Nodemon 深入解析与使用
    查看>>
    NodeSession:高效且灵活的Node.js会话管理工具
    查看>>
    node~ http缓存
    查看>>
    node不是内部命令时配置node环境变量
    查看>>
    node中fs模块之文件操作
    查看>>
    Node中同步与异步的方式读取文件
    查看>>
    node中的get请求和post请求的不同操作【node学习第五篇】
    查看>>
    Node中的Http模块和Url模块的使用
    查看>>