感知Hash算法计算图像相似度-PHP实现

1,515次阅读
没有评论

基于感知Hash算法计算图像相似度最大的优点是简单快速,适用于大规模图像匹配

该算法的原理与Google搜索引擎的SIMHash算法有相同之处,通过生成文本或图片的“指纹”(Hash值),计算Hash值的汉明距离,来表征图片之间的相似度。汉明距离越小,图片越相似。

因为Hash码一般只有有限的位数,可以短时间筛选出相似图片。如果需要精匹配,再考虑SIFT特征匹配等算法。目前,许多图像搜索引擎都在使用Perceptual Hash算法。

  1. 缩小尺寸:将图像缩小到8*8的尺寸,总共64个像素。这一步的作用是去除图像的细节,只保留结构/明暗等基本信息,摒弃不同尺寸/比例带来的图像差异;
  2. 简化色彩:将缩小后的图像,转为64级灰度,即所有像素点总共只有64种颜色;
  3. 计算平均值:计算所有64个像素的灰度平均值;
  4. 比较像素的灰度:将每个像素的灰度,与平均值进行比较,大于或等于平均值记为1,小于平均值记为0;
  5. 计算哈希值:将上一步的比较结果,组合在一起,就构成了一个64位的整数,这就是这张图像的指纹。组合的次序并不重要,只要保证所有图像都采用同样次序就行了;
  6. 得到指纹以后,就可以对比不同的图像,看看64位中有多少位是不一样的。在理论上,这等同于”汉明距离”(Hamming distance,在信息论中,两个等长字符串之间的汉明距离是两个字符串对应位置的不同字符的个数)。如果不相同的数据位数不超过5,就说明两张图像很相似;如果大于10,就说明这是两张不同的图像。
  • CentOS 7.0
  • PHP 5.4
  • Composer 1.0.3
  • jenssegers/imagehash

计算图片的Hash值:

use Jenssegers\ImageHash\ImageHash;$hasher = new ImageHash;$hash = $hasher->hash('path/to/image.jpg');

计算两个Hash码的汉明距离:

$distance = $hasher->distance($hash1, $hash2);

计算两张图片的相似度:

use Jenssegers\ImageHash\Implementations\DifferenceHash;use Jenssegers\ImageHash\ImageHash;$implementation = new DifferenceHash;$hasher = new ImageHash($implementation);$distance = $hasher->compare('path/to/image1.jpg', 'path/to/image2.jpg');

这里使用的用例是指定的树叶图像。我们选取以下8张正面图片,分别编号从1-8,以及8张反面图片,分别编号从1_1-8_1

感知Hash算法计算图像相似度-PHP实现

然后用以下代码计算对应的汉明距离:

<?phprequire '/root/vendor/autoload.php';use Jenssegers\ImageHash\Implementations\DifferenceHash;use Jenssegers\ImageHash\ImageHash;$image_path = '/data/wwwroot/default/cv/images_test/';$implementation = new DifferenceHash;$hasher = new ImageHash($implementation);echo "<table border='1'>";for( $i = 1; $i <=8; $i++){    echo "<tr>";    for( $j = 1; $j <=8; $j++)    {        $distance = $hasher->compare($image_path.$j.'_1.jpg', $image_path.$i.'.jpg');        echo "<td>".$distance."</td>";    }    echo "</tr>";}echo "</table>";?>

得到结果如下:

image 1 image 2 image 3 image 4 image 5 image 6 image 7 image 8
image 1_1 6 31 27 21 26 24 25 20
image 2_1 28 17 25 27 28 24 27 30
image 3_1 23 26 8 12 7 9 10 7
image 4_1 27 24 16 14 13 19 18 13
image 5_1 29 24 10 10 11 5 10 13
image 6_1 31 30 10 20 11 11 12 11
image 7_1 28 23 5 13 8 6 7 12
image 8_1 32 27 19 13 20 16 15 18

pHash算法可以快速从海量图片中筛选相似图片,但不能解决精匹配问题,因为图片变换(旋转、缩放、投影)对pHash算法的影响较大。待解决问题总结如下:

  1. 精匹配问题。利用pHash快速匹配后可以用SIFT特征,互信息、互相关、PNSR等配准和计算相似度。
  2. 图像的自动ReSize问题。根据样本模板自动调整待搜索图片的尺寸和角度,算法待设计。 (Ps. 最好采用窗口搜索的方法,类似于目标检测,比图像变换效果要好。)
正文完
可以使用微信扫码关注公众号(ID:xzluomor)
post-qrcode
 0
评论(没有评论)

文心AIGC

2024 年 8 月
 1234
567891011
12131415161718
19202122232425
262728293031  
文心AIGC
文心AIGC
人工智能ChatGPT,AIGC指利用人工智能技术来生成内容,其中包括文字、语音、代码、图像、视频、机器人动作等等。被认为是继PGC、UGC之后的新型内容创作方式。AIGC作为元宇宙的新方向,近几年迭代速度呈现指数级爆发,谷歌、Meta、百度等平台型巨头持续布局
文章搜索
热门文章
清库存!DeepSeek突然补全R1技术报告,训练路径首次详细公开

清库存!DeepSeek突然补全R1技术报告,训练路径首次详细公开

清库存!DeepSeek突然补全R1技术报告,训练路径首次详细公开 Jay 2026-01-08 20:18:...
训具身模型遇到的很多问题,在数据采集时就已经注定了丨鹿明联席CTO丁琰分享

训具身模型遇到的很多问题,在数据采集时就已经注定了丨鹿明联席CTO丁琰分享

训具身模型遇到的很多问题,在数据采集时就已经注定了丨鹿明联席CTO丁琰分享 衡宇 2026-01-08 20:...
「北京版幻方」冷不丁开源SOTA代码大模型!一张3090就能跑,40B参数掀翻Opus-4.5和GPT-5.2

「北京版幻方」冷不丁开源SOTA代码大模型!一张3090就能跑,40B参数掀翻Opus-4.5和GPT-5.2

「北京版幻方」冷不丁开源SOTA代码大模型!一张3090就能跑,40B参数掀翻Opus-4.5和GPT-5.2...
开源“裸考”真实世界,国产具身智能基座模型拿下全球第二!

开源“裸考”真实世界,国产具身智能基座模型拿下全球第二!

开源“裸考”真实世界,国产具身智能基座模型拿下全球第二! 西风 2026-01-08 19:02:20 来源:...
最新评论
ufabet ufabet มีเกมให้เลือกเล่นมากมาย: เกมเดิมพันหลากหลาย ครบทุกค่ายดัง
tornado crypto mixer tornado crypto mixer Discover the power of privacy with TornadoCash! Learn how this decentralized mixer ensures your transactions remain confidential.
ดูบอลสด ดูบอลสด Very well presented. Every quote was awesome and thanks for sharing the content. Keep sharing and keep motivating others.
ดูบอลสด ดูบอลสด Pretty! This has been a really wonderful post. Many thanks for providing these details.
ดูบอลสด ดูบอลสด Pretty! This has been a really wonderful post. Many thanks for providing these details.
ดูบอลสด ดูบอลสด Hi there to all, for the reason that I am genuinely keen of reading this website’s post to be updated on a regular basis. It carries pleasant stuff.
Obrazy Sztuka Nowoczesna Obrazy Sztuka Nowoczesna Thank you for this wonderful contribution to the topic. Your ability to explain complex ideas simply is admirable.
ufabet ufabet Hi there to all, for the reason that I am genuinely keen of reading this website’s post to be updated on a regular basis. It carries pleasant stuff.
ufabet ufabet You’re so awesome! I don’t believe I have read a single thing like that before. So great to find someone with some original thoughts on this topic. Really.. thank you for starting this up. This website is something that is needed on the internet, someone with a little originality!
ufabet ufabet Very well presented. Every quote was awesome and thanks for sharing the content. Keep sharing and keep motivating others.
热评文章
刚开年,马斯克就到账了200亿美金!

刚开年,马斯克就到账了200亿美金!

Failed to fetch content Read More 
B站开启AI创作大赛,首次开放《三体》改编权,奖金总计超300万

B站开启AI创作大赛,首次开放《三体》改编权,奖金总计超300万

B站开启AI创作大赛,首次开放《三体》改编权,奖金总计超300万 量子位的朋友们 2026-01-05 15:...
悲报!Stack Overflow彻底凉了,比18年前上线首月问题数量还少

悲报!Stack Overflow彻底凉了,比18年前上线首月问题数量还少

悲报!Stack Overflow彻底凉了,比18年前上线首月问题数量还少 闻乐 2026-01-05 19:...
老黄All in物理AI!最新GPU性能5倍提升,还砸掉了智驾门槛

老黄All in物理AI!最新GPU性能5倍提升,还砸掉了智驾门槛

老黄All in物理AI!最新GPU性能5倍提升,还砸掉了智驾门槛 闻乐 2026-01-06 09:09:0...