【计算机视觉】- 如何计算灰度图像 【python 灰度图像】

news/2024/11/30 10:48:28/

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

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

灰度图像:灰度图像在图像处理种有着非常重要的地位,一些常用的操作都会涉及到灰度图像的转换,边缘检测、二值化等这些操作之前通常都是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()

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()

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

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自己函数的灰度图,其实还是不一样的,应该是计算精度上的差距

 


http://www.ppmy.cn/news/264165.html

相关文章

uploads靶场通关(1-11关)

Pass-01(JS校验) 看题目我们准备好我们的php脚本文件,命名为1.php 上传该php文件,发现上传失败 方法一:将浏览器的JavaScript禁用 然后就能上传了 方法二: 查看源码,发现只能上传以下形式的文…

彩色空间转换实验

彩色空间转换(RGB与YUV) 1.彩色空间转换的基本思想及转换公式 由电视原理可知,亮度和色差信号的构成如下: Y=0.2990R0.5870G0.1140B R-Y=0.7010R-0.5870G-0.1140B B-Y=-0.2990R…

MATLAB图像处理

1. rgb2gray rgb2gray 通过计算 R、G 和 B 分量的加权和,将 RGB 值转换为灰度值: 0.2989 * R 0.5870 * G 0.1140 * B 这些权重与 rgb2ntsc 函数用于计算 Y 分量的权重相同。 在舍入到小数点后 3 位之后,rgb2gray 中用来计算灰度值的系数与…

【JZOJ5870】【NOIP2018模拟9.15】地图 (递推+DP+组合数学)

Problem Hint Solution 首先,图中只会存在链和环。记图中有one个度数为1的点,two个度数为2的点。囿于每条链有两个度数为1的点(链的两端),链的数量是确定的: o n e 2 \frac{one}2 2one​。这时&#xff0c…

Smooth Visualization(UVALive 5870)

题意: 给一个长度不超过100的整数字符串,给每一列输出‘*’和‘’,并且两列加号数量的差要小于等于1(*在列的上面)。也就在两个字符间加一些数字,让两个字符呈升序或降序,然后用‘* 和‘’表示出来(如果两个字符相同或…

【瑞格】c语言文件操作实例( 【5870】 内容的加密以及文件写入、读取)

输入文件内容&#xff1a; Hello my Dear: This is a secret, so don’t tell anyone else! Mr. Right is LiXiaoMing. ac代码&#xff1a; #include <stdio.h> #include <stdlib.h> #include <string.h>int main() {FILE *fp,*fq;char s[150];int i;if((fp…

JZOJ5870 【NOIP2018模拟9.15】地图

题目描述 Description Input Output Sample Input 4 2 1 1 2 Sample Output 2 Data Constraint 题目大意 一个无向图&#xff0c;给你 N N N个点的度数&#xff0c;每个点的度数只有 1 1 1或 2 2 2&#xff0c;问组成这个图的方案数。 解法 思考历程 非常不爽的是&#xff…

UVALive 5870 - Smooth Visualization

题目大意&#xff1a;任何一个1~7的数由竖着一列字符表示&#xff0c;从下到上数是几就有几个‘’&#xff0c;空余地方是‘*’&#xff0c;现在给定一行数&#xff0c;将这行数用一个矩阵表示出来&#xff0c;要求&#xff0c;相邻两列之间‘’个数不能相差超过1&#xff0c;超…