python中学习K-Means和图片压缩


Posted in Python onNovember 20, 2017

大家在学习python中,经常会使用到K-Means和图片压缩的,我们在此给大家分享一下K-Means和图片压缩的方法和原理,喜欢的朋友收藏一下吧。

python中学习K-Means和图片压缩

通俗的介绍这种压缩方式,就是将原来很多的颜色用少量的颜色去表示,这样就可以减小图片大小了。下面首先我先介绍下K-Means,当你了解了K-Means那么你也很容易的可以去理解图片压缩了,最后附上图片压缩的核心代码。

K-Means的核心思想

python中学习K-Means和图片压缩

python中学习K-Means和图片压缩

k-means的核心算法也就上面寥寥几句,下面将分三个部分来讲解:初始化簇中心、簇分配、簇中心移动。

初始化簇中心

python中学习K-Means和图片压缩

随机取簇中心若是不幸,会出现局部最优的情况;想要打破这种情况,需要多次取值计算来解决这种情况。

代价函数
python中学习K-Means和图片压缩

代码实现

J = zeros(100,1);
M = size(X,1);
min = inf;
for i = 1:100
%随机取k个样本点作为簇中心
randidx = randperm(M);
initial_centroids = X(randidx(1:K),:);
%将所得的中心点进行训练
[centroids0, idx] = runkMeans(X, initial_centroids,10);
for k = 1:M 
J(i) = J(i) + sum((X(k,:) - centroids0(idx(M),:)).^2); 
end
%取最小代价为样本中心点
if(min > J(i))
centroids =centroids0;
end
end

簇分配

将样本点分配到离它最近的簇中心下

tmp = zeros(K,1);
for i = 1:size(X,1)
for j = 1:K
tmp(j) = sum((X(i,:) - centroids(j,:)).^2);
end
[mins,index]=min(tmp);
idx(i) = index;
end

簇中心移动

取当前簇中心下所有样本点的均值为下一个簇中心

for i = 1:m
centroids(idx(i),:) = centroids(idx(i),:) + X(i,:);
end

for j = 1:K
centroids(j,:) = centroids(j,:)/sum(idx == j);
end

图片压缩

% 加载图片
A = double(imread('dragonfly.jpg'));
% 特征缩减
A = A / 255; 
img_size = size(A);
X = reshape(A, img_size(1) * img_size(2), 3);
K = 16; 
max_iters = 10;

%开始训练模型
initial_centroids = kMeansInitCentroids(X, K);
[centroids, idx] = runkMeans(X, initial_centroids, max_iters);

%开始压缩图片
idx = findClosestCentroids(X, centroids);
X_recovered = centroids(idx,:);
X_recovered = reshape(X_recovered, img_size(1), img_size(2), 3);
%输出所压缩的图片
subplot(1, 2, 2);
imagesc(X_recovered)
Python 相关文章推荐
Python中input和raw_input的一点区别
Oct 21 Python
30分钟搭建Python的Flask框架并在上面编写第一个应用
Mar 30 Python
搞笑的程序猿:看看你是哪种Python程序员
Jun 12 Python
举例讲解Python中的Null模式与桥接模式编程
Feb 02 Python
python装饰器初探(推荐)
Jul 21 Python
Python基于正则表达式实现检查文件内容的方法【文件检索】
Aug 30 Python
Python如何实现MySQL实例初始化详解
Nov 06 Python
Python自动化运维_文件内容差异对比分析
Dec 13 Python
解决在pycharm运行代码,调用CMD窗口的命令运行显示乱码问题
Aug 23 Python
python 截取XML中bndbox的坐标中的图像,另存为jpg的实例
Mar 10 Python
关于python中导入文件到list的问题
Oct 31 Python
python 实时调取摄像头的示例代码
Nov 25 Python
深入理解Python中的super()方法
Nov 20 #Python
python实现读取excel写入mysql的小工具详解
Nov 20 #Python
利用selenium 3.7和python3添加cookie模拟登陆的实现
Nov 20 #Python
python Matplotlib画图之调整字体大小的示例
Nov 20 #Python
python cx_Oracle的基础使用方法(连接和增删改查)
Nov 19 #Python
Python实现mysql数据库更新表数据接口的功能
Nov 19 #Python
python中urlparse模块介绍与使用示例
Nov 19 #Python
You might like
php 模拟POST|GET操作实现代码
2010/07/20 PHP
几个优化WordPress中JavaScript加载体验的插件介绍
2015/12/17 PHP
php连接oracle数据库的方法(测试成功)
2016/05/26 PHP
php的debug相关函数用法示例
2016/07/11 PHP
TP5(thinkPHP框架)实现后台清除缓存功能示例
2019/05/29 PHP
Javascript 判断Flash是否加载完成的代码
2010/04/12 Javascript
JavaScript bold方法入门实例(把指定文字显示为粗体)
2014/10/17 Javascript
超棒的响应式布局jQuery插件Freetile.js
2014/11/17 Javascript
jQuery中trigger()方法用法实例
2015/01/19 Javascript
js/jquery判断浏览器类型的方法小结
2015/05/12 Javascript
JavaScript 封装一个tab效果源码分享
2015/09/15 Javascript
学习jQuey中的return false
2015/12/18 Javascript
浅谈jquery的map()和each()方法
2016/06/12 Javascript
深入理解Angular2 模板语法
2016/08/07 Javascript
vue.js实现请求数据的方法示例
2017/02/07 Javascript
nodejs获取微信小程序带参数二维码实现代码
2017/04/12 NodeJs
BootStrap 导航条实例代码
2017/05/18 Javascript
JScript实现表格的简单操作
2017/08/15 Javascript
AngularJS 仿微信图片手势缩放的实例
2017/09/28 Javascript
[47:03]Ti4第二日主赛事败者组 LGD vs iG 2
2014/07/21 DOTA
Python中使用Queue和Condition进行线程同步的方法
2016/01/19 Python
Django中使用celery完成异步任务的示例代码
2018/01/23 Python
对pycharm代码整体左移和右移缩进快捷键的介绍
2018/07/16 Python
便捷提取python导入包的属性方法
2018/10/15 Python
Python时间和字符串转换操作实例分析
2019/03/16 Python
python交易记录链的实现过程详解
2019/07/03 Python
Python利用 utf-8-sig 编码格式解决写入 csv 文件乱码问题
2020/02/21 Python
python实现银行实战系统
2020/02/26 Python
python小技巧——将变量保存在本地及读取
2020/11/13 Python
css3选择器基本介绍
2014/12/15 HTML / CSS
LookFantastic丹麦:英国美容护肤精品在线商城
2016/08/18 全球购物
切尔西足球俱乐部官方网上商店:Chelsea FC
2019/06/17 全球购物
应届生的求职推荐信范文
2013/11/30 职场文书
运动会跳远广播稿
2014/02/04 职场文书
高中同学会活动方案
2014/08/14 职场文书
2014年商场工作总结
2014/11/22 职场文书