当前位置:
首页 >
VTK修炼之道39:图像平滑_各向异性滤波
发布时间:2025/3/15
41
豆豆
生活随笔
收集整理的这篇文章主要介绍了
VTK修炼之道39:图像平滑_各向异性滤波
小编觉得挺不错的,现在分享给大家,帮大家做个参考.
1.各向异性扩散滤波
高斯平滑方法在平滑噪声的同时,模糊了图像的重要边缘图像。 各向异性滤波是一种基于偏微分方程的滤波技术,建立于热量的各向异性扩散理论。 各向异性滤波在图像的平坦区域选择大尺度平滑,而边缘区域则选择小尺度的平滑,在抑制噪声的同时保持了图像的边缘信息。 vtkImageAnisotropicDiffusion2D(vtkImageAnisotropicDiffusion3D)实现图像各向异性扩散滤波,代码如下: #include <vtkAutoInit.h> VTK_MODULE_INIT(vtkRenderingOpenGL);#include <vtkSmartPointer.h> #include <vtkJPEGReader.h> #include <vtkImageCast.h> #include <vtkImageAnisotropicDiffusion2D.h> #include <vtkImageActor.h> #include <vtkCamera.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");vtkSmartPointer<vtkImageAnisotropicDiffusion2D> diffusion =vtkSmartPointer<vtkImageAnisotropicDiffusion2D>::New();diffusion->SetInputConnection(reader->GetOutputPort());diffusion->SetNumberOfIterations(100);diffusion->SetDiffusionThreshold(5); //小于该阈值扩散diffusion->Update();/vtkSmartPointer<vtkImageActor> originalActor =vtkSmartPointer<vtkImageActor>::New();originalActor->SetInputData(reader->GetOutput());vtkSmartPointer<vtkImageActor> diffusionActor =vtkSmartPointer<vtkImageActor>::New();diffusionActor->SetInputData(diffusion->GetOutput());double leftViewport[4] = { 0.0, 0.0, 0.5, 1.0 };double rightViewport[4] = { 0.5, 0.0, 1.0, 1.0 };vtkSmartPointer<vtkCamera> camera =vtkSmartPointer<vtkCamera>::New();vtkSmartPointer<vtkRenderer> leftRenderer =vtkSmartPointer<vtkRenderer>::New();leftRenderer->SetViewport(leftViewport);leftRenderer->AddActor(originalActor);leftRenderer->SetBackground(1.0, 0, 0);leftRenderer->SetActiveCamera(camera);leftRenderer->ResetCamera();vtkSmartPointer<vtkRenderer> rightRenderer =vtkSmartPointer<vtkRenderer>::New();rightRenderer->SetViewport(rightViewport);rightRenderer->SetBackground(1.0, 1.0, 1.0);rightRenderer->AddActor(diffusionActor);rightRenderer->SetActiveCamera(camera);/vtkSmartPointer<vtkRenderWindow> rw =vtkSmartPointer<vtkRenderWindow>::New();rw->AddRenderer(leftRenderer);rw->AddRenderer(rightRenderer);rw->SetSize(640, 320);rw->SetWindowName("Smooth by AnistropicFilter");vtkSmartPointer<vtkRenderWindowInteractor> rwi =vtkSmartPointer<vtkRenderWindowInteractor>::New();vtkSmartPointer<vtkInteractorStyleImage> style =vtkSmartPointer<vtkInteractorStyleImage>::New();rwi->SetInteractorStyle(style);rwi->SetRenderWindow(rw);rwi->Initialize();rwi->Start();return 0; }vtkImageAnisotropicDiffusion2D类通过迭代方法实现。 其中SetNumberOfIterations()用于设置迭代的次数; 各向异性扩散滤波原理是在梯度较小的像素处进行较大幅度扩散,而在大梯度处则只进行细微的扩散。因此需要设置一个扩算的阈值DiffusionThreshold,这个阈值与图像的梯度有关。SetDiffusionThreshold()即是用来设置扩散阈值。该类中还有一个梯度标志GradientMagnitudeThreshold,用来设置梯度算子。当该标志开时梯度通过中心差分方法计算;当标志为关时,需要单独处理每个相邻像素。当像素与相邻像素梯度小于DiffusionThreshold时进行扩散处理。 下图是进行各向异性扩散滤波处理的结果:
2.参看资料
1.《C++ primer》2.《The VTK User’s Guide – 11thEdition》
3. 张晓东, 罗火灵. VTK图形图像开发进阶[M]. 机械工业出版社, 2015. 与50位技术专家面对面20年技术见证,附赠技术全景图
总结
以上是生活随笔为你收集整理的VTK修炼之道39:图像平滑_各向异性滤波的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: DAEMON Tools
- 下一篇: VTK修炼之道40:频域处理_快速傅里叶