diff options
-rw-r--r-- | Makefile | 2 | ||||
-rwxr-xr-x | pix_opencv_hist_compare-help.pd (renamed from pix_opencv_histo-help.pd) | 44 | ||||
-rwxr-xr-x | pix_opencv_hist_compare.cc (renamed from pix_opencv_histo.cc) | 95 | ||||
-rwxr-xr-x | pix_opencv_hist_compare.h (renamed from pix_opencv_histo.h) | 11 |
4 files changed, 94 insertions, 58 deletions
@@ -35,7 +35,7 @@ endif .SUFFIXES = $(EXTENSION) -SOURCES = pix_opencv_edge.cc pix_opencv_laplace.cc pix_opencv_morphology.cc pix_opencv_distrans.cc pix_opencv_motempl.cc pix_opencv_haarcascade.cc pix_opencv_contours_boundingrect.cc pix_opencv_bgsubstract.cc pix_opencv_contours_convexity.cc pix_opencv_dft.cc pix_opencv_lk.cc pix_opencv_histo.cc pix_opencv_knear.cc pix_opencv_threshold.cc +SOURCES = pix_opencv_edge.cc pix_opencv_laplace.cc pix_opencv_morphology.cc pix_opencv_distrans.cc pix_opencv_motempl.cc pix_opencv_haarcascade.cc pix_opencv_contours_boundingrect.cc pix_opencv_bgsubstract.cc pix_opencv_contours_convexity.cc pix_opencv_dft.cc pix_opencv_lk.cc pix_opencv_hist_compare.cc pix_opencv_knear.cc pix_opencv_threshold.cc all: $(SOURCES:.cc=.$(EXTENSION)) diff --git a/pix_opencv_histo-help.pd b/pix_opencv_hist_compare-help.pd index 5dd00c9..17268b7 100755 --- a/pix_opencv_histo-help.pd +++ b/pix_opencv_hist_compare-help.pd @@ -1,7 +1,7 @@ -#N canvas 36 143 1154 642 10; +#N canvas 41 167 1154 642 10; #X obj 396 -37 gemhead; -#X obj 364 372 pix_texture; -#X obj 364 400 square 2; +#X obj 364 478 pix_texture; +#X obj 364 506 square 2; #X obj 9 -28 cnv 15 220 70 empty empty empty 20 12 0 14 -195568 -66577 0; #N canvas 0 22 454 304 gemwin 0; @@ -33,11 +33,11 @@ #X restore 14 16 pd gemwin; #X msg 14 -8 destroy; #X text 15 -26 Create window and render; -#X obj 200 368 pix_texture; -#X obj 200 396 square 2; +#X obj 216 478 pix_texture; +#X obj 216 506 square 2; #X obj 367 159 translateXYZ -2 0 0; #X obj 367 224 separator; -#X obj 350 285 cnv 15 500 80 empty empty empty 20 12 0 14 -24198 -66577 +#X obj 350 285 cnv 15 500 180 empty empty empty 20 12 0 14 -24198 -66577 0; #X obj 511 -66 bng 25 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 -1; @@ -57,19 +57,30 @@ #X obj 364 259 translateXYZ 4 0 0; #X obj 580 26 loadbang; #X msg 528 50 colorspace RGBA; -#X floatatom 456 349 5 0 0 0 - - -; #X obj 439 290 hradio 15 1 0 5 empty empty empty 0 -8 0 10 -262144 -1 -1 0; #X text 522 289 save an histogram at position nth ( 0 <= n <= 80 ) ; -#X text 496 350 closest histogram; -#X obj 364 315 pix_opencv_histo; #X text 5 -87 record histograms of specific situations; #X text 7 -75 the object will recognize the situations if they occur again; #X text 7 -61 Written by Lluis Gomez i Bigorda ( lluisgomez@hangar.org ); -#X text 6 -100 pix_opencv_histo : image recognition using histograms +#X floatatom 443 421 5 0 0 0 - - -; +#X obj 505 346 unpack f f f f f; +#X text 598 381 nearest to 1 is the winner; +#X text 479 422 closest histogram (winner); +#X obj 505 374 vsl 15 37 0 1 0 0 empty empty empty 0 -9 0 10 -262144 +-1 -1 0 1; +#X obj 528 374 vsl 15 37 0 1 0 0 empty empty empty 0 -9 0 10 -262144 +-1 -1 0 1; +#X obj 551 374 vsl 15 37 0 1 0 0 empty empty empty 0 -9 0 10 -262144 +-1 -1 0 1; +#X obj 574 374 vsl 15 37 0 1 0 0 empty empty empty 0 -9 0 10 -262144 +-1 -1 0 1; +#X text 597 370 matching measure with stored histograms; +#X obj 364 315 pix_opencv_hist_compare; +#X text 7 -100 pix_opencv_hist_compare : image recognition using histograms ; #X connect 0 0 21 0; #X connect 1 0 2 0; @@ -92,9 +103,14 @@ again; #X connect 21 2 17 0; #X connect 22 0 21 0; #X connect 23 0 22 0; -#X connect 24 0 31 0; +#X connect 24 0 41 0; #X connect 25 0 26 0; #X connect 26 0 21 0; -#X connect 28 0 31 1; -#X connect 31 0 1 0; -#X connect 31 1 27 0; +#X connect 27 0 41 1; +#X connect 33 0 36 0; +#X connect 33 1 37 0; +#X connect 33 2 38 0; +#X connect 33 3 39 0; +#X connect 41 0 1 0; +#X connect 41 1 32 0; +#X connect 41 2 33 0; diff --git a/pix_opencv_histo.cc b/pix_opencv_hist_compare.cc index c5000ce..865b090 100755 --- a/pix_opencv_histo.cc +++ b/pix_opencv_hist_compare.cc @@ -15,20 +15,20 @@ // ///////////////////////////////////////////////////////// -#include "pix_opencv_histo.h" +#include "pix_opencv_hist_compare.h" -CPPEXTERN_NEW(pix_opencv_histo) +CPPEXTERN_NEW(pix_opencv_hist_compare) ///////////////////////////////////////////////////////// // -// pix_opencv_histo +// pix_opencv_hist_compare // ///////////////////////////////////////////////////////// // Constructor // ///////////////////////////////////////////////////////// -pix_opencv_histo :: pix_opencv_histo() +pix_opencv_hist_compare :: pix_opencv_hist_compare() { int i; @@ -37,6 +37,7 @@ pix_opencv_histo :: pix_opencv_histo() inlet_new(this->x_obj, &this->x_obj->ob_pd, gensym("float"), gensym("save")); m_dataout = outlet_new(this->x_obj, &s_anything); + m_measureout = outlet_new(this->x_obj, &s_anything); save_now = 0; @@ -86,7 +87,7 @@ pix_opencv_histo :: pix_opencv_histo() // Destructor // ///////////////////////////////////////////////////////// -pix_opencv_histo :: ~pix_opencv_histo() +pix_opencv_hist_compare :: ~pix_opencv_hist_compare() { //Destroy cv_images to clean memory cvReleaseImage(&rgba); @@ -105,7 +106,7 @@ pix_opencv_histo :: ~pix_opencv_histo() // processImage // ///////////////////////////////////////////////////////// -void pix_opencv_histo :: processRGBAImage(imageStruct &image) +void pix_opencv_hist_compare :: processRGBAImage(imageStruct &image) { int i; int h_bins = (int)(comp_xsize/10), s_bins = (int)(comp_ysize/10); @@ -115,7 +116,7 @@ void pix_opencv_histo :: processRGBAImage(imageStruct &image) this->comp_xsize=image.xsize; this->comp_ysize=image.ysize; - post( "pix_opencv_histo : reallocating buffers" ); + post( "pix_opencv_hist_compare : reallocating buffers" ); //Destroy cv_images to clean memory cvReleaseImage(&rgba); @@ -194,6 +195,7 @@ void pix_opencv_histo :: processRGBAImage(imageStruct &image) cvNormalizeHist( hist, 1.0 ); //Normalize it double tato[MAX_HISTOGRAMS_TO_COMPARE]; + t_atom datalist[MAX_HISTOGRAMS_TO_COMPARE]; int nearest = -1; double max = 0; @@ -201,13 +203,18 @@ void pix_opencv_histo :: processRGBAImage(imageStruct &image) if ( nbsaved > 0 ) for (n=0; n<MAX_HISTOGRAMS_TO_COMPARE; n++) { tato[n] = cvCompareHist(hist, saved_hist[n], CV_COMP_INTERSECT); + SETFLOAT(&datalist[n], tato[n]); if (tato[n]>max) { max = tato[n]; nearest = n; } } - outlet_float(m_dataout, (float)nearest); + if ( nbsaved > 0 ) { + outlet_float(m_dataout, (float)nearest); + outlet_list( m_measureout, 0, MAX_HISTOGRAMS_TO_COMPARE , datalist ); + } else + outlet_float(m_dataout, -1.0); // Create an image to use to visualize our histogram. int scale = 10; @@ -234,7 +241,7 @@ void pix_opencv_histo :: processRGBAImage(imageStruct &image) } -void pix_opencv_histo :: processRGBImage(imageStruct &image) +void pix_opencv_hist_compare :: processRGBImage(imageStruct &image) { int i; int h_bins = (int)(comp_xsize/10), s_bins = (int)(comp_ysize/10); @@ -320,6 +327,7 @@ void pix_opencv_histo :: processRGBImage(imageStruct &image) cvNormalizeHist( hist, 1.0 ); //Normalize it double tato[MAX_HISTOGRAMS_TO_COMPARE]; + t_atom datalist[MAX_HISTOGRAMS_TO_COMPARE]; int nearest = -1; double max = 0; @@ -327,13 +335,18 @@ void pix_opencv_histo :: processRGBImage(imageStruct &image) if ( nbsaved > 0 ) for (n=0; n<MAX_HISTOGRAMS_TO_COMPARE; n++) { tato[n] = cvCompareHist(hist, saved_hist[n], CV_COMP_INTERSECT); + SETFLOAT(&datalist[n], tato[n]); if (tato[n]>max) { max = tato[n]; nearest = n; } } - outlet_float(m_dataout, (float)nearest); + if ( nbsaved > 0 ) { + outlet_float(m_dataout, (float)nearest); + outlet_list( m_measureout, 0, MAX_HISTOGRAMS_TO_COMPARE , datalist ); + } else + outlet_float(m_dataout, -1.0); // Create an image to use to visualize our histogram. int scale = 10; @@ -360,12 +373,12 @@ void pix_opencv_histo :: processRGBImage(imageStruct &image) } -void pix_opencv_histo :: processYUVImage(imageStruct &image) +void pix_opencv_hist_compare :: processYUVImage(imageStruct &image) { - post( "pix_opencv_histo : yuv format not supported" ); + post( "pix_opencv_hist_compare : yuv format not supported" ); } -void pix_opencv_histo :: processGrayImage(imageStruct &image) +void pix_opencv_hist_compare :: processGrayImage(imageStruct &image) { int i; int h_bins = (int)(comp_xsize/10), s_bins = (int)(comp_ysize/10); @@ -447,37 +460,43 @@ void pix_opencv_histo :: processGrayImage(imageStruct &image) cvNormalizeHist( saved_hist[save_now], 1.0 ); //Normalize it save_now=-1; nbsaved++; - } - cvCalcHist( planes, hist, 0, 0 ); //Compute histogram - cvNormalizeHist( hist, 1.0 ); //Normalize it + } + cvCalcHist( planes, hist, 0, 0 ); //Compute histogram + cvNormalizeHist( hist, 1.0 ); //Normalize it - double tato[MAX_HISTOGRAMS_TO_COMPARE]; - int nearest = -1; - double max = 0; + double tato[MAX_HISTOGRAMS_TO_COMPARE]; + t_atom datalist[MAX_HISTOGRAMS_TO_COMPARE]; + int nearest = -1; + double max = 0; - int n; - if ( nbsaved > 0 ) + int n; + if ( nbsaved > 0 ) for (n=0; n<MAX_HISTOGRAMS_TO_COMPARE; n++) { tato[n] = cvCompareHist(hist, saved_hist[n], CV_COMP_INTERSECT); + SETFLOAT(&datalist[n], tato[n]); if (tato[n]>max) { max = tato[n]; nearest = n; } - } + } - outlet_float(m_dataout, (float)nearest); + if ( nbsaved > 0 ) { + outlet_float(m_dataout, (float)nearest); + outlet_list( m_measureout, 0, MAX_HISTOGRAMS_TO_COMPARE , datalist ); + } else + outlet_float(m_dataout, -1.0); - // Create an image to use to visualize our histogram. - int scale = 10; - // populate our visualization with little gray squares. - float max_value = 0; - cvGetMinMaxHistValue( hist, 0, &max_value, 0, 0 ); + // Create an image to use to visualize our histogram. + int scale = 10; + // populate our visualization with little gray squares. + float max_value = 0; + cvGetMinMaxHistValue( hist, 0, &max_value, 0, 0 ); - int h = 0; - int s = 0; + int h = 0; + int s = 0; - for( h = 0; h < h_bins; h++ ) { - for( s = 0; s < s_bins; s++ ) { + for( h = 0; h < h_bins; h++ ) { + for( s = 0; s < s_bins; s++ ) { float bin_val = cvQueryHistValue_2D( hist, h, s ); int intensity = cvRound( bin_val * 255 / max_value ); cvRectangle( @@ -486,9 +505,9 @@ void pix_opencv_histo :: processGrayImage(imageStruct &image) cvPoint( (h+1)*scale - 1, (s+1)*scale - 1), CV_RGB(intensity,intensity,intensity), CV_FILLED, 8 , 0 ); } - } + } - memcpy( image.data, grey->imageData, image.xsize*image.ysize ); + memcpy( image.data, grey->imageData, image.xsize*image.ysize ); } @@ -497,18 +516,18 @@ void pix_opencv_histo :: processGrayImage(imageStruct &image) // ///////////////////////////////////////////////////////// -void pix_opencv_histo :: obj_setupCallback(t_class *classPtr) +void pix_opencv_hist_compare :: obj_setupCallback(t_class *classPtr) { - class_addmethod(classPtr, (t_method)&pix_opencv_histo::saveMessCallback, + class_addmethod(classPtr, (t_method)&pix_opencv_hist_compare::saveMessCallback, gensym("save"), A_FLOAT, A_NULL); } -void pix_opencv_histo :: saveMess(float index) +void pix_opencv_hist_compare :: saveMess(float index) { if (((int)index>=0)&&((int)index<MAX_HISTOGRAMS_TO_COMPARE)) save_now = (int)index; } -void pix_opencv_histo :: saveMessCallback(void *data, t_floatarg index) +void pix_opencv_hist_compare :: saveMessCallback(void *data, t_floatarg index) { GetMyClass(data)->saveMess(index); } diff --git a/pix_opencv_histo.h b/pix_opencv_hist_compare.h index ca27166..7e07f0b 100755 --- a/pix_opencv_histo.h +++ b/pix_opencv_hist_compare.h @@ -27,7 +27,7 @@ LOG /*----------------------------------------------------------------- ------------------------------------------------------------------- CLASS - pix_opencv_histo + pix_opencv_hist_compare Histogram reognition object using Open CV @@ -38,21 +38,21 @@ DESCRIPTION -----------------------------------------------------------------*/ -class GEM_EXTERN pix_opencv_histo : public GemPixObj +class GEM_EXTERN pix_opencv_hist_compare : public GemPixObj { - CPPEXTERN_HEADER(pix_opencv_histo, GemPixObj) + CPPEXTERN_HEADER(pix_opencv_hist_compare, GemPixObj) public: ////////// // Constructor - pix_opencv_histo(); + pix_opencv_hist_compare(); protected: ////////// // Destructor - virtual ~pix_opencv_histo(); + virtual ~pix_opencv_hist_compare(); ////////// // Do the processing @@ -67,6 +67,7 @@ class GEM_EXTERN pix_opencv_histo : public GemPixObj int comp_ysize; t_outlet *m_dataout; + t_outlet *m_measureout; private: |