Move the sources to trunk
[opencv] / tests / cv / src / ahoughtransform.cpp
1 /*M///////////////////////////////////////////////////////////////////////////////////////
2 //
3 //  IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
4 //
5 //  By downloading, copying, installing or using the software you agree to this license.
6 //  If you do not agree to this license, do not download, install,
7 //  copy or use the software.
8 //
9 //
10 //                        Intel License Agreement
11 //                For Open Source Computer Vision Library
12 //
13 // Copyright (C) 2000, Intel Corporation, 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 documentation
24 //     and/or other materials provided with the distribution.
25 //
26 //   * The name of Intel Corporation may not be used to endorse or promote products
27 //     derived from this software without specific prior written permission.
28 //
29 // This software is provided by the copyright holders and contributors "as is" and
30 // any express or implied warranties, including, but not limited to, the implied
31 // 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 damages
34 // (including, but not limited to, procurement of substitute goods or services;
35 // loss of use, data, or profits; or business interruption) however caused
36 // and on any theory of liability, whether in contract, strict liability,
37 // or tort (including negligence or otherwise) arising in any way out of
38 // the use of this software, even if advised of the possibility of such damage.
39 //
40 //M*/
41
42 #include "cvtest.h"
43
44 #if 0
45
46 #include <stdlib.h>
47 #include <math.h>
48 #include <float.h>
49
50 #define HT_STANDARD (size_t)1
51 #define HT_PP (size_t)2
52 #define HT_MD (size_t)3
53
54 static char* func_names[] = {"cvHoughTransform", "cvHoughTransformP", "cvHoughTransformSDiv"};
55 static char* test_desc[] = { "Run the hough transform function"};
56
57 int test_dt(void* arg);
58 int read_image_dims(void);
59 int read_gen_type(void);
60
61 int test_ht(void* arg)
62 {
63     int nlines = 10;
64     int* lines = new int[4*nlines];
65     float* flines = new float[2*nlines];
66     float rho = 10.0f, theta = 0.1f;
67     int srn = 10, stn = 10;
68     int threshold = 10;
69     int lineLength = 10, lineGap = 2;
70     int w = 100; /* width and height of the rect */
71     int h = 100;
72     int type = (int)(size_t)arg;
73     IplImage* image; /* Source and destination images */
74     image = cvCreateImage( cvSize(w, h), 8, 1 );
75     cvZero(image);
76     
77     if( image == NULL )
78     {
79         delete lines;
80         delete flines;
81         return trsResult(TRS_FAIL, "Not enough memory to perform the test");
82     }
83
84     switch(type)
85     {
86     case HT_STANDARD:
87         /* Run the distance transformation function */
88         cvHoughLines(image, rho, theta, threshold, flines, nlines);
89         break;
90
91     case HT_PP:
92         cvHoughLinesP(image, rho, theta, threshold, lineLength, lineGap, lines, nlines);
93         break;
94
95     case HT_MD:
96         cvHoughLinesSDiv(image, rho, srn, theta, stn, threshold, flines, nlines);
97         break;
98
99     default:
100         cvReleaseImage(& image);
101         delete lines;
102         delete flines;
103         trsResult(TRS_FAIL, "No such function");
104     }
105     cvReleaseImage( &image );
106     delete lines;
107     delete flines;
108     if(cvGetErrStatus() < 0)
109     {
110         return trsResult(TRS_FAIL, "Function returned 'bad argument'");
111     }
112     else
113     {
114         return trsResult(TRS_OK, "No errors");
115     }
116 }
117
118 void InitAHoughLines(void)
119 {
120     /* Registering test functions */
121     trsRegArg(func_names[0], test_desc[0], atsAlgoClass, test_ht, HT_STANDARD);
122     trsRegArg(func_names[1], test_desc[0], atsAlgoClass, test_ht, HT_PP);
123     trsRegArg(func_names[2], test_desc[0], atsAlgoClass, test_ht, HT_MD);
124
125 } /* InitADistanceTransform*/
126
127 #endif
128