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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

VTK修炼之道35:边缘检测_Laplace算子

發(fā)布時間:2025/3/15 编程问答 16 豆豆
生活随笔 收集整理的這篇文章主要介紹了 VTK修炼之道35:边缘检测_Laplace算子 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1.拉普拉斯算子

拉普拉斯算子是一個二階邊緣算子,即梯度的散度。拉普拉斯算子的實現(xiàn)也是通過模板實現(xiàn)。常用的拉普拉斯模板定義如下:


拉普拉斯算子計算圖像的二階導(dǎo)數(shù),對于圖像噪聲比較敏感。拉普拉斯算子的結(jié)果為標(biāo)量,表示邊緣的寬度。但是它常產(chǎn)生雙像素寬邊緣,而且不能提供方向信息,因此較少直接用于邊緣檢測。在VTK中由vtkImageLaplacian實現(xiàn)。

#include <vtkAutoInit.h> VTK_MODULE_INIT(vtkRenderingOpenGL);#include <vtkSmartPointer.h> #include <vtkJPEGReader.h> #include <vtkImageData.h> #include <vtkImageLaplacian.h> #include <vtkImageShiftScale.h> #include <vtkImageActor.h> #include <vtkRenderer.h> #include <vtkRenderWindow.h> #include <vtkRenderWindowInteractor.h> #include <vtkInteractorStyleImage.h>int main(int argc, char* argv[]) {vtkSmartPointer<vtkJPEGReader> reader =vtkSmartPointer<vtkJPEGReader>::New();reader->SetFileName("lena.jpg");reader->Update();vtkSmartPointer<vtkImageLaplacian> lapFilter =vtkSmartPointer<vtkImageLaplacian>::New();lapFilter->SetInputConnection(reader->GetOutputPort());lapFilter->SetDimensionality(2);double range[2];lapFilter->GetOutput()->GetScalarRange(range);vtkSmartPointer<vtkImageShiftScale> ShiftScale =vtkSmartPointer<vtkImageShiftScale>::New();ShiftScale->SetOutputScalarTypeToUnsignedChar();ShiftScale->SetScale(255 / (range[1] - range[0]));ShiftScale->SetShift(-range[0]);ShiftScale->SetInputConnection(lapFilter->GetOutputPort());ShiftScale->Update();vtkSmartPointer<vtkImageActor> originalActor =vtkSmartPointer<vtkImageActor>::New();originalActor->SetInputData(reader->GetOutput());vtkSmartPointer<vtkImageActor> gradActor =vtkSmartPointer<vtkImageActor>::New();gradActor->SetInputData(ShiftScale->GetOutput());double originalViewport[4] = { 0.0, 0.0, 0.5, 1.0 };double gradviewport[4] = { 0.5, 0.0, 1.0, 1.0 };vtkSmartPointer<vtkRenderer> originalRenderer =vtkSmartPointer<vtkRenderer>::New();originalRenderer->SetViewport(originalViewport);originalRenderer->AddActor(originalActor);originalRenderer->ResetCamera();originalRenderer->SetBackground(1.0, 1.0, 1.0);vtkSmartPointer<vtkRenderer> gradRenderer =vtkSmartPointer<vtkRenderer>::New();gradRenderer->SetViewport(gradviewport);gradRenderer->AddActor(gradActor);gradRenderer->ResetCamera();gradRenderer->SetBackground(1.0, 1.0, 1.0);vtkSmartPointer<vtkRenderWindow> rw =vtkSmartPointer<vtkRenderWindow>::New();rw->AddRenderer(originalRenderer);rw->AddRenderer(gradRenderer);rw->SetSize(640, 320);rw->Render();rw->SetWindowName("Edge by Laplacian");vtkSmartPointer<vtkRenderWindowInteractor> rwi =vtkSmartPointer<vtkRenderWindowInteractor>::New();vtkSmartPointer<vtkInteractorStyleImage> style =vtkSmartPointer<vtkInteractorStyleImage>::New();rwi->SetInteractorStyle(style);rwi->SetRenderWindow(renderWindow);rwi->Initialize();rwi->Start();return 0; }


vtkImageLaplacian輸入和輸出數(shù)據(jù)都是vtkImageData,與梯度算子不同,該filter的輸出圖像像素為標(biāo)量。函數(shù)SetDimensionality用于設(shè)置輸入圖像的維數(shù),默認(rèn)為2維。計算完畢后,利用vtkImageShiftScale將圖像的數(shù)據(jù)范圍變換至0-255之間。

計算結(jié)果如下圖所示:


2.參看資料

1.《C++ primer》
2.《The VTK User’s Guide – 11thEdition》
3.《The Visualization Toolkit – AnObject-Oriented Approach To 3D Graphics (4th Edition)》
4. ?張曉東, 羅火靈. VTK圖形圖像開發(fā)進(jìn)階[M]. 機(jī)械工業(yè)出版社, 2015.

總結(jié)

以上是生活随笔為你收集整理的VTK修炼之道35:边缘检测_Laplace算子的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。