Path: blob/master/modules/imgproc/test/test_connectedcomponents.cpp
16354 views
/*M///////////////////////////////////////////////////////////////////////////////////////1//2// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.3//4// By downloading, copying, installing or using the software you agree to this license.5// If you do not agree to this license, do not download, install,6// copy or use the software.7//8//9// License Agreement10// For Open Source Computer Vision Library11//12// Copyright (C) 2000-2008, Intel Corporation, all rights reserved.13// Copyright (C) 2009, Willow Garage Inc., all rights reserved.14// Third party copyrights are property of their respective owners.15//16// Redistribution and use in source and binary forms, with or without modification,17// are permitted provided that the following conditions are met:18//19// * Redistribution's of source code must retain the above copyright notice,20// this list of conditions and the following disclaimer.21//22// * Redistribution's in binary form must reproduce the above copyright notice,23// this list of conditions and the following disclaimer in the documentation24// and/or other materials provided with the distribution.25//26// * The name of the copyright holders may not be used to endorse or promote products27// derived from this software without specific prior written permission.28//29// This software is provided by the copyright holders and contributors "as is" and30// any express or implied warranties, including, but not limited to, the implied31// warranties of merchantability and fitness for a particular purpose are disclaimed.32// In no event shall the Intel Corporation or contributors be liable for any direct,33// indirect, incidental, special, exemplary, or consequential damages34// (including, but not limited to, procurement of substitute goods or services;35// loss of use, data, or profits; or business interruption) however caused36// and on any theory of liability, whether in contract, strict liability,37// or tort (including negligence or otherwise) arising in any way out of38// the use of this software, even if advised of the possibility of such damage.39//40//M*/4142#include "test_precomp.hpp"4344namespace opencv_test { namespace {4546class CV_ConnectedComponentsTest : public cvtest::BaseTest47{48public:49CV_ConnectedComponentsTest();50~CV_ConnectedComponentsTest();51protected:52void run(int);53};5455CV_ConnectedComponentsTest::CV_ConnectedComponentsTest() {}56CV_ConnectedComponentsTest::~CV_ConnectedComponentsTest() {}5758// This function force a row major order for the labels59void normalizeLabels(Mat1i& imgLabels, int iNumLabels) {60vector<int> vecNewLabels(iNumLabels + 1, 0);61int iMaxNewLabel = 0;6263for (int r = 0; r<imgLabels.rows; ++r) {64for (int c = 0; c<imgLabels.cols; ++c) {65int iCurLabel = imgLabels(r, c);66if (iCurLabel>0) {67if (vecNewLabels[iCurLabel] == 0) {68vecNewLabels[iCurLabel] = ++iMaxNewLabel;69}70imgLabels(r, c) = vecNewLabels[iCurLabel];71}72}73}74}757677void CV_ConnectedComponentsTest::run( int /* start_from */)78{7980int ccltype[] = { cv::CCL_WU, cv::CCL_DEFAULT, cv::CCL_GRANA };8182string exp_path = string(ts->get_data_path()) + "connectedcomponents/ccomp_exp.png";83Mat exp = imread(exp_path, 0);84Mat orig = imread(string(ts->get_data_path()) + "connectedcomponents/concentric_circles.png", 0);8586if (orig.empty())87{88ts->set_failed_test_info(cvtest::TS::FAIL_INVALID_TEST_DATA);89return;90}9192Mat bw = orig > 128;9394for (uint cclt = 0; cclt < sizeof(ccltype)/sizeof(int); ++cclt)95{9697Mat1i labelImage;98int nLabels = connectedComponents(bw, labelImage, 8, CV_32S, ccltype[cclt]);99100normalizeLabels(labelImage, nLabels);101102// Validate test results103for (int r = 0; r < labelImage.rows; ++r){104for (int c = 0; c < labelImage.cols; ++c){105int l = labelImage.at<int>(r, c);106bool pass = l >= 0 && l <= nLabels;107if (!pass){108ts->set_failed_test_info(cvtest::TS::FAIL_INVALID_OUTPUT);109return;110}111}112}113114if (exp.empty() || orig.size() != exp.size())115{116imwrite(exp_path, labelImage);117exp = labelImage;118}119120if (0 != cvtest::norm(labelImage > 0, exp > 0, NORM_INF))121{122ts->set_failed_test_info(cvtest::TS::FAIL_MISMATCH);123return;124}125if (nLabels != cvtest::norm(labelImage, NORM_INF) + 1)126{127ts->set_failed_test_info(cvtest::TS::FAIL_MISMATCH);128return;129}130131}132133ts->set_failed_test_info(cvtest::TS::OK);134}135136TEST(Imgproc_ConnectedComponents, regression) { CV_ConnectedComponentsTest test; test.safe_run(); }137138}} // namespace139140141