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
00071 #ifndef __vtkImageAnisotropicDiffusion2D_h
00072 #define __vtkImageAnisotropicDiffusion2D_h
00073
00074
00075 #include "vtkImageSpatialFilter.h"
00076 class VTK_IMAGING_EXPORT vtkImageAnisotropicDiffusion2D : public vtkImageSpatialFilter
00077 {
00078 public:
00079 static vtkImageAnisotropicDiffusion2D *New();
00080 vtkTypeMacro(vtkImageAnisotropicDiffusion2D,vtkImageSpatialFilter);
00081 void PrintSelf(ostream& os, vtkIndent indent);
00082
00088 void SetNumberOfIterations(int num);
00089
00091
00092 vtkGetMacro(NumberOfIterations,int);
00094
00096
00101 vtkSetMacro(DiffusionThreshold,float);
00102 vtkGetMacro(DiffusionThreshold,float);
00104
00106
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 vtkImageAnisotropicDiffusion2D();
00137 ~vtkImageAnisotropicDiffusion2D() {};
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, int *coreExtent, int count);
00153 private:
00154 vtkImageAnisotropicDiffusion2D(const vtkImageAnisotropicDiffusion2D&);
00155 void operator=(const vtkImageAnisotropicDiffusion2D&);
00156 };
00157
00158 #endif
00159
00160
00161