@ -43,167 +43,164 @@
namespace opencv_test { namespace {
namespace opencv_test { namespace {
class CV_TemplMatchTest : public cvtest : : ArrayTest
TEST ( Imgproc_MatchTemplate , bug_9597 ) {
{
const uint8_t img [ ] = {
public :
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
CV_TemplMatchTest ( ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
protected :
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
int read_params ( const cv : : FileStorage & fs ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
void get_test_array_types_and_sizes ( int test_case_idx , vector < vector < Size > > & sizes , vector < vector < int > > & types ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
void get_minmax_bounds ( int i , int j , int type , Scalar & low , Scalar & high ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
double get_success_error_level ( int test_case_idx , int i , int j ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
void run_func ( ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
void prepare_to_validation ( int ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
int max_template_size ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
int method ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
bool test_cpp ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
} ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
CV_TemplMatchTest : : CV_TemplMatchTest ( )
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
{
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
test_array [ INPUT ] . push_back ( NULL ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
test_array [ INPUT ] . push_back ( NULL ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
test_array [ OUTPUT ] . push_back ( NULL ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
test_array [ REF_OUTPUT ] . push_back ( NULL ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
element_wise_relative_error = false ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
max_template_size = 100 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
method = 0 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
test_cpp = false ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
}
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
int CV_TemplMatchTest : : read_params ( const cv : : FileStorage & fs )
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
{
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
int code = cvtest : : ArrayTest : : read_params ( fs ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
if ( code < 0 )
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
return code ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
read ( find_param ( fs , " max_template_size " ) , max_template_size , max_template_size ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
max_template_size = cvtest : : clipInt ( max_template_size , 1 , 100 ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
return code ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
}
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
void CV_TemplMatchTest : : get_minmax_bounds ( int i , int j , int type , Scalar & low , Scalar & high )
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
{
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
cvtest : : ArrayTest : : get_minmax_bounds ( i , j , type , low , high ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
int depth = CV_MAT_DEPTH ( type ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
if ( depth = = CV_32F )
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
{
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 ,
low = Scalar : : all ( - 10. ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
high = Scalar : : all ( 10. ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
}
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
}
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 247 , 247 , 247 , 247 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
void CV_TemplMatchTest : : get_test_array_types_and_sizes ( int test_case_idx ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
vector < vector < Size > > & sizes , vector < vector < int > > & types )
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 247 , 247 , 245 , 245 , 245 ,
{
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
RNG & rng = ts - > get_rng ( ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
int depth = cvtest : : randInt ( rng ) % 2 , cn = cvtest : : randInt ( rng ) & 1 ? 3 : 1 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
cvtest : : ArrayTest : : get_test_array_types_and_sizes ( test_case_idx , sizes , types ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 } ;
depth = depth = = 0 ? CV_8U : CV_32F ;
const uint8_t tmpl [ ] = {
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
types [ INPUT ] [ 0 ] = types [ INPUT ] [ 1 ] = CV_MAKETYPE ( depth , cn ) ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
types [ OUTPUT ] [ 0 ] = types [ REF_OUTPUT ] [ 0 ] = CV_32FC1 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
sizes [ INPUT ] [ 1 ] . width = cvtest : : randInt ( rng ) % MIN ( sizes [ INPUT ] [ 1 ] . width , max_template_size ) + 1 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
sizes [ INPUT ] [ 1 ] . height = cvtest : : randInt ( rng ) % MIN ( sizes [ INPUT ] [ 1 ] . height , max_template_size ) + 1 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
sizes [ OUTPUT ] [ 0 ] . width = sizes [ INPUT ] [ 0 ] . width - sizes [ INPUT ] [ 1 ] . width + 1 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
sizes [ OUTPUT ] [ 0 ] . height = sizes [ INPUT ] [ 0 ] . height - sizes [ INPUT ] [ 1 ] . height + 1 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
sizes [ REF_OUTPUT ] [ 0 ] = sizes [ OUTPUT ] [ 0 ] ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
method = cvtest : : randInt ( rng ) % 6 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
test_cpp = ( cvtest : : randInt ( rng ) & 256 ) = = 0 ;
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
}
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
double CV_TemplMatchTest : : get_success_error_level ( int /*test_case_idx*/ , int /*i*/ , int /*j*/ )
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
{
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 } ;
if ( test_mat [ INPUT ] [ 1 ] . depth ( ) = = CV_8U | |
cv : : Mat cvimg ( cv : : Size ( 61 , 82 ) , CV_8UC1 , ( void * ) img , cv : : Mat : : AUTO_STEP ) ;
( method > = cv : : TM_CCOEFF & & test_mat [ INPUT ] [ 1 ] . cols * test_mat [ INPUT ] [ 1 ] . rows < = 2 ) )
cv : : Mat cvtmpl ( cv : : Size ( 17 , 17 ) , CV_8UC1 , ( void * ) tmpl , cv : : Mat : : AUTO_STEP ) ;
return 1e-2 ;
cv : : Mat result ;
else
cv : : matchTemplate ( cvimg , cvtmpl , result , cv : : TM_SQDIFF ) ;
return 1e-3 ;
double minValue ;
}
cv : : minMaxLoc ( result , & minValue , NULL , NULL , NULL ) ;
ASSERT_GE ( minValue , 0 ) ;
void CV_TemplMatchTest : : run_func ( )
{
if ( ! test_cpp )
cvMatchTemplate ( test_array [ INPUT ] [ 0 ] , test_array [ INPUT ] [ 1 ] , test_array [ OUTPUT ] [ 0 ] , method ) ;
else
{
cv : : Mat _out = cv : : cvarrToMat ( test_array [ OUTPUT ] [ 0 ] ) ;
cv : : matchTemplate ( cv : : cvarrToMat ( test_array [ INPUT ] [ 0 ] ) , cv : : cvarrToMat ( test_array [ INPUT ] [ 1 ] ) , _out , method ) ;
}
}
}
//==============================================================================
static void cvTsMatchTemplate ( const CvMat * img , const CvMat * templ , CvMat * result , int method )
static void matchTemplate_reference ( Mat & img , Mat & templ , Mat & result , const int method )
{
{
int i , j , k , l ;
CV_Assert ( cv : : TM_SQDIFF < = method & & method < = cv : : TM_CCOEFF_NORMED ) ;
int depth = CV_MAT_DEPTH ( img - > type ) , cn = CV_MAT_CN ( img - > type ) ;
int width_n = templ - > cols * cn , height = templ - > rows ;
const Size res_sz ( img . cols - templ . cols + 1 , img . rows - templ . rows + 1 ) ;
int a_step = img - > step / CV_ELEM_SIZE ( img - > type & CV_MAT_DEPTH_MASK ) ;
result . create ( res_sz , CV_32FC1 ) ;
int b_step = templ - > step / CV_ELEM_SIZE ( templ - > type & CV_MAT_DEPTH_MASK ) ;
CvScalar b_mean = CV_STRUCT_INITIALIZER , b_sdv = CV_STRUCT_INITIALIZER ;
const int depth = img . depth ( ) ;
double b_denom = 1. , b_sum2 = 0 ;
const int cn = img . channels ( ) ;
int area = templ - > rows * templ - > cols ;
const int area = templ . size ( ) . area ( ) ;
const int width_n = templ . cols * cn ;
cvAvgSdv ( templ , & b_mean , & b_sdv ) ;
const int height = templ . rows ;
int a_step = ( int ) ( img . step / img . elemSize1 ( ) ) ;
for ( i = 0 ; i < cn ; i + + )
int b_step = ( int ) ( templ . step / templ . elemSize1 ( ) ) ;
b_sum2 + = ( b_sdv . val [ i ] * b_sdv . val [ i ] + b_mean . val [ i ] * b_mean . val [ i ] ) * area ;
Scalar b_mean = Scalar : : all ( 0 ) ;
if ( b_sdv . val [ 0 ] * b_sdv . val [ 0 ] + b_sdv . val [ 1 ] * b_sdv . val [ 1 ] +
Scalar b_sdv = Scalar : : all ( 0 ) ;
b_sdv . val [ 2 ] * b_sdv . val [ 2 ] + b_sdv . val [ 3 ] * b_sdv . val [ 3 ] < DBL_EPSILON & &
cv : : meanStdDev ( templ , b_mean , b_sdv ) ;
method = = cv : : TM_CCOEFF_NORMED )
double b_sum2 = 0. ;
for ( int i = 0 ; i < cn ; i + + )
b_sum2 + = ( b_sdv . val [ i ] * b_sdv . val [ i ] + b_mean . val [ i ] * b_mean . val [ i ] ) * area ;
if ( b_sdv . val [ 0 ] * b_sdv . val [ 0 ] + b_sdv . val [ 1 ] * b_sdv . val [ 1 ] +
b_sdv . val [ 2 ] * b_sdv . val [ 2 ] + b_sdv . val [ 3 ] * b_sdv . val [ 3 ] < DBL_EPSILON & &
method = = cv : : TM_CCOEFF_NORMED )
{
{
cvSet ( result , cvScalarAll ( 1. ) ) ;
result = Scalar : : a ll( 1. ) ;
return ;
return ;
}
}
if ( method & 1 )
double b_denom = 1. ;
if ( method & 1 ) // _NORMED
{
{
b_denom = 0 ;
b_denom = 0 ;
if ( method ! = cv : : TM_CCOEFF_NORMED )
if ( method ! = cv : : TM_CCOEFF_NORMED )
{
{
b_denom = b_sum2 ;
b_denom = b_sum2 ;
}
}
else
else
{
{
for ( i = 0 ; i < cn ; i + + )
for ( int i = 0 ; i < cn ; i + + )
b_denom + = b_sdv . val [ i ] * b_sdv . val [ i ] * area ;
b_denom + = b_sdv . val [ i ] * b_sdv . val [ i ] * area ;
}
}
b_denom = sqrt ( b_denom ) ;
b_denom = sqrt ( b_denom ) ;
if ( b_denom = = 0 )
if ( b_denom = = 0 )
b_denom = 1. ;
b_denom = 1. ;
}
}
CV_Assert ( cv : : TM_SQDIFF < = method & & method < = cv : : TM_CCOEFF_NORMED ) ;
for ( int i = 0 ; i < result . rows ; i + + )
for ( i = 0 ; i < result - > rows ; i + + )
{
{
for ( j = 0 ; j < result - > cols ; j + + )
for ( int j = 0 ; j < result . cols ; j + + )
{
{
Scalar a_sum ( 0 ) , a_sum2 ( 0 ) ;
Scalar a_sum ( 0 ) , a_sum2 ( 0 ) ;
Scalar ccorr ( 0 ) ;
Scalar ccorr ( 0 ) ;
double value = 0. ;
double value = 0. ;
if ( depth = = CV_8U )
if ( depth = = CV_8U )
{
{
const uchar * a = img - > data . ptr + i * img - > step + j * cn ;
const uchar * a = img . ptr < uchar > ( i , j ) ; // ??? ->data.ptr + i*img->step + j*cn;
const uchar * b = templ - > data . ptr ;
const uchar * b = templ . ptr < uchar > ( ) ;
if ( cn = = 1 | | method < cv : : TM_CCOEFF )
if ( cn = = 1 | | method < cv : : TM_CCOEFF )
{
{
for ( k = 0 ; k < height ; k + + , a + = a_step , b + = b_step )
for ( int k = 0 ; k < height ; k + + , a + = a_step , b + = b_step )
for ( l = 0 ; l < width_n ; l + + )
for ( int l = 0 ; l < width_n ; l + + )
{
{
ccorr . val [ 0 ] + = a [ l ] * b [ l ] ;
ccorr . val [ 0 ] + = a [ l ] * b [ l ] ;
a_sum . val [ 0 ] + = a [ l ] ;
a_sum . val [ 0 ] + = a [ l ] ;
@ -212,8 +209,8 @@ static void cvTsMatchTemplate( const CvMat* img, const CvMat* templ, CvMat* resu
}
}
else
else
{
{
for ( k = 0 ; k < height ; k + + , a + = a_step , b + = b_step )
for ( int k = 0 ; k < height ; k + + , a + = a_step , b + = b_step )
for ( l = 0 ; l < width_n ; l + = 3 )
for ( int l = 0 ; l < width_n ; l + = 3 )
{
{
ccorr . val [ 0 ] + = a [ l ] * b [ l ] ;
ccorr . val [ 0 ] + = a [ l ] * b [ l ] ;
ccorr . val [ 1 ] + = a [ l + 1 ] * b [ l + 1 ] ;
ccorr . val [ 1 ] + = a [ l + 1 ] * b [ l + 1 ] ;
@ -227,15 +224,15 @@ static void cvTsMatchTemplate( const CvMat* img, const CvMat* templ, CvMat* resu
}
}
}
}
}
}
else
else // CV_32F
{
{
const float * a = ( const float * ) ( img - > data . ptr + i * img - > step ) + j * cn ;
const float * a = img . ptr < float > ( i , j ) ; // ???? (const float*)(img->data.ptr + i*img->step) + j*cn;
const float * b = ( const float * ) templ - > data . ptr ;
const float * b = templ . ptr < float > ( ) ;
if ( cn = = 1 | | method < cv : : TM_CCOEFF )
if ( cn = = 1 | | method < cv : : TM_CCOEFF )
{
{
for ( k = 0 ; k < height ; k + + , a + = a_step , b + = b_step )
for ( int k = 0 ; k < height ; k + + , a + = a_step , b + = b_step )
for ( l = 0 ; l < width_n ; l + + )
for ( int l = 0 ; l < width_n ; l + + )
{
{
ccorr . val [ 0 ] + = a [ l ] * b [ l ] ;
ccorr . val [ 0 ] + = a [ l ] * b [ l ] ;
a_sum . val [ 0 ] + = a [ l ] ;
a_sum . val [ 0 ] + = a [ l ] ;
@ -244,8 +241,8 @@ static void cvTsMatchTemplate( const CvMat* img, const CvMat* templ, CvMat* resu
}
}
else
else
{
{
for ( k = 0 ; k < height ; k + + , a + = a_step , b + = b_step )
for ( int k = 0 ; k < height ; k + + , a + = a_step , b + = b_step )
for ( l = 0 ; l < width_n ; l + = 3 )
for ( int l = 0 ; l < width_n ; l + = 3 )
{
{
ccorr . val [ 0 ] + = a [ l ] * b [ l ] ;
ccorr . val [ 0 ] + = a [ l ] * b [ l ] ;
ccorr . val [ 1 ] + = a [ l + 1 ] * b [ l + 1 ] ;
ccorr . val [ 1 ] + = a [ l + 1 ] * b [ l + 1 ] ;
@ -299,130 +296,50 @@ static void cvTsMatchTemplate( const CvMat* img, const CvMat* templ, CvMat* resu
else
else
value = method ! = cv : : TM_SQDIFF_NORMED ? 0 : 1 ;
value = method ! = cv : : TM_SQDIFF_NORMED ? 0 : 1 ;
}
}
result . at < float > ( i , j ) = ( float ) value ;
( ( float * ) ( result - > data . ptr + result - > step * i ) ) [ j ] = ( float ) value ;
}
}
}
}
}
}
//==============================================================================
void CV_TemplMatchTest : : prepare_to_validation ( int /*test_case_idx*/ )
CV_ENUM ( MatchModes , TM_SQDIFF , TM_SQDIFF_NORMED , TM_CCORR , TM_CCORR_NORMED , TM_CCOEFF , TM_CCOEFF_NORMED ) ;
{
CvMat _input = cvMat ( test_mat [ INPUT ] [ 0 ] ) , _templ = cvMat ( test_mat [ INPUT ] [ 1 ] ) ;
CvMat _output = cvMat ( test_mat [ REF_OUTPUT ] [ 0 ] ) ;
cvTsMatchTemplate ( & _input , & _templ , & _output , method ) ;
//if( ts->get_current_test_info()->test_case_idx == 0 )
typedef testing : : TestWithParam < testing : : tuple < perf : : MatDepth , int , MatchModes > > matchTemplate_Modes ;
/*{
CvFileStorage * fs = cvOpenFileStorage ( " _match_template.yml " , 0 , CV_STORAGE_WRITE ) ;
TEST_P ( matchTemplate_Modes , accuracy )
cvWrite ( fs , " image " , & test_mat [ INPUT ] [ 0 ] ) ;
{
cvWrite ( fs , " template " , & test_mat [ INPUT ] [ 1 ] ) ;
const int data_type = CV_MAKE_TYPE ( get < 0 > ( GetParam ( ) ) , get < 1 > ( GetParam ( ) ) ) ;
cvWrite ( fs , " ref " , & test_mat [ REF_OUTPUT ] [ 0 ] ) ;
const int method = get < 2 > ( GetParam ( ) ) ;
cvWrite ( fs , " opencv " , & test_mat [ OUTPUT ] [ 0 ] ) ;
RNG & rng = TS : : ptr ( ) - > get_rng ( ) ;
cvWriteInt ( fs , " method " , method ) ;
cvReleaseFileStorage ( & fs ) ;
} */
if ( method > = cv : : TM_CCOEFF )
for ( int ITER = 0 ; ITER < 20 ; + + ITER )
{
{
// avoid numerical stability problems in singular cases (when the results are near to 0)
SCOPED_TRACE ( cv : : format ( " iteration %d " , ITER ) ) ;
const double delta = 10. ;
test_mat [ REF_OUTPUT ] [ 0 ] + = Scalar : : all ( delta ) ;
const Size imgSize ( rng . uniform ( 128 , 320 ) , rng . uniform ( 128 , 240 ) ) ;
test_mat [ OUTPUT ] [ 0 ] + = Scalar : : all ( delta ) ;
const Size templSize ( rng . uniform ( 1 , 100 ) , rng . uniform ( 1 , 100 ) ) ;
Mat img ( imgSize , data_type , Scalar : : all ( 0 ) ) ;
Mat templ ( templSize , data_type , Scalar : : all ( 0 ) ) ;
cvtest : : randUni ( rng , img , Scalar : : all ( 0 ) , Scalar : : all ( 255 ) ) ;
cvtest : : randUni ( rng , templ , Scalar : : all ( 0 ) , Scalar : : all ( 255 ) ) ;
Mat result ;
cv : : matchTemplate ( img , templ , result , method ) ;
Mat reference ;
matchTemplate_reference ( img , templ , reference , method ) ;
EXPECT_MAT_NEAR_RELATIVE ( result , reference , 1e-3 ) ;
}
}
}
}
TEST ( Imgproc_MatchTemplate , accuracy ) { CV_TemplMatchTest test ; test . safe_run ( ) ; }
INSTANTIATE_TEST_CASE_P ( /**/ ,
matchTemplate_Modes ,
testing : : Combine (
testing : : Values ( CV_8U , CV_32F ) ,
testing : : Values ( 1 , 3 ) ,
testing : : Values ( TM_SQDIFF , TM_SQDIFF_NORMED , TM_CCORR , TM_CCORR_NORMED , TM_CCOEFF , TM_CCOEFF_NORMED ) ) ) ;
}
TEST ( Imgproc_MatchTemplate , bug_9597 ) {
} } // namespace
const uint8_t img [ ] = {
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 246 , 246 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 247 , 247 , 247 , 247 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 247 , 247 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 } ;
const uint8_t tmpl [ ] = {
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 ,
245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 , 245 } ;
cv : : Mat cvimg ( cv : : Size ( 61 , 82 ) , CV_8UC1 , ( void * ) img , cv : : Mat : : AUTO_STEP ) ;
cv : : Mat cvtmpl ( cv : : Size ( 17 , 17 ) , CV_8UC1 , ( void * ) tmpl , cv : : Mat : : AUTO_STEP ) ;
cv : : Mat result ;
cv : : matchTemplate ( cvimg , cvtmpl , result , cv : : TM_SQDIFF ) ;
double minValue ;
cv : : minMaxLoc ( result , & minValue , NULL , NULL , NULL ) ;
ASSERT_GE ( minValue , 0 ) ;
}
} // namespace