看到微信的红包照片之后,就想了解下高斯模糊。最近实习学了Python操作OpenCV,没有好好玩过,今天恰好有空,就试了用Python+OpenCV实现图像高斯模糊。 1. 环境使用Ubuntu 14.04和Python 2.7.6,OpenCV需要安装,使用: apt-get install python-opencv 在python中import cv2,没有报错信息则安装成功。 2. 高斯模糊高斯模糊本质上是低通滤波器,输出图像的每个像素点是原图像上对应像素点与周围像素点的加权和,原理并不复杂。做久了卷积神经网络看这个分外亲切,就是用高斯分布权值矩阵与原始图像矩阵做卷积运算而已。摘录wiki上两段原文:
至于高斯分布权重矩阵,就是对二维正态分布的密度函数(也就是高斯函数)采样再做归一化的产物。
需要对高斯模糊算法的详细解释,可以参考: 使用cv2做高斯模糊,只要一行代码调用GaussianBlur函数,给出高斯矩阵的尺寸和标准差就可以: blur = cv2.GaussianBlur(img,(5,5),0) 这里(5, 5)表示高斯矩阵的长与宽都是5,标准差取0时OpenCV会根据高斯矩阵的尺寸自己计算。概括地讲,高斯矩阵的尺寸越大,标准差越大,处理过的图像模糊程度越大。 3. 实验代码直接看代码: #!/usr/bin/env python import cv2 imgName = "1.jpg"; kernel_size = (5, 5); sigma = 1.5; img = cv2.imread(imgName); img = cv2.GaussianBlur(img, kernel_size, sigma); new_imgName = "New_" + str(kernel_size[0]) + "_" + str(sigma) + "_" + imgName; cv2.imwrite(new_imgName, img); 内容非常简单,通过imread读入图片,用kernel_size和sigma定义的高斯矩阵模糊图片,用imwrite保存为一张新图片。 这里使用一只欠雷做实验,原图:
原始图片
经过不同高斯矩阵模糊后的图像:
kernel_size=(5,5), sigma=0.5
kernel_size=(5,5), sigma = 1.5
kernel_size=(9,9), sigma = 1.5
可以看出,趋势的确是高斯矩阵尺寸和标准差越大,处理后的图片越模糊。最后,让我们糊个痛快:
给红包看原图 :)
好了,受不了这么魔性的欠雷,老老实实滚去做毕设了。 (责任编辑:最模板) |