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
00058 #ifndef __vtkImageDPT_h
00059 #define __vtkImageDPT_h
00060
00061 #include "vtkImageMultipleInputFilter.h"
00062 #include "vtkImageMRIFourierFilter.h"
00063 #include "vtkCNMRRImagingWin32Header.h"
00064
00065 class VTK_CNMRR_IMAGING_EXPORT vtkImageDPT : public vtkImageMultipleInputFilter
00066 {
00067 public:
00068 static vtkImageDPT *New();
00069 vtkTypeRevisionMacro(vtkImageDPT,vtkImageMultipleInputFilter);
00070 void PrintSelf(ostream& os, vtkIndent indent);
00071
00073 static int isPowerOf2(int size){return size > 0 && (size & (size - 1)) == 0;};
00074
00076 static int findPowerOf2(int size);
00077
00079
00082 void SetDimensionality(int dim);
00083 vtkGetMacro(Dimensionality,int);
00085
00089 void DPT(vtkImageComplexNumber *eta0, vtkImageComplexNumber *out, int m);
00090
00091 protected:
00092
00093 vtkImageDPT();
00094 ~vtkImageDPT() {};
00095
00096 int Dimensionality;
00097
00098 void ExecuteInformation(vtkImageData **inputs, vtkImageData *output);
00099
00100 void ExecuteInformation(){this->vtkImageMultipleInputFilter::ExecuteInformation();};
00101
00102 void ThreadedExecute(vtkImageData **inDatas, vtkImageData *outData,
00103 int extent[6], int id);
00104
00105 void InitOutput(int outExt[6], vtkImageData *outData);
00106
00107 private:
00108 vtkImageDPT(const vtkImageDPT&);
00109 void operator=(const vtkImageDPT&);
00110 };
00111
00112 #endif