感知哈希(pHash)和梯度哈希(dHash)的Python+OpenCV+SciPy实现

</pre><pre name="code" class="python">class ImageUtils:
   
    @staticmethod
    def cvload(buf):
        npa = np.asarray(bytearray(buf), dtype=np.uint8)
        im = cv2.imdecode(npa, 1)
        return im
        
    @staticmethod
    def cvencode(im):
        ret, buf = cv2.imencode('.jpg', im)
        buf = np.array(buf).tostring()
        return buf
        
    @staticmethod
    def cvgrey(im):
        im = cv2.cvtColor(im, cv2.COLOR_BGR2GRAY)
        return im

    @staticmethod
    def phash(im):
        if im is None:
            return 0
        if len(im.shape) == 3 and im.shape[-1] == 3:
            im = ImageUtils.cvgrey(im)
        im = im.astype(float)
        im = ImageUtils.cvresize(im, (32, 32))
        from scipy.fftpack import dct
        dim = dct(im)
        mean = np.sum(dim) / (32. * 32.)
        val = 0
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值