python -opencv 图像锐化

python -opencv 图像锐化

图像锐化其实,是一种增强图片对比度的技术,我们可以通过计算图像的导数,把导数绝对值数值大于零的数值加回原图像,通过这种方法,可以增强图像的对比度。
实现代码如下:

import copy
import math
import matplotlib.pyplot as plt
import matplotlib as mpl
import numpy as np
import os

import cv2

plt.rcParams['font.family'] = 'Microsoft YaHei'

def cv_show(name,img):
    cv2.imshow(name,img)
    #cv2.waitKey(0),接收0,表示窗口暂停
    cv2.waitKey(0)
    #销毁所有窗口
    cv2.destroyAllWindows()


path=r'D:\learn\photo\cv\muxing.jpg'



img=cv2.imread(path,0)



row,col=img.shape
gra=np.zeros((row,col))
img=img.astype('float')
gra=gra.astype('float')
for x in range(row-1):
    for y in range(col-1):
        gx=abs(img[x+1,y]-img[x,y])
        gy=abs(img[x,y+1]-img[x,y])
        gra[x,y]=gx+gy


sharp=img+gra
sharp=np.where(sharp>255,255,sharp)
sharp=np.where(sharp<0,0,sharp)
gra=gra.astype('uint8')
sharp=sharp.astype('uint8')
#cv_show('img',img)
#cv_show('sharp',sharp)

plt.subplot(121)
plt.imshow(img,'gray')
plt.title('原图')

plt.subplot(122)
plt.imshow(sharp,'gray')
plt.title('锐化图')
#plt.subplot(223)
#plt.imshow(img_s)
#plt.title('平移')
#plt.subplot(224)
#plt.imshow(img_r)
#plt.title('旋转')
plt.show()
os.system("pause")

运行结果如下:
在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【资源说明】 1.项目代码均经过功能验证ok,确保稳定可靠运行。欢迎下载食用体验! 2.主要针对各个计算机相关专业,包括计算机科学、信息安全、数据科学与大数据技术、人工智能、通信、物联网等领域的在校学生、专业教师、企业员工。 3.项目具有丰富的拓展空间,不仅可作为入门进阶,也可直接作为毕设、课程设计、大作业、初期项目立项演示等用途。 4.当然也鼓励大家基于此进行二次开发。在使用过程中,如有问题或建议,请及时沟通。 5.期待你能在项目中找到乐趣和灵感,也欢迎你的分享和反馈! 【项目介绍】 基于Python-OpenCV+Pyqt5开发的图像处理系统源码附说明文档(内含常用图像处理方法和技术).zip 整合常用图像处理方法和技术,设计精美 UI 界面,开发出一套基于 OpenCV 的图像处理系统 实现功能 # 文件操作 打开、关闭、保存一幅图像 # 亮度对比度调节 调整图像的亮度和对比度 # 几何变换 对图像放大、缩小、旋转、翻转 # 灰度变换 图像灰度化、图像反转、图像二值化 # 直方图处理 直方图均衡化和直方图规定化,以及直方图的绘制 # 加性噪声 高斯噪声、椒盐噪声以及随机噪声 # 平滑处理 均值滤波、中值滤波、高斯滤波以及双边滤波 # 锐化处理 选择不同的算子对图像进行锐化,包括 sobel 算子、robert 算子、prewitt 算子、laplacain 算子 # 频域滤波 高通滤波和低通滤波 # 边缘检测 选择 laplacian 算子、sobel 算子和 canny 算子进行边缘检测 # 目标检测 yolov5、人脸检测和图像分割 代码运行 # 安装依赖 ```sh pip install -r requirements.txt ``` # 运行 ```sh python ImageProcessing.py ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值