码迷,mamicode.com
首页 > 其他好文 > 详细

中国mooc北京理工大学机器学习第一周(三)

时间:2017-05-21 19:47:38      阅读:231      评论:0      收藏:0      [点我收藏+]

标签:循环   res   code   jpeg   image   pre   range   提示   append   

三、基于聚类的整图分割

需要利用PIL进行图片处理,在anaconda安装的时候提示PIL只能用在py26,搜索知,可以conda install pillow 即可。

     
    def loadData(filePath):
        f = open(filePath,rb)
        data = []
        img = image.open(f)
        m,n = img.size
        for i in range(m):
            for j in range(n):
                x,y,z = img.getpixel((i,j))  #getpixel
                data.append([x/256.0,y/256.0,z/256.0])
        f.close()
        return np.mat(data),m,n
     
    imgData,row,col = loadData(Desktop\\12.jpg)#双斜杠
    
    label = KMeans(n_clusters=8).fit_predict(imgData)#进行聚类,找同类
    print(label)
    label = label.reshape([row,col])
    print(label)
    pic_new = image.new("L", (row, col))
    for i in range(row):
        for j in range(col):
            pic_new.putpixel((i,j), int(256/(label[i][j]+1)))#双循环putpixel
    pic_new.save("Desktop\\12-8.jpg", "JPEG")

代码比较简单,应用层面上需要注意的是图像的格式与几个像素点的问题。

以上:)

中国mooc北京理工大学机器学习第一周(三)

标签:循环   res   code   jpeg   image   pre   range   提示   append   

原文地址:http://www.cnblogs.com/deleteme/p/6885628.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!