python图像处理拉普拉斯算⼦的实现和改进-LoG和DoG算⼦拉普拉斯算⼦
拉普拉斯算⼦是最简单的各向同性微分算⼦,它具有旋转不变性。
我们经常把它作为边缘检测之⼀,也是⼯程数学中常⽤的⼀种积分变换,也可以⽤于图像增强、⾓点检测等等。
这⾥只给出它的代码,原理可参考其他博客及百科。
在图像处理中,拉普拉斯算⼦为离散的形式,其核⼼就是⼀个3✖3的卷积核。
# 图像增强算法
# 拉普拉斯算⼦,⾃编写实现,利⽤空域卷积运算实现滤波
# 具有图像增强效果,同时亦可⽤于边缘检测、⾓点检测
import cv2
import numpy as np
import matplotlib.pyplot as plt
if __name__ =='__main__':
src = cv2.imread('enhance.jpg',1)
plt.subplot(3,2,1)
plt.imshow(src)
plt.axis('off')
plt.title('Offical')
kernel = np.array([[-1,-1,-1],
[2,2,2],
[-1,-1,-1]])
horizontal_edge = cv2.filter2D(src, cv2.CV_32F, kernel)
horizontal_edge = vertScaleAbs(horizontal_edge)
# _, horizontal_edge = cv2.threshold(horizontal_edge, horizontal_edge.max() * 0.8, 255, cv2.THRESH_BINARY)
plt.subplot(3,2,2)
plt.imshow(horizontal_edge)
plt.axis('off')
plt.title('horizontal_edge')
kernel = np.array([[-1,2,-1],
[-1,2,-1],
[-1,2,-1]])
vertical_edge = cv2.filter2D(src, ddepth=cv2.CV_32F, kernel=kernel)
vertical_edge = vertScaleAbs(vertical_edge)
# _, vertical_edge = cv2.threshold(vertical_edge, vertical_edge.max() * 0.8, 255, cv2.THRESH_BINARY)
plt.subplot(3,2,3)
plt.imshow(vertical_edge)
plt.axis('off')
plt.title('vertical_edge')
kernel = np.array([[-1,-1,2],
[-1,2,-1],
[2,-1,-1]])
positive_45_deg_edge = cv2.filter2D(src, ddepth=cv2.CV_32F, kernel=kernel)
positive_45_deg_edge = vertScaleAbs(positive_45_deg_edge)
# positive_45_deg_edge = cv2.threshold(positive_45_deg_edge, positive_45_deg_edge.max() * 0.8, 255, cv2.THRESH_BINARY)
plt.subplot(3,2,4)
plt.imshow(positive_45_deg_edge)
plt.axis('off')
plt.title('positive_45_deg_edge')
kernel = np.array([[2,-1,-1],
[-1,2,-1],
[-1,-1,2]])
negative_45_deg_edge = cv2.filter2D(src, ddepth=cv2.CV_32F, kernel=kernel)
negative_45_deg_edge = vertScaleAbs(negative_45_deg_edge)
# negative_45_deg_edge = cv2.threshold(negative_45_deg_edge, negative_45_deg_edge.max() * 0.8, 255, cv2.THRESH_BINARY)
cv2.imshow('negative_45_deg_edge', negative_45_deg_edge)
plt.subplot(3,2,5)
plt.imshow(negative_45_deg_edge)
plt.axis('off')
plt.title('negative_45_deg_edge')
plt.show()
结果展⽰:
LoG和DoG算⼦
LoG和DoG算⼦是拉普拉斯算⼦的改进⽅法。
LoG:⾼斯拉普拉斯算⼦(LoG,Laplacian of Gaussian),⾸先对图像进⾏⾼斯暖卷积滤波进⾏降噪处理,再采⽤Laplace算⼦进⾏边缘检测。
DoG:⾼斯函数差分(DoG, Difference of Gaussian), 是可以通过将图像与⾼斯函数进⾏卷积得到⼀幅图像的低通滤波结果,即去噪过程,这⾥的Gaussian和⾼斯低通滤波器的⾼斯⼀样,是⼀个函数,即为正态分布函数。同时,它对⾼斯拉普拉斯LoG的近似.
# 图像增强算法
# LoG和DoG算⼦
linspace函数python# 均为基于拉普拉斯算⼦的改进
# 可⽤于边缘检测和⾓点检测
import cv2
import numpy as np
import matplotlib.pyplot as plt
def genGaussianKernel(ksize, sigma):
half_ksize = ksize //2
C =2* np.pi * sigma * sigma
x = y = np.linspace(-half_ksize, half_ksize, ksize)
x, y = np.meshgrid(x, y)
kernel = np.exp(-(x **2+ y **2)/(2* sigma **2))/ C
return kernel
def zerosCrossing(src, thresh):
dsize =(src.shape[1], src.shape[0])
M = np.array([[1,0,-1],[0,1,0]], dtype=np.float32)
shift_left = cv2.warpAffine(src, M, dsize)
M = np.array([[1,0,1],[0,1,0]], dtype=np.float32)
shift_right = cv2.warpAffine(src, M, dsize)
M = np.array([[1,0,0],[0,1,-1]], dtype=np.float32)
shift_up = cv2.warpAffine(src, M, dsize)
M = np.array([[1,0,0],[0,1,1]], dtype=np.float32)
shift_down = cv2.warpAffine(src, M, dsize)
M = np.array([[1,0,1],[0,1,1]], dtype=np.float32)
shift_right_down = cv2.warpAffine(src, M, dsize)
M = np.array([[1,0,-1],[0,1,-1]], dtype=np.float32)
shift_left_up = cv2.warpAffine(src, M, dsize)
M = np.array([[1,0,1],[0,1,-1]], dtype=np.float32)
shift_right_up = cv2.warpAffine(src, M, dsize)
M = np.array([[1,0,-1],[0,1,1]], dtype=np.float32)
shift_left_down = cv2.warpAffine(src, M, dsize)
shift_left_right_sign =(shift_left * shift_right)
shift_up_down_sign =(shift_up * shift_down)
shift_rd_lu_sign =(shift_right_down * shift_left_up)
shift_ru_ld_sign =(shift_right_up * shift_left_down)
shift_left_right_norm =abs(shift_left - shift_right)
shift_up_down_norm =abs(shift_up - shift_down)
shift_rd_lu_norm =abs(shift_right_down - shift_left_up)
shift_ru_ld_norm =abs(shift_right_up - shift_left_down)
candidate_zero_crossing = \
((shift_left_right_sign <0)&(shift_left_right_norm > thresh)).astype('uint8')+\ ((shift_up_down_sign <0)&(shift_up_down_norm > thresh)).astype('uint8')+ \ ((shift_rd_lu_sign <0)&(shift_rd_lu_norm > thresh)).astype('uint8')+ \
((shift_ru_ld_sign <0)&(shift_ru_ld_norm > thresh)).astype('uint8')
ResImg = np.zeros(shape=src.shape, dtype=np.uint8)
ResImg[candidate_zero_crossing >=2]=255
return ResImg
def LoG(src, ksize, sigma=0, thresh=None, alpha=0.01):
blur_img = cv2.GaussianBlur(src.astype('float32'),(ksize, ksize), sigmaX=sigma) LoG_img = cv2.Laplacian(blur_img, cv2.CV_32F)
if thresh is None:
thresh =abs(LoG_img).max()* alpha
edge_image = zerosCrossing(LoG_img, thresh)
return edge_image
def DoG(src, ksize, sigma, thresh=None, alpha=0.01):
sigma2 = sigma /1.6
kernel_1 = genGaussianKernel(ksize=ksize, sigma=sigma)
kernel_2 = genGaussianKernel(ksize=ksize, sigma=sigma2)
kernel = kernel_1 - kernel_2
DoG_img = cv2.filter2D(src=src, ddepth=cv2.CV_32FC1, kernel=kernel)
if thresh is None:
thresh =abs(DoG_img).max()* alpha
edge_image = zerosCrossing(src=DoG_img, thresh=thresh)
return edge_image
return edge_image
if __name__ =="__main__":
src = cv2.imread('enhance.jpg',1)
plt.subplot(2,2,1)
plt.imshow(src)
plt.axis('off')
plt.title('Offical')
edge_log = LoG(src=src, ksize=25, alpha=0.05)
plt.subplot(2,2,2)
plt.imshow(edge_log)
plt.axis('off')
plt.title('LoG')
edge_dog = DoG(src=src, ksize=25, sigma=4, alpha=0.1)
plt.subplot(2,2,3)
plt.imshow(edge_dog)
plt.axis('off')
plt.title('DoG')
plt.show()
结果展⽰:
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论