43 #ifndef __vtkImageAnisotropicDiffusion3D_h
44 #define __vtkImageAnisotropicDiffusion3D_h
47 #include "vtkImagingGeneralModule.h"
55 void PrintSelf(ostream& os, vtkIndent indent);
63 void SetNumberOfIterations(
int num);
67 vtkGetMacro(NumberOfIterations,
int);
76 vtkSetMacro(DiffusionThreshold,
double);
77 vtkGetMacro(DiffusionThreshold,
double);
82 vtkSetMacro(DiffusionFactor,
double);
83 vtkGetMacro(DiffusionFactor,
double);
88 vtkSetMacro(Faces,
int);
89 vtkGetMacro(Faces,
int);
90 vtkBooleanMacro(Faces,
int);
91 vtkSetMacro(Edges,
int);
92 vtkGetMacro(Edges,
int);
93 vtkBooleanMacro(Edges,
int);
94 vtkSetMacro(Corners,
int);
95 vtkGetMacro(Corners,
int);
96 vtkBooleanMacro(Corners,
int);
102 vtkSetMacro(GradientMagnitudeThreshold,
int);
103 vtkGetMacro(GradientMagnitudeThreshold,
int);
104 vtkBooleanMacro(GradientMagnitudeThreshold,
int);
111 int NumberOfIterations;
122 vtkInformationVector **inputVector,
123 vtkInformationVector *outputVector,
124 vtkImageData ***inData, vtkImageData **outData,
125 int extent[6],
int id);
126 void Iterate(vtkImageData *in, vtkImageData *out,
127 double ar0,
double ar1,
double ar3,
int *coreExtent,
int count);
void PrintSelf(ostream &os, vtkIndent indent)
int GradientMagnitudeThreshold
double DiffusionThreshold
edge preserving smoothing.
virtual void ThreadedRequestData(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector, vtkImageData ***inData, vtkImageData **outData, int extent[6], int threadId)
Filters that operate on pixel neighborhoods.
~vtkImageAnisotropicDiffusion3D()
static vtkImageSpatialAlgorithm * New()