内容简介:研一学习数字图像处理(刚萨雷斯版),导师让我用Python编写基于拉普拉斯算子的图像锐化,并且是在不直接调用OpenCV的情况下,由于现在还没有学习锐化彩色图像,所以本博客先联系锐化灰度图。Python代码如下:写着玩,只想记录自己在Python和图像处理的成长。
**Python实现基于OpenCV的拉普拉斯图像锐化**
研一学习数字图像处理(刚萨雷斯版),导师让我用 Python 编写基于拉普拉斯算子的图像锐化,并且是在不直接调用OpenCV的情况下,由于现在还没有学习锐化彩色图像,所以本博客先联系锐化灰度图。
Python代码如下:
import cv2 as cv import numpy as np rgb = cv.imread("D:/a.jpg") weight=rgb.shape[0] height=rgb.shape[1] number=rgb.shape[2] print("原图像大小:\n""weight: %d \nheight: %d \nnumber: %d" %(weight,height,number)) # 检查图像大小 img=cv.resize(rgb,(int(weight/6),int(height/6)),interpolation=cv.INTER_CUBIC) # 将图像缩小为原来的六分之一倍 grayimg=np.zeros((img.shape[0],img.shape[1],1),np.uint8) weight=int(weight/6) height=int(height/6) print("裁剪后图像大小:\n""weight: %d \nheight: %d \nnumber: %d" %(weight,height,number)) for i in range(weight): for j in range(height): grayimg[i,j] = 0.299 * img[i, j, 0] + 0.587 * img[i, j, 1] + 0.114 * img[i, j, 2] # 将原图片转为灰度图片 t1 = list([[0,1,0], [1,-4,1], [0,1,0]]) # 定义拉普拉斯滤波器 shp=grayimg*1 # 设置一个新的图片变量,防止修改原图片 shp=np.pad(grayimg,((1, 1), (1, 1),(0,0)),"constant",constant_values=0) # 为原图片加一层边缘 for i in range(1,weight-1): for j in range(1,height-1): shp[i,j]=abs(np.sum(shp[i:i+3,j:j+3]*t1)) # 对灰度图进行锐化 cv.imshow('srcImage', img) cv.imshow('grayImage', grayimg) cv.imshow("Laplacian",grayimg+shp[1:shp.shape[0]-1,1:shp.shape[1]-1]) cv.waitKey(0) cv.destroyAllWindow()
写着玩,只想记录自己在Python和图像处理的成长。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Opencv图像处理系列(六)—— 图像梯度
- opencv笔记(2):图像剪切和图像移位
- Opencv图像处理系列(九)—— 图像轮廓
- Python 图像处理 OpenCV (15):图像轮廓
- Opencv图像处理系列(三)——图像二值化
- Opencv图像处理系列(八)—— 图像金字塔
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
现代操作系统(第3版)
Andrew S. Tanenbaum / 陈向群、马洪兵 / 机械工业出版社 / 2009-7 / 75.00元
本书是操作系统领域的经典之作,与第2版相比,增加了关于Linux、Windows Vista和Symbian操作系统的详细介绍。书中集中讨论了操作系统的基本原理,包括进程、线程、存储管理、文件系统、输入/输出、死锁等,同时还包含了有关计算机安全、多媒体操作系统、掌上计算机操作系统、微内核、多核处理机上的虚拟机以及操作系统设计等方面的内容。此外,还在第2版的基础上对部分习题进行了增删,更有助于读者学......一起来看看 《现代操作系统(第3版)》 这本书的介绍吧!