计算图像相似度——《Python也可以》之一
声明:本文最初发表于赖勇浩(恋花蝶)的博客http://blog.csdn.net/lanphaday
先将两张图片转化为直方图,图像的相似度计算就转化为直方图的距离计算了,本文依照如下公式进行直方图相似度的定量度量:
Sim(G,S)=
其中G,S为直方图,N 为颜色空间样点数
转换为相应的 Python 代码如下:
#!/usr/bin/env python
# coding=utf-8 import Image def make_regalur_image(img,size=(256,256)):
return img.resize(size).convert('RGB') def split_image(img,part_size=(64,64)):
w,h = img.size
pw,ph = part_size assert w%pw == h%ph==0 return [img.crop((i,j,i+pw,j+ph)).copy() for i in xrange(0,w,pw) for j in xrange(0,h,ph)] def hist_similar(lh,rh):
assert len(lh)==len(rh)
return sum(1-(0 if l==r else float(abs(l-r))/max(l,r))for l,r in zip(lh,rh))/len(lh) def calc_similar(li,ri):
# return hist_similar(li.histogram(),ri.histogram())
return sum(hist_similar(l.histogram(),r.histogram()) for l,r in zip(split_image(li),split_image(ri)))/16.0 def calc_similar_by_path(lf,rf):
li,ri = make_regalur_image(Image.open(lf)),make_regalur_image(Image.open(rf))
return calc_similar(li,ri) def make_doc_data(lf,rf):
li = make_regalur_image(Image.open(lf))
ri = make_regalur_image(Image.open(rf))
li.save(lf+'_regalur.png')
ri.save(rf+'_regalur.png') fd = open('stat.csv','w')
fd.write('\n'.join(l+','+r for l,r in zip(map(str,li.histogram()),map(str,ri.histogram()))))
fd.close() import ImageDraw
li = li.convert('RGB')
draw = ImageDraw.Draw(li)
for i in xrange(0,256,64):
draw.line((0,i,256,i),fill ='#F00')
draw.line((i,0,i,256),fill='#F00')
li.save(lf+'_lines.png') if __name__=='__main__':
path = r'test/TEST%d/%d.JPG'
for i in xrange(1,7):
print 'test_case_%d: %.3f%%'%(i,calc_similar_by_path('test/TEST%d/%d.JPG'%(i,1),'test/TEST%d/%d.JPG'%(i,2))*100) make_doc_data('test/TEST4/1.JPG','test/TEST4/2.JPG')
参考:
计算图像相似度——《Python也可以》之一的更多相关文章
- MatLab计算图像圆度
		
本文所述方法可以检测同一图像中的多个圆形(准确的说,应该是闭合图像). 在Matlab2010a中可以实现. 附录效果图: %颗粒圆度 clear;close all; %% %读取源图像 I = i ...
 - 图像相似度算法的C#实现及测评
		
近日逛博客的时候偶然发现了一个有关图片相似度的Python算法实现.想着很有意思便搬到C#上来了,给大家看看. 闲言碎语 才疏学浅,只把计算图像相似度的一个基本算法的基本实现方式给罗列了出来,以至于在 ...
 - OpenCV进行图像相似度对比的几种办法
		
转载请注明出处:http://blog.csdn.net/wangyaninglm/article/details/43853435, 来自:shiter编写程序的艺术 对计算图像相似度的方法,本文做 ...
 - 图像相似度计算之哈希值方法OpenCV实现
		
http://blog.csdn.net/fengbingchun/article/details/42153261 图像相似度计算之哈希值方法OpenCV实现 2014-12-25 21:27 29 ...
 - Python OpenCV 图像相识度对比
		
强大的openCV能做什么我就不啰嗦,你能想到的一切图像+视频处理. 这里,我们说说openCV的图像相似度对比, 嗯,说好听一点那叫图像识别,但严格讲, 图像识别是在一个图片中进行类聚处理,比如图片 ...
 - python计算余弦复杂度
		
import numpy as np from sklearn.metrics.pairwise import cosine_similarity a = np.array([1, 2, 3, 4]) ...
 - 深入学习OpenCV中图像灰度化原理,图像相似度的算法
		
最近一段时间学习并做的都是对图像进行处理,其实自己也是新手,各种尝试,所以我这个门外汉想总结一下自己学习的东西,图像处理的流程.但是动起笔来想总结,一下却不知道自己要写什么,那就把自己做过的相似图片搜 ...
 - 转-------CNN图像相似度匹配     2-channel  network
		
基于2-channel network的图片相似度判别 原文地址:http://blog.csdn.net/hjimce/article/details/50098483 作者:hjimce 一.相 ...
 - 我用JAVA做了个简易图像相似度计算器
		
简单说两句: 笔主利用这个七夕前后两天的寂寞时光,用JAVA磨了一个简单的图像相似度计算小程序,就在刚才终于纠结完毕,输出了1.0版本,小小的满足了一下可怜的虚荣心..→_→ 使用最简单最基础的感知哈 ...
 
随机推荐
- 清除git以外文件
			
清除git以外文件 清除git以外文件 git clean -fxd git log 查看某段时刻的log git log --until=2013-11-23 #表示查看2013年11月23日以前的 ...
 - C语言基础:函数(Function)                                                    分类:            iOS学习  c语言基础             2015-06-10 21:48    14人阅读    评论(0)    收藏
			
函数:一段具有某些特定功能的代码段. 使用函数的严格规定: 1.函数声明 2.函数定义 3.函数调用 函数声明:告知系统编译器该系统的函数名,函数参数,参数类型,参数个数,参数顺序等等,以便函数调用时 ...
 - LIBCURL踩坑记
			
这里一个java程序员进行C++开发使用libcurl踩过的坑: 1. 发送指定请求类型body,比较通用方法如下,可以直接填写数据并手动指定content type,如果是form表单等形式,则需 ...
 - shell 脚本实战笔记(4)--linux磁盘分区重新挂载
			
背景: Hadoop的HDFS文件系统的挂载, 默认指定的文件目录是/mnt/disk{N}. 当运维人员, 不小心把磁盘挂载于其他目录, 比如/mnt/data, /mnt/disk01, /mnt ...
 - 【opencv基础】OpenCV从Mat中提取某些行或列
			
这两个函数返回的是指向原矩阵内部位置的指针,类似于浅拷贝: code cv::Mat align_mean(cv::Mat mean, cv::Rect facebox, float scaling_ ...
 - Tensorflow中的滑动平均模型
			
原文链接 在Tensorflow的教程里面,使用梯度下降算法训练神经网络时,都会提到一个使模型更加健壮的策略,即滑动平均模型. 基本思想 在使用梯度下降算法训练模型时,每次更新权重时,为每个权重维护一 ...
 - CTF之常见的两种关于word的信息隐藏技术
			
一.利用word本身自带的文字隐藏功能 1.在word中输入文字 2.选中文字,单击右键,选择字体选项 3.单击字体选项后,单击隐藏,确定 查找隐藏信息 1.单击左上角WPS文字后,选择选项按钮单击 ...
 - java8 array、list操作 汇【3】)(-Java8新特性之Collectors 详解
			
//编写一个定制的收集器 public static class MultisetCollector<T> implements Collector<T, Multiset<T ...
 - LeetCode-Microsoft-Remove K Digits
			
Given a non-negative integer num represented as a string, remove k digits from the number so that th ...
 - css文字和背景色渐变色
			
定义一个div: <div class="shop-title" >上海迪士尼度假区官方旗舰店</div> 使用css: .shop-title{ widt ...