圖片相似度判斷差異值哈希算法JAVA版_第1頁
圖片相似度判斷差異值哈希算法JAVA版_第2頁
圖片相似度判斷差異值哈希算法JAVA版_第3頁
全文預覽已結束

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、圖片相似度判斷-差異值哈希算法JAVA版在網上找了好久都沒有找到判斷圖片相似度的差異值哈希算法的JAVA版正確實現(xiàn),自己手寫了一個,提供給大家參考。差異值哈希算法的流程(dHash)圖片縮放為9*8大小將圖片灰度化差異值計算(每行相鄰像素的差值,這樣會生成8*8的差值,前一個像素大于后一個像素則為1,否則為0)生成哈希值packagecom.example.demo.hello;importjavax.imageio.ImagelO;importjava.awt.*;importjava.awt.image.Bufferedlmage;importjava.io.File;importjava

2、.io.IOException;/*差異哈希算法*/publicclassDHashUtil/*計算dHash方法*paramfile文件returnhash*/privatestaticStringgetDHash(Filefile)讀取文件BufferedlmagesrcImage;trysrcImage=ImagelO.read(file);catch(lOExceptione)e.printStackTrace();returnnull;文件轉成9*8像素,為算法比較通用的長寬BufferedlmagebuffImg=newBufferedImage(9,8,BufferedImage

3、.TYPE_INT_RGB);buffImg.getGraphics().drawImage(srcImage.getScaledInstance(9,8,Image.SCALE_SMOOTH),0,0,null);intwidth=buffImg.getWidth();intheight=buffImg.getHeight();intgrayPix=newintwidthheight;StringBufferfigure=newStringBuffer();for(inty=0;yheight;y+)for(intx=0;x16&0 xff;intg=rgb8&Oxff;intb=rgb&O

4、xff;intgray=(r*30+g*59+b*11)/100;grayPixxy=gray;開始計算dHash總共有9*8像素每行相對有8個差異值總共有8*8=64個if(x!=0)longbit=grayPixx-1ygrayPixxy?1:0;figure.append(bit);returnfigure.toString();/*計算海明距離vp*原本用于編碼的檢錯和糾錯的一個算法*現(xiàn)在拿來計算相似度,如果差異值小于一定閾值則相似,一般經驗值小于5為同一張圖片*paramstrlparamstr2return距離*/privatestaticlonggetHammingDistanc

5、e(Stringstrl,Stringstr2)intdistance;if(str1=null|str2=null|str1.length()!=str2.length()distance=-1;elsedistance=0;for(inti=0;istr1.length();i+)if(str1.charAt(i)!=str2.charAt(i)distance+;returndistance;/DHashUtil參數(shù)值為待處理文件夾publicstaticvoidmain(Stringargs)Filefile1=newFile(xxx/1.jpg);Filefile2=newFile(xxx/2.jpg);System.out.println(圖片1hash值:+getDHash(file1);System.out.println(圖片2hash值:+getDHash(file2);System.out.println(海明距離為:+getHammingDistance(getDHash(file1),getDHash(file2);運行結果如下:圖片lhash值:1001110011111000101100101001010011001000111000001001100011000000圖片2hash值:1001110011111000101

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論