数字图像处理基础与应用 第五章

这段代码实现了一个简单的图像锐化算法,通过单方向的差分算子对灰度图像进行处理。首先定义了一个函数`singleDirectionSharp`,它遍历图像并应用特定的算子来增强边缘。然后读取图像,将其转换为灰度,调用该函数,最后保存和显示处理后的图像。该过程展示了基础的图像处理操作。
摘要由CSDN通过智能技术生成

5-1感觉这些方法主体都差不多,就是微分算子不同,懒得一个个写了

from cv2 import cv2
import numpy as np
import random


def singleDirectionsharpen(img, N=3):
    p = N // 2
    img_shape = np.shape(img)
    out = np.zeros(img_shape)
    for i in range(img_shape[0]):
        for j in range(img_shape[1]):
            if i >= p and i < img_shape[0] - p and j >= p and j < img_shape[1] - p:
                out[i][j] = img[i - 1][j - 1] - img[i + 1][j - 1] + 2 * (img[i - 1][j] - img[i + 1][j]) + img[i - 1][j + 1] - img[i + 1][j + 1]
            else:
                out[i][j] = 0
    return out



img = cv2.imread("C:\\test\\1.jpg")
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
single_irection_sharpen = singleDirectionsharpen(gray)

cv2.imwrite("C:\\test\\single_irection_sharpen.jpg", single_irection_sharpen)

single_irection_sharpen = cv2.imread("C:\\test\\single_irection_sharpen.jpg")

cv2.imshow('gray', gray)
cv2.imshow('single_irection_sharpen', single_irection_sharpen)

cv2.waitKey()
cv2.destroyAllWindows
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值