绘制彩色图的颜色直方图

计数直方图

Opencv中已经集成了关于彩色图像直方图计算的函数,形式如下:

import cv2

cv2.calcHist(images, channels, mask, histSize, ranges[, hist[, accumulate]])

参数

  • imagesarray-like类型,要计算的图像(单张或多张);
  • channels:要计算的通道索引;
  • mask:图像掩膜;
  • histSize:直方图的柱子数量,即将数据分布在多少个区间上计数;
  • ranges:为直方图取值范围;
  • hist:为返回值,不用填;
  • accumulate:多张图的时候是否叠加。

实例

import cv2
import numpy as np
import matplotlib.pyplot as plt

img = cv2.imread('D:\\DataSet\\images\\test\\lena.jpg')

color = ('b','g','r')  #稍微调整显示颜色,提高可视化效果
for id,bgrcolor in enumerate(color):
    hist = cv2.calcHist([img],[id], None, [256], [0.0,255.0])   #彩色图有三个通道,通道索引依次是b:0,g:1,r:2
    plt.plot(hist, color=bgrcolor)
    plt.title('Histrogram of Color image')
plt.show()

在这里插入图片描述

概率密度直方图

示例1

import cv2
import numpy as np
import matplotlib.pyplot as plt

img = cv2.imread('D:\\DataSet\\images\\test\\lena.jpg')

color = ('b','g','r')  #稍微调整显示颜色,提高可视化效果
for id,bgrcolor in enumerate(color):
    plt.hist(img[:,:,id].flatten(),bins=256, density=True,color=bgrcolor,alpha=.7)   
    plt.title('Histrogram of Color image')

plt.show()

在这里插入图片描述

示例2

import cv2
import numpy as np
import seaborn as sns
import matplotlib.pyplot as plt

img = cv2.imread('D:\\DataSet\\images\\test\\lena.jpg')

color = ('b','g','r')  #稍微调整显示颜色,提高可视化效果
for id,bgrcolor in enumerate(color):
    sns.kdeplot(img[:,:,id].flatten(), shade=True, color=bgrcolor, label=bgrcolor, alpha=.7)
    plt.title('Histrogram of Color image')

plt.show()

在这里插入图片描述

  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
OpenCV提供了一个函数cv::calcHist()来计算像的直方图,在绘制之前需要将像转换为灰度像。下面是一个简单的示例代码,用于绘制灰度像的直方图: ```cpp #include <opencv2/opencv.hpp> #include <iostream> using namespace cv; using namespace std; int main() { // 读取像 Mat image = imread("example.jpg", IMREAD_GRAYSCALE); // 定义直方图参数 int histSize = 256; // 直方图中条目的数量 float range[] = { 0, 256 }; // 像素值范围 const float* histRange = { range }; bool uniform = true, accumulate = false; // 计算直方图 Mat hist; calcHist(&image, 1, 0, Mat(), hist, 1, &histSize, &histRange, uniform, accumulate); // 绘制直方图 int hist_w = 512, hist_h = 400; int bin_w = cvRound((double)hist_w / histSize); Mat histImage(hist_h, hist_w, CV_8UC1, Scalar(0)); normalize(hist, hist, 0, histImage.rows, NORM_MINMAX, -1, Mat()); for (int i = 1; i < histSize; i++) { line(histImage, Point((i - 1) * bin_w, hist_h - cvRound(hist.at<float>(i - 1))), Point((i)*bin_w, hist_h - cvRound(hist.at<float>(i))), Scalar(255), 2, LINE_AA); } // 显示绘制直方图 namedWindow("Histogram", WINDOW_AUTOSIZE); imshow("Histogram", histImage); waitKey(0); return 0; } ``` 在这个示例中,我们使用cv::calcHist()函数计算像的直方图,然后使用cv::normalize()函数将直方图归一化,使其适合于像显示。最后,我们使用cv::line()函数在一个新的Mat对象上绘制直方图,并使用cv::imshow()函数显示它。 需要注意的是,这个示例只绘制了灰度像的直方图,如果需要绘制彩色像的直方图,则需要将彩色像转换为HSV颜色空间,然后计算每个通道的直方图,并将它们组合成一个三维直方图
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

great-wind

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值