数字图像处理-7-图像的梯度锐化算法

文章目录

  • [1. 门限梯度锐化](#1. 门限梯度锐化)
  • [2. 梯度二值化](#2. 梯度二值化)
  • [3. 固定值梯度锐化](#3. 固定值梯度锐化)

图像梯度是灰度值在空间上的变化速率。平滑区域梯度小(灰度均匀),边缘区域梯度大(灰度急变)。
其实这种方法在前面也说过,计算公式如下: 一阶差分近似

G(x, y) = sqrt( (f(x,y) - f(x-1,y))² + (f(x,y) - f(x,y-1))² )

梯度锐化根据梯度大小采取三种不同的增强策略:

    1. 门限锐化 --- 梯度大则增加固定亮度 +100(可动态调整),边缘变亮但保留纹理
    1. 二值化 --- 根据梯度输出纯黑/白二值图,清晰显示边缘轮廓
    1. 固定锐化 --- 梯度大则强制输出白色,否则保留原灰度值

下面是一阶差分近似梯度的python代码,在下面三种方法中都会用到, 原理简单.就是计算上下,左右 的梯度值, 然后求各个维度差分平方的和.

这里说明下下面代码片段中默认阈值(GRADIENT_THRESHOLD=30)

python 复制代码
def _compute_gradient(img, x, y):
    """
    计算像素 (x, y) 的梯度幅度(使用左邻和上邻的一阶差分)。

    公式: G = sqrt( dx² + dy² )
      dx = f(x, y) - f(x-1, y)
      dy = f(x, y) - f(x, y-1)
    """
    curr = img.get_pixel(x,     y)
    left = img.get_pixel(x - 1, y)
    up   = img.get_pixel(x,     y - 1)
    dx = curr - left
    dy = curr - up
    return math.sqrt(dx * dx + dy * dy)

1. 门限梯度锐化

  • 原理:

    对边缘区域(梯度≥阈值)叠加固定亮度 100(默认),使边缘在视觉上更突出;

    平坦区域保持原值,不破坏背景纹理细节。

  • 处理方法:

    设置阈值threhold, 如果超过了阈值,则在当前灰度值上面叠加指定的灰度值,让图像边缘更突出

    复制代码
    G >= threshold → output = min(G + 100, 255)   [边缘增亮]
    G <  threshold → output = 原始像素值            [平坦区域不变]
  • python代码

python 复制代码
def threshold_enhance(img, threshold=GRADIENT_THRESHOLD):
    result = img.clone()

    for y in range(1, img.height):
        for x in range(1, img.width):
            g = _compute_gradient(img, x, y)
            if g >= threshold:
                result.set_pixel(x, y, min(255, g + 100))
            # g < threshold 时 clone 的原值保持不变

    return result
  • 效果图

2. 梯度二值化

  • 原理:

    对梯度图像进行全局阈值分割,输出纯黑白二值图。结果图像清晰地勾勒出边缘轮廓,常用于后续形态学处理。

  • 处理方法:

    这其实就是二值化的处理过程

    复制代码
    G >  threshold → output = 255  (白色,边缘)
    G <= threshold → output = 0    (黑色,非边缘)
  • python代码

python 复制代码
def binary_threshold(img, threshold=GRADIENT_THRESHOLD):
    result = Image(img.width, img.height)   # 默认全黑

    for y in range(1, img.height):
        for x in range(1, img.width):
            g = _compute_gradient(img, x, y)
            result.set_pixel(x, y, 255 if g > threshold else 0)

    return result
  • 效果图

3. 固定值梯度锐化

  • 原理:
    介于门限增强和二值化之间:
    边缘被强制置为最大亮度(255),突出轮廓;
    非边缘区域保留原始灰度,保持背景信息可读。
  • 处理方法:
    G > threshold → output = 255 边缘高亮为白色
    G <= threshold → output = 原始像素值 非边缘保留原灰度
python 复制代码
def fixed_enhance(img, threshold=GRADIENT_THRESHOLD):
    result = img.clone()

    for y in range(1, img.height):
        for x in range(1, img.width):
            g = _compute_gradient(img, x, y)
            if g > threshold:
                result.set_pixel(x, y, 255)
            # g <= threshold 时保持 clone 的原值

    return result
  • 效果图
相关推荐
sali-tec16 小时前
C# 基于OpenCv的视觉工作流-章84-包胶有无检测
图像处理·人工智能·opencv·算法·计算机视觉
安逸sgr17 小时前
《图解机器学习-第三章》:训练、验证、测试:三分数据,缺一不可!
人工智能·深度学习·机器学习·计算机视觉
韩师傅17 小时前
用 7 年前的 SHWD 数据,带你读一遍 Ultralytics predict 链
计算机视觉
硅谷秋水18 小时前
ProDrive:基于自身-环境协同演化的自动驾驶主动规划
人工智能·深度学习·机器学习·计算机视觉·自动驾驶
菜鸟‍18 小时前
【论文学习】2026.5 || 分解式视觉-语言对齐用于细粒度开放词汇分割
人工智能·深度学习·计算机视觉
郝学胜-神的一滴19 小时前
[简化版 GAMES 101] 计算机图形学 13:从光栅化到着色——赋予三维像素光影灵魂
c++·计算机视觉·unity·godot·图形渲染·opengl·unreal
硅谷秋水1 天前
面向长上下文自动驾驶的规划对齐Token压缩
人工智能·深度学习·机器学习·计算机视觉·自动驾驶
YOLO数据集集合1 天前
无人机山地灾害巡检数据集 | 滑坡多区域实例分割 遥感影像解译 地质灾害预警深度学习数据10296期
人工智能·深度学习·目标检测·计算机视觉·无人机
庄周迷蝴蝶1 天前
Vision Banana
人工智能·计算机视觉
Java患者·1 天前
《Python 人脸识别入门实践:从人脸检测到人脸比对完整实现》
开发语言·python·opencv·目标检测·计算机视觉·目标跟踪·视觉检测