天天看點

圖像特征提取的總結

圖像特征提取代碼集合

目錄:

1,顔色提取

2,形狀提取

3,角點提取

4,hough直線提取

5,hough圓提取

6,hough矩形提取

7,邊緣直方圖提取

8,視訊流中邊緣檢測

9,紋理提取

1,顔色提取

顔色直方圖提取:

#include <cv.h>

#include <highgui.h>

#include <iostream>

using namespace std;

 int main( int argc, char** argv )

{

IplImage * src= cvLoadImage("f.jpg",1);

IplImage* hsv = cvCreateImage( cvGetSize(src), 8, 3 );

IplImage* h_plane = cvCreateImage( cvGetSize(src), 8, 1 );

IplImage* s_plane = cvCreateImage( cvGetSize(src), 8, 1 );

IplImage* v_plane = cvCreateImage( cvGetSize(src), 8, 1 );

IplImage* planes[] = { h_plane, s_plane };

int h_bins = 16, s_bins = 8;

int hist_size[] = {h_bins, s_bins};

float h_ranges[] = { 0, 180 }; 

float s_ranges[] = { 0, 255 };

float* ranges[] = { h_ranges, s_ranges };

cvCvtColor( src, hsv, CV_BGR2HSV );

cvCvtPixToPlane( hsv, h_plane, s_plane, v_plane, 0 );

CvHistogram * hist = cvCreateHist( 2, hist_size, CV_HIST_ARRAY, ranges, 1 );

cvCalcHist( planes, hist, 0, 0 );

float max_value;

cvGetMinMaxHistValue( hist, 0, &max_value, 0, 0 );

int height = 240;

int width = (h_bins*s_bins*6);

IplImage* hist_img = cvCreateImage( cvSize(width,height), 8, 3 );

cvZero( hist_img );

IplImage * hsv_color = cvCreateImage(cvSize(1,1),8,3);

IplImage * rgb_color = cvCreateImage(cvSize(1,1),8,3);

int bin_w = width / (h_bins * s_bins);

for(int h = 0; h < h_bins; h++)

{

for(int s = 0; s < s_bins; s++)

{

int i = h*s_bins + s;

float bin_val = cvQueryHistValue_2D( hist, h, s );

int intensity = cvRound(bin_val*height/max_value);

cvSet2D(hsv_color,0,0,cvScalar(h*180.f / h_bins,s*255.f/s_bins,255,0));

cvCvtColor(hsv_color,rgb_color,CV_HSV2BGR);

CvScalar color = cvGet2D(rgb_color,0,0);

cvRectangle( hist_img, cvPoint(i*bin_w,height),

cvPoint((i+1)*bin_w,height - intensity),

color, -1, 8, 0 );

}

}

cvNamedWindow( "Source", 1 );

cvShowImage( "Source", src );

cvNamedWindow( "H-S Histogram", 1 );

cvShowImage( "H-S Histogram", hist_img ); 

cvWaitKey(0);

}

圖像特征提取的總結
圖像特征提取的總結

2,形狀提取

Candy算子對邊緣提取:

#include "cv.h"

#include "cxcore.h"

#include "highgui.h" 

int main( int argc, char** argv ) 

{

    //聲明IplImage指針

         IplImage* pImg = NULL; 

    IplImage* pCannyImg = NULL; 

    //載入圖像,強制轉化為Gray

pImg = cvLoadImage( "result.bmp", 0); 

//為canny邊緣圖像申請空間

pCannyImg = cvCreateImage(cvGetSize(pImg), IPL_DEPTH_8U, 1);

//canny邊緣檢測

cvCanny(pImg, pCannyImg, 50, 150, 3); 

//建立視窗

cvNamedWindow("src", 1);

cvNamedWindow("canny",1);

//顯示圖像

cvShowImage( "src", pImg ); 

cvShowImage( "canny", pCannyImg ); 

//等待按鍵

cvWaitKey(0);

//銷毀視窗

cvDestroyWindow( "src" ); 

cvDestroyWindow( "canny" );

//釋放圖像

cvReleaseImage( &pImg ); 

cvReleaseImage( &pCannyImg );

return 0;

圖像特征提取的總結
圖像特征提取的總結

3,角點提取:

#include <stdio.h>

#include "cv.h"

#include "highgui.h"

#define MAX_CORNERS 100

int main(void)

{

int cornersCount=MAX_CORNERS;//得到的角點數目

CvPoint2D32f corners[MAX_CORNERS];//輸出角點集合

IplImage *srcImage = 0,*grayImage = 0,*corners1 = 0,*corners2 = 0;

int i;

CvScalar color = CV_RGB(255,0,0);

cvNamedWindow("image",1);

//Load the image to be processed

srcImage = cvLoadImage("f.jpg",1);

grayImage = cvCreateImage(cvGetSize(srcImage),IPL_DEPTH_8U,1);

//copy the source image to copy image after converting the format

//複制并轉為灰階圖像

cvCvtColor(srcImage,grayImage,CV_BGR2GRAY);

//create empty images os same size as the copied images

//兩幅臨時位浮點圖像,cvGoodFeaturesToTrack會用到

corners1 = cvCreateImage(cvGetSize(srcImage),IPL_DEPTH_32F,1);

corners2 = cvCreateImage(cvGetSize(srcImage),IPL_DEPTH_32F,1);

cvGoodFeaturesToTrack(grayImage,corners1,corners2,corners,&cornersCount,0.05,

30,//角點的最小距離是

0,//整個圖像

3,0,0.4);

printf("num corners found: %d\n",cornersCount);

//開始畫出每個點

if (cornersCount>0)

{

for (i=0;i<cornersCount;i++)

{

cvCircle(srcImage,cvPoint((int)(corners[i].x),(int)(corners[i].y)),2,color,2,CV_AA,0);

}

}

cvShowImage("image",srcImage);

cvSaveImage("imagedst.png",srcImage);

cvReleaseImage(&srcImage);

cvReleaseImage(&grayImage);

cvReleaseImage(&corners1);

cvReleaseImage(&corners2);

cvWaitKey(0);

return 0;

圖像特征提取的總結
圖像特征提取的總結

4,hough直線提取

#include <cv.h>

#include <highgui.h>

#include <math.h>

int main(int argc, char** argv)

{

    IplImage* src = cvLoadImage( "house.png" , 0 );

    IplImage* dst;

    IplImage* color_dst;

    CvMemStorage* storage = cvCreateMemStorage(0);

    CvSeq* lines = 0;

    int i;

    if( !src )

        return -1;

    dst = cvCreateImage( cvGetSize(src), 8, 1 );

    color_dst = cvCreateImage( cvGetSize(src), 8, 3 );

    cvCanny( src, dst, 50, 200, 3 );

    cvCvtColor( dst, color_dst, CV_GRAY2BGR );

#if 0

    lines = cvHoughLines2( dst, storage, CV_HOUGH_STANDARD, 1, CV_PI/180, 100, 0, 0 );

    for( i = 0; i < MIN(lines->total,100); i++ )

    {

        float* line = (float*)cvGetSeqElem(lines,i);

        float rho = line[0];

        float theta = line[1];

        CvPoint pt1, pt2;

        double a = cos(theta), b = sin(theta);

        double x0 = a*rho, y0 = b*rho;

        pt1.x = cvRound(x0 + 1000*(-b));

        pt1.y = cvRound(y0 + 1000*(a));

        pt2.x = cvRound(x0 - 1000*(-b));

        pt2.y = cvRound(y0 - 1000*(a));

        cvLine( color_dst, pt1, pt2, CV_RGB(255,0,0), 3, CV_AA, 0 );

    }

#else

    lines = cvHoughLines2( dst, storage, CV_HOUGH_PROBABILISTIC, 1, CV_PI/180, 50, 50, 10 );

    for( i = 0; i < lines->total; i++ )

    {

        CvPoint* line = (CvPoint*)cvGetSeqElem(lines,i);

        cvLine( color_dst, line[0], line[1], CV_RGB(255,0,0), 3, CV_AA, 0 );

    }

#endif

    cvNamedWindow( "Source", 1 );

    cvShowImage( "Source", src );

    cvNamedWindow( "Hough", 1 );

    cvShowImage( "Hough", color_dst );

    cvWaitKey(0);

    return 0;

}

圖像特征提取的總結
圖像特征提取的總結

5,hough圓提取

#include <cv.h>

#include <highgui.h>

#include <math.h>

#include <iostream>

using namespace std;

int main(int argc, char** argv)

{

    IplImage* img;

img=cvLoadImage("c4.jpg", 1);

 IplImage* gray = cvCreateImage( cvGetSize(img), 8, 1 );

     CvMemStorage* storage = cvCreateMemStorage(0);

     cvCvtColor( img, gray, CV_BGR2GRAY );

     cvSmooth( gray, gray, CV_GAUSSIAN, 5, 15 );

// smooth it, otherwise a lot of false circles may be detected

CvSeq* circles = cvHoughCircles( gray, storage, CV_HOUGH_GRADIENT, 2, gray->height/4, 200, 100 );

    int i;

     for( i = 0; i < circles->total; i++ )

     {

          float* p = (float*)cvGetSeqElem( circles, i );

          cvCircle( img, cvPoint(cvRound(p[0]),cvRound(p[1])), 3, CV_RGB(0,255,0), -1, 8, 0 );

 cvCircle( img, cvPoint(cvRound(p[0]),cvRound(p[1])), cvRound(p[2]), CV_RGB(255,0,0), 3, 8, 0 );

          cout<<"圓心坐标x= "<<cvRound(p[0])<<endl<<"圓心坐标y= "<<cvRound(p[1])<<endl;

          cout<<"半徑="<<cvRound(p[2])<<endl; 

     }

     cout<<"圓數量="<<circles->total<<endl;

     cvNamedWindow( "circles", 1 );

     cvShowImage( "circles", img );

     cvWaitKey(0);

    return 0;

}

圖像特征提取的總結
圖像特征提取的總結

(未完待續)