时间:2021-05-22
问题:
我正尝试使用matplotlib读取RGB图像并将其转换为灰度。
在matlab中,我使用这个:
img = rgb2gray(imread('image.png'));在matplotlib tutorial中他们没有覆盖它。他们只是在图像中阅读
然后他们切片数组,但是这不是从我所了解的将RGB转换为灰度。
lum_img = img[:,:,0]编辑:
我发现很难相信numpy或matplotlib没有内置函数来从rgb转换为灰色。这不是图像处理中的常见操作吗?
我写了一个非常简单的函数,它可以在5分钟内使用imread导入的图像。这是非常低效的,但这就是为什么我希望内置专业实施。
塞巴斯蒂安改善了我的功能,但我仍然希望找到内置的一个。
matlab的(NTSC / PAL)实现:
回答:
如何使用PIL
from PIL import Imageimg = Image.open('image.png').convert('LA')img.save('greyscale.png')使用matplotlib和the formula
Y' = 0.299 R + 0.587 G + 0.114 B你可以这样做:
import numpy as npimport matplotlib.pyplot as pltimport matplotlib.image as mpimg def rgb2gray(rgb): return np.dot(rgb[...,:3], [0.299, 0.587, 0.114]) img = mpimg.imread('image.png') gray = rgb2gray(img) plt.imshow(gray, cmap = plt.get_cmap('gray'))plt.show()以上这篇Python 将RGB图像转换为Pytho灰度图像的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
算法流程:将图像转换为灰度图像利用Sobel滤波器求出海森矩阵(Hessianmatrix):将高斯滤波器分别作用于Ix²、Iy²、IxIy
本文实例讲述了Python图像处理实现两幅图像合成一幅图像的方法。分享给大家供大家参考,具体如下:将两幅图像合成一幅图像,是图像处理中常用的一种操作,pytho
RGB是如何转换为灰度的?这是让人困惑已久的一道难题。1、RGB复合通道转灰度:转换后的色阶值只与RGB空间有关,而与作为目的地的灰度空间无关。也就是说,只要当
本文实例为大家分享了Opencv实现图像灰度线性变换的具体代码,供大家参考,具体内容如下通过图像灰度线性变换提高图像对比度和亮度,原图像为src,目标图像为ds
本文实例讲述了C#图像灰度级拉伸的方法。分享给大家供大家参考。具体如下://定义图像灰度拉伸函数privatestaticBitmapGrayLP(Bitmap