educoder之Python数值计算库Numpy图像处理详解
作者:实力 发布时间:2023-12-06 03:49:32
标签:Python,数值计算,库,Numpy,图像处理
NumPy Python数值计算重要库
在图像处理领域,NumPy可以帮助我们高效地对图像进行处理。通过使用NumPy中的数组操作,我们可以快速地完成各种基本的图像处理任务,例如图像的裁剪、缩放、翻转、色彩模式转换等
读取和显示图像
首先,在处理图像之前,我们需要将图像加载到Python程序中。在Python中,可以使用PIL(Python Imaging Library)或OpenCV等库来读取图像。下面是使用PIL库读取一张图片并在窗口中显示的示例代码:
from PIL import Image
import numpy as np
import matplotlib.pyplot as plt
# 读入图片
img = Image.open('test.jpg')
# 显示图片
plt.imshow(np.asarray(img))
plt.show()
图像的大小调整
接下来,我们看一下如何通过NumPy来调整图像的大小。有时候,我们需要将一个大尺寸的图像缩放成小尺寸的图像。在这里,我们将使用ndarray对象的resize()方法以及scipy.interpolate中的interpolate()方法实现图像的缩放。
from scipy import interpolate
# 将图像放大两倍
scale_factor = 2
image_arr = np.array(img)
width, height = image_arr.shape[:2]
new_width, new_height = int(scale_factor * width), int(scale_factor * height)
# 采用scipy.interpolate的interpolate()方法实现缩放
a, b = np.linspace(0, width, width), np.linspace(0, height, height)
x, y = np.meshgrid(a,b)
f = interpolate.interp2d(x, y, image_arr, kind='cubic')
new_x, new_y = np.linspace(0, width, new_width), np.linspace(0, height, new_height)
new_image_arr = f(new_x, new_y)
# 重新转为图像格式,显示出来观察。
new_image = Image.fromarray(np.uint8(new_image_arr))
plt.imshow(np.asarray(new_image))
plt.show()
图像的翻转
在有些场景下,我们需要将图像水平或垂直翻转。NumPy中提供了flip()方法来实现图像的翻转操作。
# 将图像水平翻转
img_flip_horizontal = np.fliplr(image_arr)
# 将图像垂直翻转
img_flip_vertical = np.flipud(image_arr)
图像缩放和裁剪
调整图像大小是常见的图像处理任务,除此之外,您还可能需要对图像进行裁剪或者缩放的同时进行裁剪。在这里,我们使用与之前一样的方法,即resize()实现图像缩放,并且结合crop()方法对图片进行裁剪。
# 图像缩放并裁剪
scale_factor = 2
crop_area = (50, 100, 250, 350)
image_arr = np.array(img)
width, height = image_arr.shape[1], image_arr.shape[0]
new_width, new_height = int(scale_factor * width), int(scale_factor * height)
new_image_arr = np.asarray(Image.fromarray(image_arr).resize((new_width, new_height)))
# 裁剪图像
left, upper, right, lower = crop_area
cropped_image_arr = new_image_arr[upper:lower, left:right]
# 显示处理过的图片
plt.imshow(np.asarray(Image.fromarray(cropped_image_arr)))
颜色通道处理
在一些情况下,我们需要进行图像颜色通道处理。例如,我们可能需要将图像转换为灰度图像或对三个颜色通道分别进行操作,这可以用于实现许多视觉处理等算法中。
# 灰度化
gray_image_arr = np.dot(image_arr, [0.2989, 0.5870, 0.1140])
gray_image = Image.fromarray(np.uint8(gray_image_arr))
plt.imshow(np.asarray(gray_image))
# 颜色通道处理
red_channel_arr = np.zeros_like(image_arr)
red_channel_arr[:, :, 0] = image_arr[:, :, 0]
red_channel_image = Image.fromarray(np.uint8(red_channel_arr))
plt.imshow(np.asarray(red_channel_image))
green_channel_arr = np.zeros_like(image_arr)
green_channel_arr[:, :, 1] = image_arr[:, :, 1]
green_channel_image = Image.fromarray(np.uint8(green_channel_arr))
plt.imshow(np.asarray(green_channel_image))
blue_channel_arr = np.zeros_like(image_arr)
blue_channel_arr[:, :, 2] = image_arr[:, :, 2]
blue_channel_image = Image.fromarray(np.uint8(blue_channel_arr))
plt.imshow(np.asarray(blue_channel_image))
图像滤波
图像滤波是另一个有用的图像处理任务。NumPy中提供了多种图像滤波的方法,其中之一是卷积操作。下面的代码演示如何使用3x3卷积核进行图像平滑化。
# 图像平滑化
kernel = np.ones((3, 3), np.float32) / 9
smooth_image_arr = cv2.filter2D(image_arr, -1, kernel)
# 显示滤波过后的图片
plt.imshow(smooth_image_arr)
来源:https://juejin.cn/post/7223680663618699319


猜你喜欢
- 简单的解析例子:首先还是从官方文档中的例子:package mainimport (?? ?"fmt"?? ?"
- 一、在for循环中直接更改列表中元素的值不会起作用:如:l = list(range(10)[::2]) print (l)for n in
- 就像这个图的样子:解决方法,setting.py中DEBUG选项为True,否则无法映射到静态文件目录来源:https://blog.csd
- SELECT SUBSTR (T.RPT_ID, &nb
- 触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程。触发器主要是通过事件进行触发被自动调用执行的。而存储过程可以通过存储过程的
- 大家好,我叫斑马纹列表中使用两种相同的样式但颜色不同的背景,来间隔显示的内容。当然这个释义我是借鉴《designing interfaces
- 导言:到目前为止,我们的教程围绕的是text数据。然而,很多应用程序既需要处理text数据,也需要处理二进制数据。比如招聘网站可能需要用户上
- php多进程实现PHP有一组进程控制函数(编译时需要–enable-pcntl与posix扩展),使得php能在nginx系统中实现跟c一样
- 本文实例为大家分享了tensorflow实现线性回归的具体代码,供大家参考,具体内容如下一、随机生成1000个点,分布在y=0.1x+0.3
- ERRNO: 256 TEXT: SQLSTATE[HY000]: General error: 1436 Thread stac
- 导语新的一年迎来了元宵节,元宵佳节在陪伴家人的同时,自然也少不了赏花灯,猜灯谜的项目。当然,受到疫情的影响,许多地方今年无法出门赏花灯,猜灯
- 许多网页开发者想从ASP.NET 页面传递一个值到另一个页面(比如从一个框架frame页面到一个弹窗页面)。看了代码就明白了。呵呵。(一)向
- T-SQL 标识符在T-SQL语言中,对SQLServer数据库及其数据对象(比如表、索引、视图、存储过程、触发器等)需要以名称来进行命名并
- function toBreakWord(intLen, id){ var obj=document.getElementById(id);
- 把昨天做的高级查询界面完善了一下,支持动态添加多个查询条件、定义逻辑关系,支持整形、浮点、字符串、日期、布尔值、自定义选择列表的录入,通过E
- 前言在设计爬虫项目的时候,首先要在脑内明确人工浏览页面获得图片时的步骤一般地,我们去网上批量打开壁纸的时候一般操作如下:1、打开壁纸网页2、
- 最近去公司,连续几天被保安查健康码,觉得他们效率有点慢,排了长队,回到家就来兴致,写了个简易的健康码识别系统(主要是针对上海的健康码 随申码
- 本文实例讲述了Python实现动态给类和对象添加属性和方法操作。分享给大家供大家参考,具体如下:动态给类和对象添加属性定义一个Person类
- 本文实例讲述了jQuery实现弹出带遮罩层的居中浮动窗口效果。分享给大家供大家参考,具体如下:<!doctype html>&l
- 本文实例讲述了PHP商品秒杀问题解决方案。分享给大家供大家参考,具体如下:引言假设num是存储在数据库中的字段,保存了被秒杀产品的剩余数量。