python一维数据高斯滤波,利用Python语言进行简单的数字图像处理(直方图、均衡化、高斯滤波)...

本文介绍了如何使用Python进行简单的数字图像处理,包括绘制直方图、直方图均衡化和高斯滤波。通过PIL库和scipy.ndimage模块,实现了对灰度图像的处理,增强了图像的对比度并进行了高斯模糊,展示了不同标准差下的模糊效果。
摘要由CSDN通过智能技术生成

利用Python语言进行简单的数字图像处理(直方图、均衡化、高斯滤波)

一、 利用Python语言绘制直方图

图像直方图为反映一幅图像中各灰度级与各灰度级像素出现的频率之间的关系图。

PIL (Python Imaging Library)图像库提供了很多常用的图像处理及很多有用的图像基本操作。PIL库下载地址链接: link.

实现

原图片

b9d0a80c8c50b48e8d14b613a8b07f38.png

(课本代码)

from PCV.tools import imtools

from PIL import Image

# 添加中文字体支持

from matplotlib.font_manager import FontProperties

from pylab import *

from scipy.ndimage import filters

font = FontProperties(fname=r"c:\windows\fonts\SimSun.ttc", size=14)

im = array(Image.open('flower.jpg').convert('L')) # 打开图像,并转成灰度图像

#im = array(Image.open('../data/AquaTermi_lowcontrast.JPG').convert('L'))

im2, cdf = imtools.histeq(im)

figure()

subplot(3, 3, 1)

axis('off')

gray()

title(u'原始图像', fontproperties=font)

imshow(im)

subplot(3, 3, 4)

axis('off')

title(u'原始直方图', fontproperties=font)

#hist(im.flatten(), 128, cumulative=True, normed=True)

hist(im.flatten(), 128, density=True)1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

结果

04f189ced7f621923f13252eaa63cca9.png

二、直方图均衡化

基本原理

直方图均衡化,是通过使用累积函数对灰度值进行“调整”以实现对比度的增强。直方图均衡化处理的“中心思想”是把原始图像的灰度直方图从比较集中的某个灰度区间变成在全部灰度范围内的均匀分布。直方图均衡化就是对图像进行非线性拉伸,重新分配图像像素值,使一定灰度范围内的像素数量大致相同

实现

(课本代码)

subplot(3, 3, 2)

axis('off')

title(u'直方图均衡化后的图像', fontproperties=font)

imshow(im2)

subplot(3, 3, 5)

axis('off')

title(u'均衡化后的直方图', fontproperties=font)

#hist(im2.flatten(), 128, cumulative=True, normed=True)

hist(im2.flatten(), 128, density=True)1

2

3

4

5

6

7

8

9

10

结果

d38c44b38da9ddfe7519089f6b0266e3.png

三、高斯滤波器进行高斯模糊

基本原理

在网上有搜索相关原理,链接: link.这个博主说的感觉挺容易理解的。

一个经典的并且十分有用的图像卷积例子是对图像进行高斯模糊。高斯模糊可以用于定义图像尺度、计算兴趣点以及很多其他的应用场合。

实现

课本代码(根据不同的标准差对图像进行模糊处理)

for bi, blur in enumerate([2, 5, 10]):

im2 = filters.gaussian_filter(im, blur)

im2 = np.uint8(im2)

imNum=str(blur)

subplot(3, 3, 7 + bi)

axis('off')

title(u'标准差为'+imNum, fontproperties=font)

imshow(im2)1

2

3

4

5

6

7

8

9

结果

3c67945efd1ebf2c9fa7c7c832285b5f.png

总结

本次使用的图片为灰度图像,只是进行的操作较为简单的图像处理,主要是开始接触python语言,安装使用pycharm、调用一些库函数以及与计算机视觉相结合的操作和方法。

文章来源: blog.csdn.net,作者:小饼干cookie,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/qq_44818951/article/details/114538510

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值