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
00055 #ifndef __vtkImageReducedFFT_h
00056 #define __vtkImageReducedFFT_h
00057
00058
00059 #define VTK_PRUNEDFFT_SAMPLED 0
00060 #define VTK_PRUNEDFFT_COPIED 1
00061
00062 #include "vtkImageMRIFourierFilter.h"
00063 #include "vtkCNMRRImagingWin32Header.h"
00064
00065 class VTK_CNMRR_IMAGING_EXPORT vtkImageReducedFFT : public vtkImageMRIFourierFilter
00066 {
00067 public:
00068 static vtkImageReducedFFT *New();
00069 vtkTypeRevisionMacro(vtkImageReducedFFT,vtkImageMRIFourierFilter);
00070
00072
00073 vtkSetMacro(IFFT, int);
00074 vtkGetMacro(IFFT, int);
00075 vtkBooleanMacro(IFFT, int);
00077
00079
00080 vtkSetMacro(Operation,int);
00081 vtkGetMacro(Operation,int);
00082 void SetOperationToPrunedFFTSampled() {this->SetOperation(VTK_PRUNEDFFT_SAMPLED);};
00083 void SetOperationToPrunedFFTCopied() {this->SetOperation(VTK_PRUNEDFFT_COPIED);};
00085
00087
00090 vtkSetMacro(PrunedLength, int);
00091 vtkGetMacro(PrunedLength, int);
00093
00095
00103 int SplitExtent(int splitExt[6], int startExt[6],
00104 int num, int total);
00106
00107
00108 protected:
00109 vtkImageReducedFFT();
00110 ~vtkImageReducedFFT() {};
00111
00112 int PrunedLength;
00113 int IFFT;
00114 int Operation;
00115
00116 virtual int IterativeRequestInformation(vtkInformation* in,
00117 vtkInformation* out);
00118 virtual int IterativeRequestUpdateExtent(vtkInformation* in,
00119 vtkInformation* out);
00120
00121 void ThreadedExecute(vtkImageData *inData, vtkImageData *outData,
00122 int outExt[6], int threadId);
00123 private:
00124 vtkImageReducedFFT(const vtkImageReducedFFT&);
00125 void operator=(const vtkImageReducedFFT&);
00126 };
00127
00128 #endif