知行编程网知行编程网  2023-01-14 04:30 知行编程网 隐藏边栏  14 
文章评分 0 次,平均分 0.0
导语: 本文主要介绍了关于python如何分析灰度的相关知识,包括opencv python 灰度,以及imagej灰度分析教程这些编程知识,希望对大家有参考作用。

python如何分析灰度

图像类型:通常我们的数字图像是彩色3通道RGB图像,R代表红色,G代表绿色,B代表蓝色。

存储方式:通常为uint8无符号整数,0~255,当然还有24bits可以表示更多的颜色,虽然这样可以提高图像对真实世界的还原度,但是会增加更多的开销,所以我们通常还是使用8位

灰度图像:灰度图像在图像处理中起着非常重要的作用。一些常用的操作涉及灰度图像的转换。在这些操作之前,比如边缘检测和二值化,通常都是RGB to Gray。


直接给出公式:Gray = 0.2989*R+0.5870*G+0.1140*B

#Python Opencv
#导入头文件
%matplotlib inline
import matplotlib.pyplot as plt 
import cv2
import numpy as np
 
#读取图像,opencv读取图像通道顺序为BGR
img=cv2.imread('img.path.jpg')
 
#显示图像,其中.astype(np.uint8)为了确保数据格式以免无法显示,plt显示图像需要为RGB顺序
plt.figure(figsize=(15,10))
plt.imshow(cv2.cvtColor(img.astype(np.uint8), cv2.COLOR_BGR2RGB))
plt.show()

python如何分析灰度

img=0.2989*img[:,:,2]+0.5870*img[:,:,1]+0.1140*img[:,:,0]
######
plt.figure(figsize=(15,10))
plt.imshow(img, cmap ='gray')
plt.show()

python如何分析灰度

#opencv 自带函数进行转化
plt.figure(figsize=(15,10))
plt.imshow(cv2.cvtColor(img.astype(np.uint8), cv2.COLOR_BGR2GRAY),cmap='gray')
plt.show()

python如何分析灰度

img3=0.2989*img[:,:,2]+0.5870*img[:,:,1]+0.1140*img[:,:,0]
img2=cv2.cvtColor(img.astype(np.uint8), cv2.COLOR_BGR2GRAY)
print((img3-img2).sum()/(img.shape[0]*img.shape[1]))  ###结果=-0.0072855376781315

对比一下,使用公式得到的灰度图和opencv自带函数的灰度图其实是有区别的,应该是计算精度的区别。

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写
扫一扫二维码分享