您当前的位置: 首页 >  搜索

qianbo_insist

暂无认证

  • 0浏览

    0关注

    399博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

搜索图片及相似度探秘 一

qianbo_insist 发布时间:2021-07-17 22:36:58 ,浏览量:0

均值和标准差

一副图片的均值和标准差是可以看出两幅图片的差异的,首先我们把两幅图片缩放到足够小的状态,例如8*8

cv::resize(image1, a1, cv::Size(8,8));

计算标准差

cv::meanStdDev(a1, mat_mean1, mat_stddev1);

opencv的函数非常方便,是一个强有力的工具,里面直接计算出了均值,而标准差放在了mat_stddev里面。

我们导入三张图片 三张图片 很明显,我们可以看出1和2 是有相似之处的,摄像头拍摄的远景图片基本都是房子和树木,草地,但图三是lena图,接下来我们计算他们的标准差。

Mat image1 = cv::imread(f1, IMREAD_GRAYSCALE);
   Mat image2 = cv::imread(f2, IMREAD_GRAYSCALE);
   Mat image3 = cv::imread("./lena.png", IMREAD_GRAYSCALE);
   imshow("1", image1);
   imshow("2", image2);
   imshow("3", image3);

   if (image1.empty() || image2.empty())
   {
   	return retString;
   }
   Mat a1, a2,a3;
   cv::resize(image1, a1, cv::Size(8,8));
   cv::resize(image2, a2, cv::Size(8,8));
   cv::resize(image3, a3, cv::Size(8,8));
   Mat mat_mean1, mat_mean2,mat_mean3, mat_stddev1, mat_stddev2, mat_stddev3;
   cv::meanStdDev(a1, mat_mean1, mat_stddev1);
   cv::meanStdDev(a2, mat_mean2, mat_stddev2);
   cv::meanStdDev(a3, mat_mean3, mat_stddev3);
   double m1,m2,m3, s1,s2,s3;
   m1 = mat_mean1.at(0, 0);
   s1 = mat_stddev1.at(0, 0);
   cout             
关注
打赏
1663161521
查看更多评论
0.0381s