cv2.mean() 用于计算图像的像素值的平均值

函数cv::mean(&cv::Mat)用于计算Mat(图像像素)的平均值,可以用于单通道图像、多通道图像(如彩色图像)、带掩码的图像等。

函数定义 :

Scalar cv::mean(InputArray src, InputArray mask = noArray());

src: 输入图像或矩阵,类型可以是多通道或单通道图像。

mask: (可选)掩码图像,它是一个8位单通道的二值图像。如果提供掩码,则只对掩码中非零的像素区域计算平均值。如果不提供掩码,函数将对整个图像计算。

返回值: 返回一个 cv::Scalar 类型的对象,其包含图像的平均值。

1)单通道图像,cv::Scalar 前3个元素相等,表示图像灰度的平均值,第4个为0。

2)3通道图像,cv::Scalar 4个元素,分别为蓝色B、绿色G、红色R通道的均值,第4个为0(Alpha或者填充0)。

3)4通道图像(BGRA),cv::Scalar 4个元素,分别为蓝色B、绿色G、红色R通道的均值,Alpha通道的均值。

例如:

对于灰度图像(单通道),返回的 cv::Scalar 是一个包含单个元素的标量,表示图像的灰度平均值。

对于 RGB 图像(3 通道),返回的 cv::Scalar 是一个包含三个元素的标量,分别表示 B、G、R 通道的平均值。

1.Python实例:

1)计算灰度图像的每个通道的平均值

python 复制代码
import cv2 

# 读取图像:image.jpg为灰度图像,或者彩色转为灰度图像
image = cv2.imread('image.jpg')

# 计算整个图像的平均值、标准差、最小值和最大值
mean_val = cv2.mean(image)
print("平均值:", mean_val[0])  # 对于灰度图,直接使用 mean_val[0]
print("标准差:", mean_val[1])  # 对于灰度图,直接使用 mean_val[1]
print("最小值:", mean_val[2])  # 对于灰度图,直接使用 mean_val[2]
print("最大值:", mean_val[3])  # 对于灰度图,直接使用 mean_val[3]

2)计算彩色图像的每个通道的平均值

python 复制代码
import cv2

# 读取图像
image = cv2.imread('path_to_image.jpg')

# 分离颜色通道
b, g, r = cv2.split(image)

# 计算每个通道的均值
mean_b = cv2.mean(b)[0]
mean_g = cv2.mean(g)[0]
mean_r = cv2.mean(r)[0]

print(f'Blue mean: {mean_b}')
print(f'Green mean: {mean_g}')
print(f'Red mean: {mean_r}')

2.C++实例:

1)计算灰度图像的每个通道的平均值

cpp 复制代码
// 方法1:
//cv::Mat gray = cv::imread("img.jpg", cv::IMREAD_GRAYSCALE);

// 方法1:
cv::Mat gray;
cv::Mat image = cv::imread("img.jpg" );
cout << "输入图像大小image.size: " << image.size() << std::endl;
cout << "输入图像通道image.channels = " << image.channels() << endl;
if (image.channels() > 1)               // 通道 > 1 ,则需要转为灰度图像; = 1表示是灰度图像,不需要转换 。
{
	cvtColor(image, gray, COLOR_RGB2GRAY); 
}
cout << "灰度图像通道gray.channels = " << gray.channels() << endl;

cv::Scalar meanVal = cv::mean(gray);
std::cout << "图像平均灰度值Average intensity: " << meanVal[0] << std::endl;
// 计算整个图像的平均值、标准差、最小值和最大值
cout << "meanVal: " << meanVal<< std::endl;

2)计算彩色图像的每个通道的平均值

cpp 复制代码
cv::Mat img = cv::imread("image.jpg");
cv::Scalar meanVal = cv::mean(img);
std::cout << "B: " << meanVal[0] << " G: " << meanVal[1] << " R: " << meanVal[2] << std::endl;

彩色图像,meanVal[0] 是蓝色通道的平均值,meanVal[1] 是绿色通道的平均值,meanVal[2] 是红色通道的平均值。
相关推荐
薛定猫AI14 小时前
【深度解析】从 Mythos 安全风波看下一代大模型漏洞挖掘能力与工程实践
人工智能·安全
zhangshuang-peta14 小时前
MCP 与 Prompt Engineering:协议出现后,Prompt 还重要吗?
人工智能·prompt·ai agent·mcp·peta
码农BookSea14 小时前
RAG详解:让大模型看见你的私有知识
人工智能·后端
英伦传奇14 小时前
万字干货:理解 Harness Engineering,看这一篇就够了
人工智能
rainbow72424414 小时前
零库存管理实操:传统仓管到AI供应链规划师的自动化补货与路径优化SOP
运维·人工智能·自动化
我叫张土豆14 小时前
Spring AI 集成 MCP 服务踩坑实录:SSE 与 Streamable HTTP 协议的兼容性深度剖析
人工智能·spring·http
深度学习lover14 小时前
<数据集>yolo扑克牌识别<目标检测>
人工智能·python·yolo·目标检测·计算机视觉·扑克牌识别
ovensi14 小时前
肝了一个插件!Claude Code 实时显示 MiniMax Token 用量,告别「额度何时跑完」的焦虑
人工智能
Coovally AI模型快速验证14 小时前
无人机拍矿区→AI找裂缝→几何量化:DRA-UNet采矿地裂缝检测与形态分析全流程
人工智能·无人机·裂缝检测·智慧矿区
迷藏49414 小时前
**发散创新:基于 Rust的模型保护机制设计与实践**在人工智能快速发
java·人工智能·python·rust·neo4j