V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
LeeReamond
V2EX  ›  算法

滤波有什么快速搜索邻域极大值极小值的算法吗?

  •  
  •   LeeReamond · 2023-09-23 04:29:52 +08:00 · 907 次点击
    这是一个创建于 460 天前的主题,其中的信息可能已经有所发展或是发生改变。

    二维图像里要做卷积是比较简单,比如一个像素包含自身在内其周围有九个点,经过[1,1,1,1,1,1,1,1,1]卷积核以后就可以得到周围九点均值,卷积运算属于库里写好的。 但是如果想替换为周围九点内极大值或者极小值呢?有没有什么快速算法,我想了半天还是只能遍历?

    5 条回复    2023-09-23 14:25:40 +08:00
    wormtooth
        1
    wormtooth  
       2023-09-23 04:41:46 +08:00
    每个像素至少要读一次,最多(遍历)是九次。无论怎样都跟像素数量成正比,所以遍历就好。大部分库应该有现成的 MaxPooling. 求最小可以 -MaxPooling(-x)
    wormtooth
        2
    wormtooth  
       2023-09-23 04:46:33 +08:00   ❤️ 1
    如果核很大(相对于二维图像),可以考虑二分查找
    jackOff
        3
    jackOff  
       2023-09-23 09:43:01 +08:00 via Android
    布隆过滤器?
    lance6716
        4
    lance6716  
       2023-09-23 12:32:08 +08:00 via Android
    多刷 leetcode 就能看到这种题啊。思路是,假设是最大值池化,在窗口向右平移的过程中,如果一个点 a 右侧有比它更大的点 b ,就可以直接舍弃点 a ,因为有 b 在 a 永无出头之日
    passive
        5
    passive  
       2023-09-23 14:25:40 +08:00 via Android
    楼上说了那么多,倒是给出一个核啊😸
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1262 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 17:52 · PVG 01:52 · LAX 09:52 · JFK 12:52
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.