Matlab 实现感知哈希法

BinToHex.m

function str=BinToHex(A)
str='';
    for  i=1:8
        for j=1:4:8
            temp = dec2hex(bin2dec(num2str(A(i,j:j+3))));
            str=strcat(str,num2str(temp));
        end
    end
end

Perceptual_hash_algorithm

function A=Perceptual_hash_algorithm(str)

img=imread(str);

%转换为灰度图
temp=rgb2gray(img);

%缩小到8*8
img2=imresize(temp,[8 8]);

%划分灰度等级为64
img2=uint8(double(img2)/4);

%求均值
average=mean(mean(img2));

%生成二进制矩阵
img2(img2<average) = 0;
img2(img2>=average) = 1;
A=img2;
%将二进制转换为16进制,指纹
Str=BinToHex(A)
end

hash.m

clear all;
clc;
E=Perceptual_hash_algorithm('G:\\壁纸\\高达UC\\gundam_uc-026.jpg');
F=Perceptual_hash_algorithm('G:\\壁纸\\高达UC\\26_A.jpg');
G=xor(E,F);
a=sum(G(:)==1)

  • 0
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值