【问题标题】:compare the block Integral [closed]比较块积分[关闭]
【发布时间】:2012-05-21 20:35:14
【问题描述】:

我想将两个图像分成相等数量的块,然后将每个块的像素值求和以与相应的块总和进行比较。 我用了这段代码,我想知道如何比较每个块的积分:

//Divide the image
Mat divide (Mat input)
 {
   Mat block;
int numberblocks=10; 
int bh;
int bw;
bh=input.cols/numberblocks;
bw=input.rows/numberblocks; 
double blockarea=bh*bw;
double num=0;
Mat sum = cvCreateMat(input.cols + 1, input.rows + 1, CV_32SC1);
Mat sqsum = cvCreateMat(input.cols + 1, input.rows + 1, CV_64FC1);

for (int r = 0; r < input.rows; r += bw)
{
for (int c = 0; c < input.cols; c += bh)
block = input(cv::Range(r, min(r + bw, input.rows)),cv::Range(c, min(c + bh, input.cols)));


integral(input, sum, sqsum);

//double mean=(cv::sum(block).val[0])/255;
//double whiteratio=mean/blockarea;
num++;
}
return sqsum;
}




int main(int argc, char ** argv)
{

Mat I = imread("01.png", CV_LOAD_IMAGE_GRAYSCALE);


Mat Idivided= divide (I);

imshow("name1", Idivided);

waitKey(0);
return 0;
}

【问题讨论】:

  • 我想如何获取每个块的积分以将其与第二张图像中另一个块的另一个积分进行比较......我只是不知道如何编码

标签: c++ image-processing opencv pattern-matching augmented-reality


【解决方案1】:

假设您的图像分为mXn 块,因此您有mXn 整数值(即块的总和为整数)然后 Img1, Img2,具有mXn 大小。

IplImage *Img1 , IplImage *Img2
    for(i = 0; i<=m; i++)
      for(j = 0; j<=n; j++)
       { 
          if((int)cvGetReal2D(Img1, i, j) == (int)cvGetReal2D(Img2, i, j));// get the block value and compare it.
          //write u r logic here.
       }

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-08-02
    • 2011-07-03
    • 2021-06-07
    • 2019-09-27
    • 2011-06-15
    • 1970-01-01
    相关资源
    最近更新 更多