Atitit 判斷判斷一張圖片是否包含另一張小圖片

来源:http://www.cnblogs.com/attilax/archive/2016/10/06/5933728.html
-Advertisement-
Play Games

Atitit 判斷判斷一張圖片是否包含另一張小圖片 1. keyword1 2. 模板匹配是在圖像中尋找目標的方法之一(切割+圖像相似度計算)1 3. 匹配效果2 4. 圖片相似度的演算法(感知哈希演算法”(Perceptual hash algorithm)2 5. 性能結果2 6. 如何提升性能3 ...


 

Atitit 判斷判斷一張圖片是否包含另一張小圖片 

 

1. keyword1

2.  模板匹配是在圖像中尋找目標的方法之一(切割+圖像相似度計算)1

3. 匹配效果2

4. 圖片相似度的演算法(感知哈希演算法Perceptual hash algorithm2

5. 性能結果2

6. 如何提升性能3

6.1. 可以採用簡化的演算法。二次匹配法,先大概確定區域3

6.2. 切割圖片設置一個step3

7. 參考資料3

8. ------code3

 

1. keyword

 

圖像匹配

圖片是否另外一張圖片的一部分

如果是標準圖片,模板匹配就好

 

2.  模板匹配是在圖像中尋找目標的方法之一(切割+圖像相似度計算)

Come On, Boy.我們一起來看看模板匹配到底是怎麼回事。

模板匹配的工作方式
    模板匹配的工作方式跟直方圖的反向投影基本一樣,大致過程是這樣的:通過在輸入圖像上滑動圖像塊對實際的圖像塊和輸入圖像進行匹配。
    假設我們有一張100x100的輸入圖像,有一張10x10的模板圖像,查找的過程是這樣的:
  1)從輸入圖像的左上角(0,0)開始,切割一塊(0,0)(10,10)的臨時圖像;
  2)用臨時圖像和模板圖像進行對比,對比結果記為c
  3)對比結果c,就是結果圖像(0,0)處的像素值;
  4)切割輸入圖像從(0,1)(10,11)的臨時圖像,對比,並記錄到結果圖像;
  5)重覆(1)~(4)步直到輸入圖像的右下角。
    大家可以看到,直方圖反向投影對比的是直方圖,而模板匹配對比的是圖像的像素值;模板匹配比直方圖反向投影速度要快一些,但是我個人認為直方圖反向投影的魯棒性會更好。

 

3. 匹配效果

效果不錯,基本可以確定查找到對應的區域坐標。。對於彩色圖片,可以使用色彩空間信息排除掉其他錯誤的匹配圖片,幾乎可以精確的確定一個圖片了。。

4. 圖片相似度的演算法(感知哈希演算法Perceptual hash algorithm

感知哈希演算法Perceptual hash algorithm),它的作用是對每張圖片生成一個“指紋”(fingerprint)字元串,然後比較不同圖片的指紋。結果越接近,就說明圖片越相似。

下麵是一個最簡單的實現:

第一步,縮小尺寸。將圖片縮小到8×8的尺寸,總共64個像素。這一步的作用是去除圖片的細節,只保留結構、明暗等基本信息,摒棄不同尺寸、比例帶來的圖片差異。

第二步,簡化色彩。將縮小後的圖片,轉為64級灰度。也就是說,所有像素點總共只有64種顏色。

第三步,計算平均值。計算所有64個像素的灰度平均值。

第四步,比較像素的灰度。將每個像素的灰度,與平均值進行比較。大於或等於平均值,記為1;小於平均值,記為。

第五步,計算哈希值。將上一步的比較結果,組合在一起,就構成了一個64位的整數,這就是這張圖片的指紋。組合的次序並不重要,只要保證所有圖片都採用同樣次序就行了。

得到指紋以後,就可以對比不同的圖片,看看64位中有多少位是不一樣的。在理論上,這等同於計算漢明距離。如果不相同的數據位不超過5,就說明兩張圖片很相似;如果大於10,就說明這是兩張不同的圖片。

 

 

5. 性能結果

在我機子上,語言java ,純java實現。匹配變換dct演算法size 8

每次移動step=5  。。使用了並行庫。。

速度大概在120s。。懶得繼續調整性能了,主要是測試思路,不過總結了思路,暫時先用著,理想的目標應該在3秒內。。

 

這個是參考文章的說法大概70秒。。語言是c#調用opencv介面

模板匹配和直方圖反向投影的效率
    總的來說,模板匹配和直方圖反向投影的效率都不高。在我的機器上,在1136*852大小的輸入圖像上匹配104*132的大小的模板圖像(都是單通道灰度圖像),大約需要700毫秒;而直方圖反向投影大約需要75000毫秒(1.25分鐘)。看來還需要繼續學習,尋找更好的處理方法

 

6. 如何提升性能

主要演算法消耗在匹配小圖片上。。

6.1. 可以採用簡化的演算法。二次匹配法,先大概確定區域

。首先可以大幅度的就確定幾張疑似圖像坐標。。然後對疑似圖像進行高精度演算法匹配,就可以幾乎匹配到唯一的一張。。如果圖片是彩色圖片,再使用顏色信息二次匹配相似度。。以及直方圖等演算法補充來匹配。。

6.2. 切割圖片設置一個step

比如要尋找的圖片大小60*60,可以設置一個20%以內的不敬step來跳躍切割,可以大幅度提升性能, 60/0.05=12.。 可以立馬提升12倍的性能。。

 

然後大概選定了區域後,在使用精確移動step來切割圖片。

 

7. 參考資料

 

如何判斷一張圖片是否包含另一張小圖片?圖像匹配?-CSDN論壇-CSDN.NET-中國最大的IT技術社區.html

模板匹配(Match Template) - Wuya - 博客園.html

演算法 - JPEGDCT壓縮原理,誰能通俗易懂解釋一下? - SegmentFault.html

作者:: 綽號:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿爾 拉帕努伊 ) 

漢字名:艾提拉(艾龍)   EMAIL:[email protected]

轉載請註明來源: http://www.cnblogs.com/attilax/

 

8. ------code

 

private void t() throws IOException {

String big = "c:\\t.jpeg";

String lit = "c:\\lit.jpg";

// diff==484

 

BufferedImage lit_img = ImageIO.read(new File(lit));

 

int w2 = lit_img.getWidth();

int h2 = lit_img.getHeight();

 

imgx imgx = new imgx();

BufferedImage img = ImageIO.read(new File(big));

int width = img.getWidth();

int h = img.getHeight();

ImagePHash imagePHash = new ImagePHash(8, 8);

ImageReader ImageReader1 = imgx.ImgReader(new File(big));

 

String ext = filex.getExtName(big);

imgx.save(lit_img, "c:\\0tmpPic\\" + filex.getUUidName() + "." + ext, ext);

ExecutorService es=Executors.newFixedThreadPool(3);

lab: for (int i = 0; i < width; i = i + 5) {

for (int j = 0; j < h; j = j + 5) {

// BufferedImage tmp =

// (BufferedImage) imgx.cutImage_retImg(big,

// i, j, w2, h2);

n++;

int x = i;

int y = j;

int nowCount=n;

Runnable ra = () -> {

 

process(lit_img, w2, h2, imgx, imagePHash, ImageReader1, nowCount,

ext, x, y);

};

es.execute(ra);

 

}

}

es.shutdown();

}

 

private int process(BufferedImage lit_img, int w2, int h2, imgx imgx,

ImagePHash imagePHash, ImageReader ImageReader1, int n, String ext,

int i, int j) {

Rectangle rect = new java.awt.Rectangle(i, j, w2, h2);

BufferedImage tmp = imgx.cutImg(rect, ImageReader1);

 

int dis = imagePHash.distance(tmp, lit_img);

 

if (dis < 5) {

log.info(" count:" + String.valueOf(n) + " dis:"

+ String.valueOf(dis) + " rect:" + String.valueOf(i) + "_"

+ String.valueOf(j));

// break lab;

}

if (dis < 10) {

String out = "c:\\0tmpPic\\" + filex.getUUidName() + "." + ext;

imgx.save(tmp, out, ext);

log.info(" count:" + String.valueOf(n) + " dis:"

+ String.valueOf(dis) + " rect:" + String.valueOf(i) + "_"

+ String.valueOf(j) + " file:" + out);

}

 

int cnt = n;

if (cnt % 100 == 0) {

String count = String.valueOf(cnt);

 

log.info(" count:" + count + " dis:" + String.valueOf(dis)

+ " rect:" + String.valueOf(i) + "_" + String.valueOf(j));

}

return n;

}

 

}

 

Atiend

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 說明:在我們調試C語言的過程中,經常會遇到duplicate symbol錯誤(在Mac平臺下利用Xcode集成開發環境)。如下圖: 一.簡單分析一下C語言程式的開發步驟。 由上圖我們可以看出C語言由編寫源程式->編譯->鏈接->運行幾個步驟進行。 編寫源程式: C語言的源文件的擴展名為.c,源文件 ...
  • 批處理是一次性向資料庫發出多條查詢指令,一起執行Statement 介面定義的方法:|—增加批處理語句: |—執行批處理: PreparedStatement介面定義的方法:增加批處理:public void addBatche()throws SQLexceeption public class ...
  • 下麵是我今天下午用PHP寫的一個生成圖片驗證碼demo,僅供參考。這個demo總共分為4個文件,具體代碼如下: ...
  • 題目鏈接 https://acm.bnu.edu.cn/v3/contest_show.php?cid=8506#problem/A problem description As we know, the NTU Final PK contest usually tends to be pretty ...
  • (-1)寫在前面 spring2.0、struts1.2、hibernate3.0、myeclipse8.5、tomcat6.0,整合之中出現了很多問題,前幾天忙著整理畢業論文的資料,時間騰出來了,總算有能寫的東西。話說這宿舍的人少了,蚊子的選擇也少了。 (0)詳細解釋 a.錯誤產生的原因 java ...
  • 要用Java實現記事本的功能。首先列出記事本所需功能: 可以添加記錄(字元串); 可以獲得記錄條數; 可以刪除其中某一條記錄; 可以獲得指定第幾條的記錄; 可以列出所有的記錄。 如果這個記事本是某個大程式的其中一部分,也就是說還有上層程式,那麼上層程式就有可能會調用這個記事本以上列出的某個數據。 ... ...
  • 一、記憶體中的程式: 在進程被載入記憶體中時,基本上被分成許多小的節,以下是6個主要的節。 低地址 高地址 .text 節 .text節基本上相當於二進位可執行文件的.text部分,它包含了完成程式任務的機器指令。 該節標記為只讀,如果發生寫操作,會造成 segmentation fault。 在進程最 ...
  • 靜態代理 1、新建一個介面,這個介面所提供的方法是關於資料庫操作的 2、建一個目標類實現這個介面,這個目標類是我們要進行的業務 3、再建一個代理類,為目標對象提供一種代理,並以控制對這個對象的訪問。 由以上可知,代理模式的組成包括:目標介面(抽象角色),目標類(真實角色)和代理類(代理角色)。 4、 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...