25.直方图比较

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

#include <opencv4/opencv2/opencv.hpp>
#include <iostream>
#include <math.h>

std::string convertToString(double d);


int main(int argc, char** argv){
    cv::Mat src1 = cv::imread("../../source/lena.png");
    cv::Mat src2 = cv::imread("../../source/matlab.jpeg");
    if(src1.empty() && src2.empty()){
        std::cout << "could not load image ...." << std::endl;
        return -1;
    }

    cv::cvtColor(src1, src1, cv::COLOR_BGR2HSV);
    cv::cvtColor(src2, src2, cv::COLOR_BGR2HSV);

    int h_bins = 50;
    int s_bins = 60;
    int histSize[] = {h_bins, s_bins};
    // hue varies from 0 to 179, saturation from 0 to 255
    float h_ranges[] = {0, 180};
    float s_ranges[] = {0, 256};
    const float* ranges[] = {h_ranges, s_ranges};
    // Use the o-th and 1-st channels
    int channels[] = {0, 1};
    cv::MatND hist_src1, hist_src2;

    cv::calcHist(&src1, 1, channels, cv::Mat(), hist_src1, 2, histSize, ranges, true, false);
    cv::normalize(hist_src1, hist_src1, 0, 1, cv::NORM_MINMAX);
    cv::calcHist(&src2, 1, channels, cv::Mat(), hist_src2, 2, histSize, ranges, true, false);
    cv::normalize(hist_src2, hist_src2, 0, 1, cv::NORM_MINMAX);

    double base = cv::compareHist(hist_src1, hist_src1, cv::HISTCMP_CORREL);
    double base1 = cv::compareHist(hist_src1, hist_src2, cv::HISTCMP_CORREL);

    cv::putText(src1, convertToString(base), cv::Point(30, 30), cv::FONT_HERSHEY_COMPLEX, 1, cv::Scalar(0, 255, 255));
    cv::putText(src2, convertToString(base1), cv::Point(30, 30), cv::FONT_HERSHEY_COMPLEX, 1, cv::Scalar(0, 255, 255));

    cv::imshow("src1", src1);
    cv::imshow("src2", src2);
    cv::waitKey();
}


std::string convertToString(double d){
    std::ostringstream os;
    if(os << d){
        return os.str();
    }
    return "invalid conversion";
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值