【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

这篇具有很好参考价值的文章主要介绍了【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Sharpen锐化

Image sharpening algorithms are a technique used to enhance details and edges in images. These methods can all be used for image sharpening. In short, sharpening is about enhancing the difference on edges (what is an edge, see image edge detection, etc.) to highlight the color brightness value between pixels around the edge.

Edge detection is to find the edge information of the image, that is, the place where the pixel changes greatly, that is, to calculate the gradient value for the derivative, the commonly used method mainly involves the calculation of first-order differentiation and second-order differentiation. Specifically, you should choose the appropriate method according to your needs.

Method

Good detection results: low false detection rate of edges, avoiding the detection of false edges while detecting true edges; The edge position of the marker should be as close as possible to the real edge position on the image.

When calculating the gradient of the image (the intensity of change between pixels), unlike the differential derivation of one-dimensional data, convolutional calculations are mainly used in two-dimensional or above-dimensional arrays (what is convolutional computing, self-search, recently known as due to the fire of deep learning networks), the following are several common image sharpening algorithms:

  • 1.拉普拉斯算子(Laplace operator, Laplacian)

  • 2.高斯——拉普拉斯算子(Laplacian of Gaussian)

  • 3.Roberts算子

  • 4.Sobel算子

  • 5.Prewitt算法

锐化综述

图像锐化算法是一种用于增强图像中细节和边缘的技术。这些方法都可以用于图像锐化。 简言之,锐化就是增强边缘上的差异(何为边缘检测,可查看图像边缘检测等内容),来突出边缘周围像素间颜色亮度值。

边缘检测在于找到图像边缘信息,就是像素变化较大的地方,即为求导数算梯度值,常用的方法主要涉及的计算就是一阶微分二阶微分等计算。具体应该根据需要选择适合的方法。

好的检测结果:对边缘的错误检测率低,在检测出真实边缘的同时,避免检测虚假边缘;标记的边缘位置要和图像上真正的边缘位置尽量接近。

在计算图像的梯度(像素间变化强度)时,与一维数据微分求导不同,在二维或以上维度数组主要用的是卷积计算(何为卷积计算,自行搜索,最近为大家所熟知是由于深度学习网络的大火),以下是常见的几种图像锐化算法:

1. 拉普拉斯算子锐化:

拉普拉斯是一种二阶微分计算。通过在原始图像上应用拉普拉斯滤波器来增强图像中的边缘和细节,边缘定位准确,对噪声非常敏感。
推导出的拉普拉斯卷积核两个常用示例如下。拉普拉斯卷积核中心值比较大,意味着在做计算中,图像当前像素值占权重较大,锐化时为了增大与周围像素的差异,周围像素值较小。在卷积核中,中心像素值为9,表示将中心像素的强度值增加,周围像素的强度值减少。这样,锐化后的图像将具有更强的边缘和更清晰的细节。这就会使得计算后突变的像素更加突出,慢变的像素相对弱化。

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

拉普拉斯算子

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

原图

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

laplace

(不平滑,但效果明显)

缺点:这种方法可能会导致图像噪声的增加,丢失部分边缘方向信息,导致一些不连续的检测边缘。优点:把x、y两个方向均考虑了,不依赖于方向,对阶跃型边缘检测很准。

2. 高斯——拉普拉斯算子锐化(LoG):

该方法相较于拉普拉斯算法,是一种更好的边缘检测器。它把高斯模糊平滑器和拉普拉斯锐化结合起来,先用高斯核对图像进行平滑去噪,再用拉普拉斯核对图像进行边缘检测锐化。
该卷积核的中心权重很大,周围随着距离增加权重系数逐渐降低。示例两种高斯——拉普拉斯卷积核如下:

(右为Usharpe Masking法)

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

原图

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

LoG(中间算子)

(相较于Laplace效果更加平滑)

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

Usharpe Masking(右算子)

(相较于Laplace效果更加平滑)

优点:主要是对于拉普拉斯算子的优化,将高斯平滑考虑其中,降低了拉普拉斯算子对于噪声抑制能力差的问题。缺点:但同时无法避免对于一些尖锐的高频特征,也会有一定的平滑,其中高斯卷积的方差参数会对边缘检测效果有一定影响。

3. Roberts算子锐化:

是一种斜向偏差分的梯度计算方法,梯度的大小代表边缘的强度,梯度的方向与边缘的走向垂直。卷积核如下:

Roberts算子

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

原图

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

Roberts(左算子)

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

Roberts(右算子)

缺点:对角线相减,定位比较高,但是没有平滑处理,直接减,容易丢失一部分边缘,不具备抗噪声的能力。优点:但对陡峭边缘且含噪声少的图像效果较好。

4. Sobel算子锐化:

通过在原始图像上应用Sobel算子,可以增强图像中的水平和垂直边缘。这种方法比拉普拉斯算子锐化更平滑。卷积核如下:

Sobel算子

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

原图

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

Sobel(左算子)

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

Sobel(右算子)

缺点:对噪声有一定平滑抑制的能力,但是还会存在虚假边缘检测,容易检测出多像素的边缘宽度。

5. Prewitt算法:

Prewitt算法和sobel算法类似,只是卷积核的权重值不同。Prewitt算法的卷积核模板对于周围像素的中间位置像素权重与两侧权重相同,这使得周围3临近的像素对于当前像素的影响相同。卷积核如下:

Prewitt算子

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

原图

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

Prewitt(左算子)

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

Prewitt(算子)

6. Canny算子锐化:

Canny算子锐化是一种多阶段边缘检测算法,可在保留更多真实边缘的同时减少噪声。由于Canny输出为二值数据(边缘、非边缘),锐化暂时未考虑该方法。

Canny边缘检测算法主要包括以下五个步骤:

  • 对图像进行高斯滤波,以去除噪声。
  • 计算图像的梯度幅值和方向。
  • 对梯度幅值进行非极大值抑制。
  • 使用双阈值法进行边缘跟踪。
  • 去除噪声并连接边缘。

具体GLSL实现Canny边缘检测实现请看:链接(候补)。

7. Unsharp Masking锐化:

Unsharp Masking锐化也是一种常用的图像增强技术,它通过对原始图像进行高斯模糊并将其减去原始图像,然后对结果应用增强锐化滤波器,以增强图像的细节和边缘。
最初应用于暗房摄影。它的名字来源,即该技术使用模糊的或“不清晰的”负片图像来创建蒙版原始图像的。然后将反锐化蒙版与原始正像结合,创建一个比原始图像更不模糊的图像。生成的图像虽然更清晰,但对图像主体的表示可能不太准确。
卷积核为:。其计算过程如下:

属于高斯——拉普拉斯算子的一种,其效果如下:

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

原图

【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】

Unsharp Masking(LoG算子)

代码实现例程:

主要通过 C++Pythonshader GLSL实现。文章来源地址https://www.toymoban.com/news/detail-471106.html

(1). OpenCV(C++):

#include <opencv2/opencv.hpp>
using namespace cv;

int main() {
// 读取图像
Mat img = imread("image.jpg");
// 定义锐化卷积核(以拉普拉斯算子为例)
Mat kernel = (Mat_<float>(3,3) << -1,-1,-1,
                                   -1, 9,-1,
                                   -1,-1,-1);

// 应用锐化卷积核
Mat sharp_img;
filter2D(img, sharp_img, -1, kernel);

// 显示原图和锐化后的图像
namedWindow("Original Image");
namedWindow("Sharpened Image");
imshow("Original Image", img);
imshow("Sharpened Image", sharp_img);
waitKey(0);
destroyAllWindows();

return 0;
}

(2). OpenCV(Python):

import cv2
import numpy as np

# 读取图像
img = cv2.imread('image.jpg')

# 定义锐化卷积核(以拉普拉斯算子为例)
kernel = np.array([[-1,-1,-1],
                   [-1, 9,-1],
                   [-1,-1,-1]])

# 应用锐化卷积核
sharp_img = cv2.filter2D(img, -1, kernel)

# 显示原图和锐化后的图像
cv2.imshow('Original Image', img)
cv2.imshow('Sharpened Image', sharp_img)
cv2.waitKey(0)
cv2.destroyAllWindows()

(3). GLSL版本(片段着色器):

varying vec2 vv2_Texcoord;   // 纹理坐标
uniform sampler2D m_texture; // 原图片

vec3 mtexSample(const float x, const float y)
{
    vec2 uv = vv2_Texcoord + vec2(x / 1280.0, y / 720.0); // 纹理分辨率:1280,720
    lowp vec3 textureColor = texture2D(m_texture, uv);    // 图像纹理采样
    return textureColor;
}

vec3 sharpen(vec2 fragCoord, float strength)
{
    //卷积核 (以拉普拉斯算子为例)
    vec3 f =
        mtexSample(-1.0, -1.0) * -1.0 +
        mtexSample(0.0, -1.0) * -1.0 +
        mtexSample(1.0, -1.0) * -1.0 +

        mtexSample(-1.0, 0.0) * -1.0 +
        mtexSample(0.0, 0.0) * 9.0 +
        mtexSample(1.0, 0.0) * -1.0 +

        mtexSample(-1.0, 1.0) * -1.0 +
        mtexSample(0.0, 1.0) * -1.0 +
        mtexSample(1.0, 1.0) * -1.0;

    return mix(vec4(mtexSample(0.0, 0.0), 1.0), vec4(f, 1.0), strength).rgb;
}

void main()
{
    vec3 sharpened = sharpen(vv2_Texcoord, 1.0);
    gl_FragColor = vec4(sharpened, 1.0);
}

到了这里,关于【图像增强——7种锐化方法原理与实现(C++、Python、shader GLSL)】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 拉普拉斯锐化[原理及Python实现](含拉氏标定、拉普拉斯标定)

    [原理及Python实现](含拉氏标定、拉普拉斯标定) 原创文章;转载请注明出处:©️ Sylvan Ding 锐化处理的主要目的是突出灰度的过度部分。图像锐化的用途多种多样,应用范围从电子印刷和医学成像到工业检测和军事系统的制导等。利用图像微分可以增强边缘和其他突变(如

    2023年04月10日
    浏览(36)
  • opencv图像增强实现方法

      opencv是一款开源的图像增强工具,主要用于在 python环境下实现图像增强功能。 使用 opencv实现图像增强,需要使用 opencv的 GUI模块,如图1所示。 在 opencv中,有一个 datasets模块,这个模块主要用于处理数据和可视化操作,如图2所示。 在这里我们将使用这个 datasets模块进行图

    2024年02月06日
    浏览(38)
  • (数字图像处理MATLAB+Python)第七章图像锐化-第一、二节:图像锐化概述和微分算子

    图像锐化 :是一种用于改善图像质量的技术,它可以 增强图像中的高频细节信息 ,从而使得图像更加清晰和有视觉冲击力。在图像处理和计算机视觉中,图像锐化通常被用于特征提取、图像增强、目标识别等应用中 图像边缘分析 :是一种用于在图像中找到 明显的边缘或轮

    2024年02月01日
    浏览(49)
  • Python与FPGA——图像锐化

      在增强图像之前一般会先对图像进行平滑处理以减少或消除噪声,图像的能量主要集中在低频部分,而噪声和图像边缘信息的能量主要集中在高频部分。因此,平滑处理会使原始的图像边缘和轮廓变得模糊。为了减少不利效果的影响,需要利用图像锐化技术。   图像锐

    2024年03月23日
    浏览(24)
  • WebGL Shader着色器GLSL语言

    在2D绘图中的坐标系统,默认情况下是与窗口坐标系统相同,它以canvas的左上角为坐标原点,沿X轴向右为正值,沿Y轴向下为正值。其中canvas坐标的单位都是’px’。 WebGL使用的是正交右手坐标系,且每个方向都有可使用的值的区间,超出该矩形区间的图像不会绘制: X轴最左

    2024年02月14日
    浏览(35)
  • Python实现图像对比度增强

    Python实现图像对比度增强 在数字图像处理中,对比度增强被广泛运用于图像增强、图像去噪、特征提取等领域。本文将用Python实现一种简单的图像对比度增强方法,并提供源代码。 首先,我们需要导入必要的库:numpy和OpenCV。在执行之前确保已安装这两个库。 以下是我们实

    2024年02月07日
    浏览(35)
  • 数字图像处理与Python实现-图像增强经典算法汇总

    本文将对图像增强经典算法做一个简单的汇总。图像增强的经典算法有:像素变换、图像逆变换、幂律变换、对数变换、图像均衡化、对比受限自适应直方图均衡(CLAHE)、对比度拉伸、Sigmoid校正、局部对比度归一化。 转换是将一组输入映射到一组输出的函数,这样每个输入

    2024年02月09日
    浏览(31)
  • 【OpenCV Python实现图像增强:高斯模糊和运动模糊】

    【OpenCV Python实现图像增强:高斯模糊和运动模糊】 图像处理是计算机视觉领域的重要分支,它在各个领域都有广泛的应用。图像增强是其中的一个重要技术,可以帮助我们提升图像的质量和清晰度。本文将介绍如何使用Python和OpenCV库来实现两种常见的图像增强方法:高斯模

    2024年02月12日
    浏览(32)
  • 【Webgl_glsl&Threejs】搬运分享shader_飘落心形

    将shadertory上的代码转成了threejs可以直接用的代码,引入文件的material,并在创建mesh或已有物体上使用material即可,使用时请注意uv对齐。 flowHeart

    2024年04月27日
    浏览(22)
  • 学习笔记:Opencv实现拉普拉斯图像锐化算法

    2023.8.19 为了在暑假内实现深度学习的进阶学习,Copy大神的代码,记录学习日常 图像锐化的百科: 图像锐化算法-sharpen_lemonHe_的博客-CSDN博客 在环境配置中要配置opencv: pip install opencv-contrib-python Code and lena.png:注意你是否在data下由lena.png   附上lena.png  效果所示(解读):

    2024年02月12日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包