线性代数于工程应用中的实践:以代码实例拆解图像平滑问题的求解逻辑

图像平滑


目录

图像平滑

1.矩阵卷积

2.理解图像

3.图像平滑

4.应用实例


1.矩阵卷积

矩阵卷积是一种基本的图像处理技术,用于在图像上滑动一个卷积核,并通过对卷积核和图像上对应位置的元素进行逐元素相乘,然后求和得到一个新的像素值。矩阵卷积常用于图像处理,可以用于实现各种图像滤波操作,如边缘检测、模糊、锐化等。它也被广泛应用于深度学习中的卷积神经网络(Convolutional Neural Network, CNN),用于提取图像特征。
图一

矩阵卷积在深度学习:卷积神经网络CNN;

矩阵卷积的数学意义:先将卷积核顺时针旋转180°,然后再进行滑动加权求和;

2.理解图像

一张图片通常是由RGB三个颜色通道的灰度图叠加而成,每个灰度图都可以视为一个mxn的矩阵,其中m和n分别表示图像的高度和宽度。以一个大小为1024x512像素的图片为例,其每个灰度图矩阵都是一个1024行x512列的矩阵。矩阵中每个元素的数值范围在0到255之间,不同的值代表了该像素点的亮暗程度,最终通过叠加这三个灰度图的数值,形成一张完整的彩色图片。

3.图像平滑

图像平滑处理是通过对图片灰度图对应的矩阵进行卷积操作实现的。在卷积过程中,采用卷积核对图像矩阵进行处理,旨在使每个像素值与其周围像素值相似,以减轻图像中的明暗变化。参数如卷积核的尺寸、滑动步长以及周围范围等需要根据具体需求进行设计和调整。通过这种处理,可以实现图像的平滑效果,消除图像中的噪点和细节,使图像看起来更加柔和和模糊。在实际应用中,根据任务的不同,可以选择不同的卷积核和参数来实现不同的平滑效果。
图二

4.应用实例

**代码及运行结果**

python 复制代码
import numpy as np
from PIL import Image
from scipy import signal

#1.读取一张图片
picture_filename="pictures/people_picture.jpg"
picture_rgb=Image.open(picture_filename)
picture_rgb.show()

#2.将彩色图片转化为灰度图
picture_gray=picture_rgb.convert('L')
picture_gray.show()

#3.将灰度图转换为像素矩阵
matrix=np.asarray(picture_gray)
print("像素矩阵的行列:",matrix.shape)
#像素矩阵的行列: (420, 420)
print(matrix)
# [[75 75 75 ... 57 57 57]
#  [75 75 75 ... 57 57 57]
#  [75 75 75 ... 57 57 57]
#  ...
#  [20 26 27 ... 11  6  5]
#  [20 26 27 ... 11  6  5]
#  [20 26 27 ... 11  5  4]]

#4.定义卷积核(均值滤波器)
filter_5x5=np.array([[1/49,1/49,1/49,1/49,1/49],
                     [1/49,1/49,1/49,1/49,1/49],
                     [1/49,1/49,1/49,1/49,1/49],
                     [1/49,1/49,1/49,1/49,1/49],
                     [1/49,1/49,1/49,1/49,1/49]])

#sobel算子(检测图像边缘)
# sobel=np.array([[-1,-2,-1],
#                 [0,0,0],
#                 [1,2,1]])

#5.图像平滑(卷积)
result=signal.convolve2d(matrix,filter_5x5,mode='same')
#result1=signal.convolve2d(matrix,sobel,mode='same')
print("卷积后像素矩阵的行列:",result.shape)
#卷积后像素矩阵的行列: (420, 420)
print(np.around(result))
# [[14. 18. 23. ... 17. 14. 10.]
#  [18. 25. 31. ... 23. 19. 14.]
#  [23. 31. 38. ... 29. 23. 18.]
#  ...
#  [ 7. 10. 12. ...  3.  3.  2.]
#  [ 6.  8.  9. ...  2.  2.  2.]
#  [ 4.  6.  7. ...  2.  2.  1.]]

#6.把像素矩阵转换回图片
picture_result=Image.fromarray(result)
picture_result.show()
# picture_result1=Image.fromarray(result1)
# picture_result1.show()

图三


相关推荐
码界筑梦坊6 分钟前
基于Flask的历史空难数据可视化分析系统的设计与实现
python·信息可视化·flask·毕业设计
声网11 分钟前
a16z 最新 Voice AI 报告:语音将成为关键切入点,而非最终产品本身丨 Voice AI 学习笔记
人工智能·笔记·学习
萧鼎11 分钟前
使用Python的Tabulate库优雅地格式化表格数据
python
程序员小远18 分钟前
接口自动化测试框架(pytest+allure+aiohttp+ 用例自动生成)
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·pytest
钮钴禄·爱因斯晨43 分钟前
赛博算命之 ”梅花易数“ 的 “JAVA“ 实现 ——从玄学到科学的探索
java·开发语言·python
云边有个稻草人1 小时前
DeepSeek与人工智能的结合:探索搜索技术的未来
人工智能·笔记·科技·算法·deepseek
卜及中2 小时前
【Go语言快速上手】第二部分:Go语言进阶
开发语言·后端·golang
进阶的小叮当2 小时前
Vue+Node调用Python并将结果显示到Web页面中
vue.js·python·node.js
BuHuaX2 小时前
C#元组和Unity Vector3
开发语言·unity·c#·游戏引擎·全文检索
《雨声》2 小时前
第3章《VTK可视化基础》
开发语言·c++·qt·算法