第五章终于翻篇了,看自己写的东西还是觉得思维很混乱,有些东西理解的不深入,一直处于似的非懂的状态。但是第一遍的学习希望能建立一个知识框架,了解一个大概,毕竟刚入门图像,等到第二遍的时候再细细考究每一个算法的实现。
-------------------------------------------------------------------------------------
先来了解卷积的概念与作用(转自网络):
对图像做卷积
void cvFilter2D( const CvArr* src, CvArr* dst, const CvMat* kernel, CvPoint anchor=cvPoint(-1,-1)); #define cvConvolve2D cvFilter2D
/*code*/
核心是将图像IplImage结构转换为图像数组。
#include <highgui.h> #include <cv.h> #include <stdio.h> int main(int argc,char**argv) { IplImage* src, *dst, src_f; float k[9] = { 1.0, -2.0, 1.0, 4.0, -2.0, -1.0, 4.0, -2.0, 2.0 }; //核 CvMat km = cvMat( 3, 3, CV_32FC1, k ); //构造单通道浮点矩阵,将图像IplImage结构转换为图像数组 src = cvLoadImage( argv[1] ); dst = cvCreateImage( cvGetSize(src), IPL_DEPTH_8U, 3 ); cvNamedWindow( "src", 0 ); cvShowImage( "src", src ); cvNamedWindow( "Filtering", 0 ); cvFilter2D( src, dst, &km, cvPoint( -1, -1 ) ); //设参考点为核的中心 cvShowImage( "Filtering", dst ); cvWaitKey(0); cvReleaseImage( &src ); cvReleaseImage( &dst ); return 0; }
卷积后图像