栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

高斯边缘检测的拉普拉斯算术的Python实现

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

高斯边缘检测的拉普拉斯算术的Python实现

matlab edge()应该做什么

  1. 计算LOG
  2. 计算LoG上的零交叉
  3. 计算本地LoG差异的阈值
  4. 边缘像素=零交叉&&局部差异>阈值

scipy的LoG过滤器仅执行上述步骤1。我实现了以下代码段来模仿上面的步骤2〜4:

import scipy as spimport numpy as npimport scipy.ndimage as ndimport matplotlib.pyplot as pltfrom skimage import data# lena = sp.misc.lena() this function was deprecated in version 0.17img = data.camera()  # use a standard image from skimage insteadLoG = nd.gaussian_laplace(img , 2)thres = np.absolute(LoG).mean() * 0.75output = sp.zeros(LoG.shape)w = output.shape[1]h = output.shape[0]for y in range(1, h - 1):    for x in range(1, w - 1):        patch = LoG[y-1:y+2, x-1:x+2]        p = LoG[y, x]        maxP = patch.max()        minP = patch.min()        if (p > 0): zeroCross = True if minP < 0 else False        else: zeroCross = True if maxP > 0 else False        if ((maxP - minP) > thres) and zeroCross: output[y, x] = 1plt.imshow(output)plt.show()

这当然很慢,并且可能不是惯用的,因为我也是Python的新手,但应该可以证明这个想法。也欢迎任何有关如何改进它的建议。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/648652.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号