/**

* 图片相似度比较

*

* @version $Id: ImageHash.php 4429 2012-04-17 13:20:31Z jax $

* @authorjax.hu

* www.osxue.com

*//Sample_1

*$aHash = ImageHash::hashImageFile('wsz.11.jpg');

*$bHash = ImageHash::hashImageFile('wsz.12.jpg');

*var_dump(ImageHash::isHashSimilar($aHash, $bHash));

*

*//Sample_2

*var_dump(ImageHash::isImageFileSimilar('wsz.11.jpg', 'wsz.12.jpg'));

*

*/

class ImageHash {

/**取样倍率 1~10

* @access public

* @staticvar int

* */

public static $rate = 2;

/**相似度允许值 0~64

* @access public

* @staticvar int

* */

public static $similarity = 80;

/**图片类型对应的开启函数

* @access private

* @staticvar string

* */

private static $_createFunc = array(

IMAGETYPE_GIF =>'imageCreateFromGIF',

IMAGETYPE_JPEG=>'imageCreateFromJPEG',

IMAGETYPE_PNG =>'imageCreateFromPNG',

IMAGETYPE_BMP =>'imageCreateFromBMP',

IMAGETYPE_WBMP=>'imageCreateFromWBMP',

IMAGETYPE_XBM =>'imageCreateFromXBM',

);

/**从文件建立图片

* @param string $filePath 文件地址路径

* @return resource 当成功开启图片则传递图片 resource ID,失败则是 false

* */

public static function createImage($filePath){

if(!file_exists($filePath)){ return false; }

/*判断文件类型是否可以开启*/

$type = exif_imagetype($filePath);

if(!array_key_exists($type,self::$_createFunc)){ return false; }

$func = self::$_createFunc[$type];

if(!function_exists($func)){ return false; }

return $func($filePath);

}

/**hash 图片

* @param resource $src 图片 resource ID

* @return string 图片 hash 值,失败则是 false

* */

public static function hashImage($src){

if(!$src){ return false; }

/*缩小图片尺寸*/

$delta = 8 * self::$rate;

$img = imageCreateTrueColor($delta,$delta);

imageCopyResized($img,$src, 0,0,0,0, $delta,$delta,imagesX($src),imagesY($src));

/*计算图片灰阶值*/

$grayArray = array();

for ($y=0; $y for ($x=0; $x $rgb = imagecolorat($img,$x,$y);

$col = imagecolorsforindex($img, $rgb);

$gray = intval(($col['red']+$col['green']+$col['blue'])/3)& 0xFF;

$grayArray[] = $gray;

}

}

imagedestroy($img);

/*计算所有像素的灰阶平均值*/

$average = array_sum($grayArray)/count($grayArray);

/*计算 hash 值*/

$hashStr = '';

foreach ($grayArray as $gray){

$hashStr .= ($gray>=$average) ? '1' : '0';

}

return $hashStr;

}

/**hash 图片文件

* @param string $filePath 文件地址路径

* @return string 图片 hash 值,失败则是 false

* */

public static function hashImageFile($filePath){

$src = self::createImage($filePath);

$hashStr = self::hashImage($src);

imagedestroy($src);

return $hashStr;

}

/**比较两个 hash 值,是不是相似

* @param string $aHash A图片的 hash 值

* @param string $bHash B图片的 hash 值

* @return bool 当图片相似则传递 true,否则是 false

* */

public static function isHashSimilar($aHash, $bHash){

$aL = strlen($aHash); $bL = strlen($bHash);

if ($aL !== $bL){ return false; }

/*计算容许落差的数量*/

$allowGap = $aL*(100-self::$similarity)/100;

/*计算两个 hash 值的汉明距离*/

$distance = 0;

for($i=0; $i if ($aHash{$i} !== $bHash{$i}){ $distance++; }

}

return ($distance<=$allowGap) ? true : false;

}

/**比较两个图片文件,是不是相似

* @param string $aHash A图片的路径

* @param string $bHash B图片的路径

* @return bool 当图片相似则传递 true,否则是 false

* */

public static function isImageFileSimilar($aPath, $bPath){

$aHash = ImageHash::hashImageFile($aPath);

$bHash = ImageHash::hashImageFile($bPath);

return ImageHash::isHashSimilar($aHash, $bHash);

}

}

php 图片相似度对比算法,php比较图片相似度代码示例相关推荐

  1. 不同长度的字符串/中文串相似度对比算法

    1.背景介绍 今天在公司接到一个需求,大概是这样的.我们ERP系统数据库有张customer(客户)表,其中有个字段是小区名称(plotName),当初在录入数据时没有对这一字段做界定和规范,由人工手 ...

  2. python kivy显示图片_python基于Kivy写一个图形桌面时钟程序代码示例

    本篇文章小编给大家分享一下python基于Kivy写一个图形桌面时钟程序代码示例,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看. Kivy 是一个开源的 ...

  3. php 图片相似度对比算法,图像处理技术之图片相似度比较

    Today,工作中发现需要去除图片上的水印,由于涉及文章太多,手动重新编辑很慢且容易出错.于是想到了使用脚本比较全部图片的相似度,然后替换文件的方式来达到去除水印效果.在完成这项工作前,我们需要找到所 ...

  4. 数据结构与算法(二) 栈与队列(代码示例)

    数据结构与算法 栈与队列 1. 数组和链表实现栈 2. 用O(1)的时间复杂度求栈中的最小元素 3. 链表和数组实现队列 4. 用两个栈模拟队列操作 1. 数组和链表实现栈 链表的方式: /*** 描 ...

  5. 【CSS】滑动门技术 ( 借助 CSS 精灵技术实现 | 外部标签设置左半部分背景图片 | 内部标签设置右半部分背景图片 | 鼠标经过更换背景 | 代码示例 )

    文章目录 一.滑动门技术 1.滑动门技术借助 CSS 精灵技术实现 2.外部标签设置左半部分背景图片 3.内部标签设置右半部分背景图片 4.鼠标经过时更换背景 二.完整代码示例 一.滑动门技术 1.滑 ...

  6. html中图片阴影怎么写,css怎么在图片上加阴影?

    css怎么在图片上加阴影?下面本篇文章给大家介绍一下使用CSS在图片上加阴影的方法.有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助. 方法1:设置box-shadow属性 box-sh ...

  7. OCR图片相似度对比和分类算法

    目录 算法清单 前提知识 一.像素点对比 二.重心对比 三.投影比对 四.分块对比 Logistic回归的直观认识 带入数据进行训练 使用训练好的模型 训练模型的代码 参考文献: Ocr文字识别其中的 ...

  8. CV之Hog+HamMingDistance:基于Hog提取和汉明距离对比的应用—图像相似度对比之for循环将多个成对图片依次对比并输出相似度

    CV之Hog+HamMingDistance:基于Hog提取和汉明距离对比的应用-图像相似度对比之for循环将多个成对图片依次对比并输出相似度 目录 测试数据集 核心代码 相关文章 ML之相似度计算: ...

  9. php 图片一摸一样,PHP实现图片相似度对比

    PHP如何实现图片相似度对比?本文将通过感知哈希算法来实现搜索相似图片.希望对大家有所帮助. 感知哈希的优点是简单快速,不受图片大小缩放的影响,缺点是图片的内容不能变更.实际应用中,往往采用更强大的p ...

最新文章

  1. ​新型支架状电极允许人类思想操作计算机
  2. react native与webview通信跳转页面报错:Cannot read property 'setNativeProps' of undefiend
  3. High Logic MainType 10中文版
  4. 5G商用将在“十三五”时期内启动
  5. colorpix取色小工具_我发现一款神器!它集合了 60 多个超实用的工具
  6. MVC:感觉用户认证标识(IsAuthenticated)有点延时。
  7. SpringMVC中的Controller默认单例
  8. [leetcode]01.04. 回文排列
  9. YII2 搭建redis拓展(教程)
  10. 自信息、信息熵和相对熵
  11. CS224N笔记——依存句法分析
  12. mat opencv 修改roi_OpenCV开发笔记(七十三):红胖子8分钟带你使用opencv+dnn+yolov3识别物体...
  13. Qt_QDbus用法
  14. matlab小波变换学习入门
  15. 计算机专业论文评语,计算机毕业论文评语
  16. 山东大学科技文献期末复习(个人速成向)
  17. elasticsearch最大节点数_记录 Elasticsearch 的 maximum shards open 问题
  18. 智能电话机器人(AI语音机器人)是什么
  19. SQL中的查询语句总结(实例)
  20. 服务器存放代码的位置在哪里,云服务器代码放在哪里

热门文章

  1. fifo的rdata_FIFO的使用总结
  2. python什么证书最有价值,python考什么证含金量高
  3. 网络安全职业规划(笔记)
  4. 如何学习stm32,怎么学习stm32,不是仅仅看教程,照着写复制代码
  5. 是时候客观评价Retrofit了,Retrofit这几点你必须明白!
  6. TDengine 常见问题解答
  7. C++Web服务器(一):服务器整体运行流程
  8. Node 之 nvm 下载、安装、使用,以及node 、nrm 的相关使用
  9. 彭亮—Python学习
  10. DAVSE VCC-H10004K超高清会议摄像机