• 机器学习进阶-直方图与傅里叶变换-图像直方图 1.cv2.calc(生成图像的像素频数分布(直方图))


    1. cv2.calc([img], [0], mask, [256], [0, 256])  # 用于生成图像的频数直方图

    参数说明: [img]表示输入的图片, [0]表示第几个通道, mask表示掩码,通常生成一部分白色,一部分黑色的掩码图, [256]表示直方图的个数, [0, 256]表示数字的范围

    图像直方图表示的是颜色的像素值,在单个或者一个范围内出现的频数,一般图像会在某一个颜色区间内呈现较高的值

    一只小猫,即其(0-255)的像素点的直方图分布情况,我们可以看出其在100-200之间的像素分布较密集

    代码:

    1. 灰度图的颜色通道

    第一步:读取图片

    第二步:使用cv2.calhist([img], [0], None, [256], [0, 256]) 获得每个像素点的频数值

    第三步:使用plt.hist(img.ravel(), 256)做出直方图

    import cv2
    import numpy as np
    import matplotlib.pyplot as plt
    
    
    def cv_show(img, name):
        cv2.imshow(name, img)
        cv2.waitKey(0)
        cv2.destroyAllWindows()
    
    # 第一步读入图片
    img = cv2.imread('cat.jpg', 0)
    
    # 第二步:使用calchist计算每个像素点的频数
    hist = cv2.calcHist([img], [0], None, [256], [1, 256])
    
    # 第三步:进行画图操作
    plt.subplot(131)
    plt.imshow(img, cmap='gray')
    plt.subplot(132)
    plt.hist(img.ravel(), 256)
    plt.subplot(133)
    plt.plot(hist, color='red')
    plt.show()

    2.研究不同通道的颜色频度

    # 研究不同颜色像素分布情况
    img = cv2.imread('cat.jpg')
    
    color = ['b', 'g', 'r']
    for i, col in enumerate(color):
        histr = cv2.calcHist([img], [i], None, [256], [1, 256])
        plt.plot(histr, color=col, label=col)
        plt.legend()
    plt.show()

    3.使用掩码mask删选出部分图像,做像素频度分析

    第一步:读入图片

    第二步:使用np.zeros生成掩码mask

    第三步:使用cv2.bitwise将掩码与图像结合截取中间位置的图片

    第四步:使用cv2.calcHist生成统计像素点的频数图

    第五步:进行绘图操作

    # 第一步读入图片
    img = cv2.imread('cat.jpg', 0)
    
    # 第二步:生成掩码,中间部分为255,边缘部分都为0
    mask = np.zeros(img.shape[:2], np.uint8)
    mask[100:300, 100:400] = 255
    
    # 第三步:使用cv2.bitwise与操作,只保留图像的中间部分
    ret = cv2.bitwise_and(img, img, mask=mask) # 做与操作
    
    # 第四步:使用cv2.calcHist带入掩码生成频数曲线
    m_hist = cv2.calcHist([img], [0], mask, [256], [1, 256])
    
    # 第五步:进行最终的绘图操作
    plt.subplot(221)
    plt.imshow(img, 'gray')
    plt.subplot(222)
    plt.imshow(mask, 'gray')
    plt.subplot(223)
    plt.imshow(ret, 'gray')
    plt.subplot(224)
    plt.plot(m_hist)
    plt.plot(hist)
    plt.show()

  • 相关阅读:
    洛谷1069 细胞分裂
    洛谷1050 循环
    CF Good Bye 2018
    洛谷1043 数字游戏
    洛谷1041 传染病控制
    洛谷1040 加分二叉树
    洛谷1039 侦探推理
    洛谷1038 神经网络
    设计模式的区别
    volatile和synchronized与lock的理解
  • 原文地址:https://www.cnblogs.com/my-love-is-python/p/10405448.html
Copyright © 2020-2023  润新知