00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00072 #ifndef __vtkImageAnisotropicDiffusion3D_h
00073 #define __vtkImageAnisotropicDiffusion3D_h
00074
00075
00076 #include "vtkImageSpatialFilter.h"
00077
00078 class VTK_IMAGING_EXPORT vtkImageAnisotropicDiffusion3D : public vtkImageSpatialFilter
00079 {
00080 public:
00081 static vtkImageAnisotropicDiffusion3D *New();
00082 vtkTypeMacro(vtkImageAnisotropicDiffusion3D,vtkImageSpatialFilter);
00083 void PrintSelf(ostream& os, vtkIndent indent);
00084
00085
00091 void SetNumberOfIterations(int num);
00092
00094
00095 vtkGetMacro(NumberOfIterations,int);
00097
00099
00104 vtkSetMacro(DiffusionThreshold,float);
00105 vtkGetMacro(DiffusionThreshold,float);
00107
00109
00110 vtkSetMacro(DiffusionFactor,float);
00111 vtkGetMacro(DiffusionFactor,float);
00113
00115
00116 vtkSetMacro(Faces,int);
00117 vtkGetMacro(Faces,int);
00118 vtkBooleanMacro(Faces,int);
00119 vtkSetMacro(Edges,int);
00120 vtkGetMacro(Edges,int);
00121 vtkBooleanMacro(Edges,int);
00122 vtkSetMacro(Corners,int);
00123 vtkGetMacro(Corners,int);
00124 vtkBooleanMacro(Corners,int);
00126
00128
00130 vtkSetMacro(GradientMagnitudeThreshold,int);
00131 vtkGetMacro(GradientMagnitudeThreshold,int);
00132 vtkBooleanMacro(GradientMagnitudeThreshold,int);
00134
00135 protected:
00136 vtkImageAnisotropicDiffusion3D();
00137 ~vtkImageAnisotropicDiffusion3D() {};
00138
00139 int NumberOfIterations;
00140 float DiffusionThreshold;
00141 float DiffusionFactor;
00142
00143 int Faces;
00144 int Edges;
00145 int Corners;
00146
00147 int GradientMagnitudeThreshold;
00148
00149 void ThreadedExecute(vtkImageData *inData, vtkImageData *outData,
00150 int extent[6], int id);
00151 void Iterate(vtkImageData *in, vtkImageData *out,
00152 float ar0, float ar1, float ar3, int *coreExtent, int count);
00153 private:
00154 vtkImageAnisotropicDiffusion3D(const vtkImageAnisotropicDiffusion3D&);
00155 void operator=(const vtkImageAnisotropicDiffusion3D&);
00156 };
00157
00158 #endif
00159
00160
00161