??????? 1、cvSmooth函數用法
???????????? 定義原型
<span style="font-size:12px;"> void cvSmooth( const CvArr* src, CvArr* dst,int smoothtype=CV_GAUSSIAN,int param1, int param2, double param3, double param4 );</span>
??? src:輸入圖像.??? dst:輸出圖像.
??? smoothtype平滑方法:
CV_BLUR_NO_SCALE(簡單不帶尺度變換的模糊)-對每個象素的 param1×param2 領域求和。如果鄰域大小是變化的,可以事先利用函數 cvIntegral 計算積分圖像. 但是該選項沒有計算平均值的操作,所以比? CV_BLUR? 的運算快,但是容易溢出,因此輸入輸出圖像必須有不同的數值精度,才能保證不會溢出。 不縮放比例的simple blur 支持8位的圖像輸入,但是結果必須是?? IPL_DEPTH_16S(CV_16S)?? 或者?? IPL_DEPTH_32S(CV_32S)??? 簡單無縮放的濾波不適合? IN_PLACE? 方式:因為輸入與輸出類型必須不同。
CV_GAUSSIAN(gaussian blur) - -對圖像進行核大小為 param1×param2 的高斯卷積。
CV_MEDIAN(median blur) - -對圖像進行核大小為param1×param1 的中值濾波 (鄰域是方的)。
CV_BILATERAL(雙向濾波) - -應用雙向 3x3 濾波,彩色 sigma=param1,空間 sigma=param2.。
??? 關于雙向濾波,可參考http://www.dai.ed.ac.uk/CVonline/LOCAL_COPIES/MANDUCHI1/Bilateral_Filtering.html。
????? param1? 平滑操作的第一個參數.
????? param2? 平滑操作的第二個參數. 對于簡單/非尺度變換的高斯模糊的情況,如果param2的值為零,則表示其被設定為param1。
????? param3? 對應高斯參數的 Gaussian sigma (標準差). 如果為零,則標準差由下面的核尺寸計算:
????? sigma = (n/2 - 1)*0.3 + 0.8, 其中 n=param1 對應水平核,n=param2 對應垂直核 .? 對小的卷積核 (3×3 to 7×7) 使用如上公式所示的標準 sigma 速度會快。如果 param3 不為零,而 param1 和 param2 為零,則核大小由sigma 計算 (以保證足夠精確的操作).
?
???????? 函數 cvSmooth 可使用上面任何一種方法平滑圖像。每一種方法都有自己的特點以及局限。
???????? 沒有縮放的圖像平滑僅支持單通道圖像,并且支持8位到16位的轉換(與cvSobel和cvaplace相似)和32位浮點數到32位浮點數的變換格式。
? ? ? ?? 簡單模糊和高斯模糊支持 1- 或 3-通道, 8-比特 和 32-比特 浮點圖像。這兩種方法可以(in-place)方式處理圖像。
? ? ? ?? 中值和雙向濾波工作于 1- 或 3-通道, 8-位圖像,但是不能以 in-place 方式處理圖像.
- 中值濾波????? 中值濾波法是一種非線性平滑技術,它將每一象素點的灰度值設置為該點某鄰域窗口內的所有象素點灰度值的中值。實現方法:
- 通過從圖像中的某個采樣窗口取出奇數個數據進行排序
- 用排序后的中值取代要處理的數據即可
- 中值濾波法對消除椒鹽噪音非常有效,在光學測量條紋圖象的相位分析處理方法中有特殊作用,但在條紋中心分析方法中作用不大。中值濾波在圖像處理中,常用于用來保護邊緣信息,是經典的平滑噪聲的方法
- ????????? 中值濾波原理
????? ? ? 中值濾波是基于排序統計理論的一種能有效抑制噪聲的非線性信號處理技術,中值濾波的基本原理是把數字圖像或數字序列中一點的值用該點的一個拎域中各點值的中值代替,讓周圍的像素值接近的值,從而消除孤立的噪聲點。方法是去某種結構的二維滑動模板,將板內像素按照像素值的大小進行排序,生成單調上升(或下降)的為二維數據序列。二維中值濾波輸出為g(x,y)=med{f(x-k,y-l),(k,l∈W)} ,其中,f(x,y),g(x,y)分別為原始圖像和處理后圖像。W為二維模板,通常為2*2,3*3區域,也可以是不同的的形狀,如線狀,圓形,十字形,圓環形等。
- ???? ? ? 高斯濾波
???????? 高斯濾波實質上是一種信號的濾波器,其用途是信號的平滑處理,我們知道數字圖像用于后期應用,其噪聲是最大的問題,由于誤差會累計傳遞等原因,很多圖像處理教材會在很早的時候介紹Gauss濾波器,用于得到信噪比SNR較高的圖像(反應真實信號)。于此相關的有Gauss-Lapplace變換,其實就是為了得到較好的圖像邊緣,先對圖像做Gauss平滑濾波,剔除噪聲,然后求二階導矢,用二階導的過零點確定邊緣,在計算時也是頻域乘積=>空域卷積。
???? ? ? 濾波器就是建立的一個數學模型,通過這個模型來將圖像數據進行能量轉化,能量低的就排除掉,噪聲就是屬于低能量部分。其實編程運算的話就是一個模板運算,拿圖像的八連通區域來說,中間點的像素值就等于八連通區的像素值的均值,這樣達到平滑的效果。若使用理想濾波器,會在圖像中產生振鈴現象。采用高斯濾波器的話,系統函數是平滑的,避免了振鈴現象。
2、實例(OpenCV 2.48+VS2012)
#include<cv.h>
#include<highgui.h>
#include<stdio.h>
void main()
{IplImage* img_src = 0;IplImage* img_dst = 0;char* pictureImage = (char*)("11.bmp");img_src = cvLoadImage(pictureImage, 1);if (!img_src){printf("Could not load image file:%s", pictureImage);exit(0);}img_dst = cvCreateImage(cvGetSize(img_src), IPL_DEPTH_8U, 3);cvNamedWindow("原始圖像:", CV_WINDOW_AUTOSIZE);cvMoveWindow("原始圖像:", 100, 100);cvShowImage("原始圖像:", img_src);cvNamedWindow("簡單模糊:", CV_WINDOW_AUTOSIZE);cvMoveWindow("簡單模糊:", 200, 100);//(simple blur)簡單模糊- -對每個象素param1×param2鄰域求和并做尺度變換 1/(param1×param2)。cvSmooth(img_src, img_dst, CV_BLUR, 3, 3, 0, 0);cvShowImage("簡單模糊:", img_dst);//注意使用CV_BLUR_NO_SCALE時,原始圖像和目標圖像,他們的類型不能是一致的。IplImage* img_dst2 = 0;img_dst2 = cvCreateImage(cvGetSize(img_src), IPL_DEPTH_16S, 3);cvNamedWindow("簡單不帶尺度變換的模糊:", CV_WINDOW_AUTOSIZE);cvMoveWindow("簡單不帶尺度變換的模糊:", 300, 100);//(簡單不帶尺度變換的模糊)-對每個象素的 param1×param2 領域求和。如果鄰域大小是變化的,可以事先利用函數 cvIntegral 計算積分圖像cvSmooth(img_src, img_dst2, CV_BLUR_NO_SCALE, 3, 3, 0, 0);cvShowImage("簡單不帶尺度變換的模糊:", img_dst2);cvNamedWindow("高斯卷積:", CV_WINDOW_AUTOSIZE);cvMoveWindow("高斯卷積:", 400, 100);//對圖像進行核大小為 param1×param2 的高斯卷積。cvSmooth(img_src, img_dst, CV_GAUSSIAN, 3, 3, 0, 0);cvShowImage("高斯卷積:", img_dst);cvNamedWindow("中值濾波:", CV_WINDOW_AUTOSIZE);cvMoveWindow("中值濾波:", 500, 100);//對圖像進行核大小為param1×param1 的中值濾波 (鄰域是方的)。cvSmooth(img_src, img_dst, CV_MEDIAN, 3, 3, 0, 0);cvShowImage("中值濾波:", img_dst);// cvSmooth(pFrameMat,pFrameMat,CV_BILATERAL,3,0,0);//雙向濾波 //參數不對,改成 //cvSmooth(pFrameMat,pFrameMat,CV_BILATERAL,3,3,11,11); //試試,后面兩個參數分別代表了位置上和顏色上的sigma值,不能設為0的 cvNamedWindow("雙向濾波:", CV_WINDOW_AUTOSIZE);cvMoveWindow("雙向濾波:", 600, 100);//(雙向濾波) - -應用雙向 3x3 濾波,彩色 sigma=param1,空間 sigma=param2.。cvSmooth(img_src, img_dst, CV_BILATERAL, 3, 3, 11, 11);cvShowImage("雙向濾波:", img_dst);cvWaitKey(0);cvReleaseImage(&img_src);cvReleaseImage(&img_dst);cvDestroyWindow("原始圖像:");cvDestroyWindow("簡單不帶尺度變換的模糊:");cvDestroyWindow("高斯卷積:");cvDestroyWindow("中值濾波:");cvDestroyWindow("雙向濾波:");
}
從結果可以看出,對于椒鹽噪聲,3x3中值濾波已有很好的效果。