日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

VTK修炼之道41:频域处理_低通滤波(理想+巴特沃兹)

發布時間:2025/3/15 编程问答 14 豆豆
生活随笔 收集整理的這篇文章主要介紹了 VTK修炼之道41:频域处理_低通滤波(理想+巴特沃兹) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.低通濾波器

低通濾波是將頻域圖像中的高頻部分濾除而通過低頻部分。圖像的邊緣和噪聲對應于頻域圖像中的高頻部分,而低通濾波的作用即是減弱這部分的能量,從而達到圖像平滑去噪的目的。

2.理想低通濾波器

最簡單的低通濾波器是理想低通濾波器,基本思想是給定一個頻率閾值,將高于該閾值的所有部分設置為0,而低于該頻率的部分保持不變。

理想是指該濾波器不能用電子元器件來實現,但是可以通過計算機來模擬。

在VTK中定義了理想低通濾波器,下面我們來看下怎么使用該濾波器來對圖像進行低通濾波:

#include <vtkAutoInit.h> VTK_MODULE_INIT(vtkRenderingOpenGL);#include <vtkSmartPointer.h> #include <vtkJPEGReader.h> #include <vtkImageFFT.h> #include <vtkImageIdealLowPass.h> #include <vtkImageData.h> #include <vtkImageRFFT.h> #include <vtkImageCast.h> #include <vtkImageExtractComponents.h> #include <vtkImageActor.h> #include <vtkRenderer.h> #include <vtkRenderWindow.h> #include <vtkRenderWindowInteractor.h>int main() {vtkSmartPointer<vtkJPEGReader> reader =vtkSmartPointer<vtkJPEGReader>::New();reader->SetFileName("lena.jpg");reader->Update();vtkSmartPointer<vtkImageFFT> fftFilter =vtkSmartPointer<vtkImageFFT>::New();fftFilter->SetInputConnection(reader->GetOutputPort());fftFilter->Update();vtkSmartPointer<vtkImageIdealLowPass> lowPassFilter =vtkSmartPointer<vtkImageIdealLowPass>::New();lowPassFilter->SetInputConnection(fftFilter->GetOutputPort());lowPassFilter->SetXCutOff(0.05);lowPassFilter->SetYCutOff(0.05);lowPassFilter->Update();vtkSmartPointer<vtkImageRFFT> rfftFilter =vtkSmartPointer<vtkImageRFFT>::New();rfftFilter->SetInputConnection(lowPassFilter->GetOutputPort());rfftFilter->Update();vtkSmartPointer<vtkImageExtractComponents> ifftExtractReal =vtkSmartPointer<vtkImageExtractComponents>::New();ifftExtractReal->SetInputConnection(rfftFilter->GetOutputPort());ifftExtractReal->SetComponents(0);vtkSmartPointer<vtkImageCast> castFilter =vtkSmartPointer<vtkImageCast>::New();castFilter->SetInputConnection(ifftExtractReal->GetOutputPort());castFilter->SetOutputScalarTypeToUnsignedChar();castFilter->Update();vtkSmartPointer<vtkImageActor> originalActor =vtkSmartPointer<vtkImageActor>::New();originalActor->SetInputData(reader->GetOutput());vtkSmartPointer<vtkImageActor> erodedActor =vtkSmartPointer<vtkImageActor>::New();erodedActor->SetInputData(castFilter->GetOutput());double leftViewport[4] = { 0.0, 0.0, 0.5, 1.0 };double rightViewport[4] = { 0.5, 0.0, 1.0, 1.0 };vtkSmartPointer<vtkRenderer> leftRenderer =vtkSmartPointer<vtkRenderer>::New();leftRenderer->AddActor(originalActor);leftRenderer->ResetCamera();leftRenderer->SetViewport(leftViewport);leftRenderer->SetBackground(1.0, 0, 0);vtkSmartPointer<vtkRenderer> rightRenderer =vtkSmartPointer<vtkRenderer>::New();rightRenderer->AddActor(erodedActor);rightRenderer->SetViewport(rightViewport);rightRenderer->ResetCamera();rightRenderer->SetBackground(1.0, 1.0, 1.0);vtkSmartPointer<vtkRenderWindow> renderWindow =vtkSmartPointer<vtkRenderWindow>::New();renderWindow->AddRenderer(rightRenderer);renderWindow->AddRenderer(leftRenderer);renderWindow->SetSize(640, 320);renderWindow->SetWindowName("Frequency_IdealLowPassFilter");vtkSmartPointer<vtkRenderWindowInteractor> interactor =vtkSmartPointer<vtkRenderWindowInteractor>::New();interactor->SetRenderWindow(renderWindow);renderWindow->Render();interactor->Start();return 0; }
首先讀入一副圖像,通過vtkImageFFT將圖像轉換到頻域空間。vtkImageIdealLowPass對頻域圖像做理想低通濾波,需要用戶設置每個方向的截斷頻率,相應的設置函數SetXCutOff()和SetYCutOff()。執行完畢后,需要通過vtkImageRFFT將處理后的頻域圖像轉換至空域圖像。需要注意的是,轉換后的圖像每個像素都是一個復數,需要vtkImageExtractComponents將該圖像的第一個分量提出出來顯示,否則圖像不能正確顯示。由于傅里葉變換輸入輸出的數據類型都是double,為了方便顯示,還需要將其轉換為Unsigned char類型,這里vtkImageCast負責類型轉換。

下面是對圖像做低通濾波的效果:


從結果看,在過濾掉圖像的高頻部分后,圖像變得模糊,丟失了許多細節,另外還可以看到圖像會存在一定的振鈴效應,這也是理想低通濾波的特點

3.巴特沃茲低通濾波器

在實際中經常使用的是巴特沃斯濾波器。巴特沃斯濾波器對應的轉移函數(可以看做是一個系數矩陣)是:


其中D(u,v)表示頻域點(u,v)到頻域圖像原點的距離,稱為截止頻率,當D(u,v) = 時,H(u,v)=0.5,即對應的頻域能量將為原來的一半。因為巴特沃斯低通濾波器在高低頻間的過渡平滑,因此不會出現明顯的振鈴效應。VTK中實現巴特沃斯低通濾波器的類是vtkImageButterworthLowPass.

其使用過程如下:

#include <vtkAutoInit.h> VTK_MODULE_INIT(vtkRenderingOpenGL);#include <vtkSmartPointer.h> #include <vtkJPEGReader.h> #include <vtkImageFFT.h> #include <vtkImageButterworthLowPass.h> #include <vtkImageRFFT.h> #include <vtkImageExtractComponents.h> #include <vtkImageCast.h> #include <vtkImageActor.h> #include <vtkRenderer.h> #include <vtkRenderWindow.h> #include <vtkRenderWindowInteractor.h> #include <vtkInteractorStyleImage.h>int main() {vtkSmartPointer<vtkJPEGReader> reader =vtkSmartPointer<vtkJPEGReader>::New();reader->SetFileName("lena.jpg");reader->Update();vtkSmartPointer<vtkImageFFT> fftFilter =vtkSmartPointer<vtkImageFFT>::New();fftFilter->SetInputConnection(reader->GetOutputPort());fftFilter->Update();vtkSmartPointer<vtkImageButterworthLowPass> lowPassFilter =vtkSmartPointer<vtkImageButterworthLowPass>::New();lowPassFilter->SetInputConnection(fftFilter->GetOutputPort());lowPassFilter->SetXCutOff(0.05);lowPassFilter->SetYCutOff(0.05);lowPassFilter->Update();vtkSmartPointer<vtkImageRFFT> rfftFilter =vtkSmartPointer<vtkImageRFFT>::New();rfftFilter->SetInputConnection(lowPassFilter->GetOutputPort());rfftFilter->Update();vtkSmartPointer<vtkImageExtractComponents> ifftExtractReal =vtkSmartPointer<vtkImageExtractComponents>::New();ifftExtractReal->SetInputConnection(rfftFilter->GetOutputPort());ifftExtractReal->SetComponents(0);vtkSmartPointer<vtkImageCast> castFilter =vtkSmartPointer<vtkImageCast>::New();castFilter->SetInputConnection(ifftExtractReal->GetOutputPort());castFilter->SetOutputScalarTypeToUnsignedChar();castFilter->Update();vtkSmartPointer<vtkImageActor> originalActor =vtkSmartPointer<vtkImageActor>::New();originalActor->SetInputData(reader->GetOutput());vtkSmartPointer<vtkImageActor> erodedActor =vtkSmartPointer<vtkImageActor>::New();erodedActor->SetInputData(castFilter->GetOutput());///double leftViewport[4] = { 0.0, 0.0, 0.5, 1.0 };double rightViewport[4] = { 0.5, 0.0, 1.0, 1.0 };vtkSmartPointer<vtkRenderer> leftRenderer =vtkSmartPointer<vtkRenderer>::New();leftRenderer->AddActor(originalActor);leftRenderer->SetViewport(leftViewport);leftRenderer->SetBackground(1.0, 0, 0);leftRenderer->ResetCamera();vtkSmartPointer<vtkRenderer> rightRenderer =vtkSmartPointer<vtkRenderer>::New();rightRenderer->AddActor(erodedActor);rightRenderer->SetViewport(rightViewport);rightRenderer->SetBackground(1.0, 1.0, 1.0);rightRenderer->ResetCamera();/vtkSmartPointer<vtkRenderWindow> rw =vtkSmartPointer<vtkRenderWindow>::New();rw->AddRenderer(leftRenderer);rw->AddRenderer(rightRenderer);rw->SetSize(640, 320);rw->SetWindowName("ButterworthLowPassExample");vtkSmartPointer<vtkRenderWindowInteractor> rwi =vtkSmartPointer<vtkRenderWindowInteractor>::New();vtkSmartPointer<vtkInteractorStyleImage> style =vtkSmartPointer<vtkInteractorStyleImage>::New();rwi->SetInteractorStyle(style);rwi->SetRenderWindow(rw);rwi->Start();return 0; }


vtkImageButterworthLowPass與理想低通濾波器的使用一樣。為了便于比較,這里設置X和Y方向的截止頻率時,與理想低通濾波器設置一致,下面是相應的執行結果:


從結果來看,巴特沃斯低通濾波器產生的圖像更為平滑,不會出現振鈴現象。

4.參看資料

1.《C++ primer》
2.《The VTK User’s Guide – 11thEdition》
3. ?張曉東, 羅火靈. VTK圖形圖像開發進階[M]. 機械工業出版社, 2015.

總結

以上是生活随笔為你收集整理的VTK修炼之道41:频域处理_低通滤波(理想+巴特沃兹)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 在哪里看毛片 | 日韩视频精品 | 四虎久久| 极品美女销魂一区二区三区 | 亚洲精品天堂成人片av在线播放 | 国产精品69久久久久孕妇欧美 | 俺也去在线视频 | 午夜激情视频 | 国产看真人毛片爱做a片 | www视频在线观看免费 | 国产精品7777777 | 97香蕉超级碰碰久久免费软件 | 日本乱码一区二区 | 日韩免费专区 | 国产精品丝袜视频 | 天天干天天操天天爱 | a天堂在线视频 | 91吃瓜今日吃瓜入口 | 中文一区在线观看 | 国产精品jizz在线观看美国 | 国产成人激情视频 | 催眠调教后宫乱淫校园 | 精品久久久一区 | 一区二区三区麻豆 | 青少年xxxxx性开放hg | a级一级黄色片 | 国产乱淫a∨片免费观看 | 无码国产精品一区二区免费16 | 91午夜视频在线观看 | 天天激情综合 | 麻豆成人精品 | 涩涩屋视频 | av一区二区不卡 | 玖玖五月| 激情久久视频 | 亚洲黄色精品 | 少妇又紧又深又湿又爽视频 | 成人毛片在线观看 | 亚洲午夜精品一区二区三区他趣 | 亚洲性天堂 | 国产91在线亚洲 | av一起看香蕉| 在线观看免费视频一区 | 成年人免费小视频 | 小视频在线看 | 香蕉视频在线视频 | 在线播放91 | 蜜臀av性久久久久蜜臀av麻豆 | 国产免费一区二区视频 | 成人你懂的 | 国产美女91呻吟求 | 国产福利在线播放 | 91官网在线| 一区二区视频在线播放 | 永久免费未满蜜桃 | 亚洲自拍偷拍精品视频 | 成人网在线免费观看 | www日韩视频 | 青草福利视频 | 久久久噜噜噜久久 | 青苹果av| 大胸奶汁乳流奶水出来h | 欧美亚洲黄色 | 男女啪啪毛片 | 欧美日韩在线视频一区 | 日本激情一区二区 | 麻豆亚洲av成人无码久久精品 | 色爱AV综合网国产精品 | 操丰满女人 | 黄色a一级 | 色播在线观看 | 亚洲熟女一区二区 | 蜜桃传媒一区二区亚洲 | 免费性视频 | 国产一区二区三区四区三区四 | 国产精品腿扒开做爽爽爽挤奶网站 | 天天操天天操天天操天天操天天操 | 91欧美日韩国产 | 夜夜爽妓女8888视频免费观看 | 日韩欧美在线观看 | 超碰成人在线免费观看 | 热久久国产精品 | 视频免费1区二区三区 | 亚洲福利国产 | 丰满少妇毛片 | 女生毛片| 污污网站在线看 | 国产毛片毛片毛片 | 成人99视频 | 欧美一级网 | 久草最新 | 国产午夜精品久久久 | 日韩精品电影在线观看 | 一区二区三区小视频 | 国产高清二区 | www.亚洲综合 | 波多野结衣一区二区三区中文字幕 | 蜜桃av噜噜一区二区三区 | 欧美精品1 |