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
00039
00055 #ifndef __vtkExtentTranslator_h
00056 #define __vtkExtentTranslator_h
00057
00058 #include "vtkObject.h"
00059
00060
00061 class VTK_COMMON_EXPORT vtkExtentTranslator : public vtkObject
00062 {
00063 public:
00064 static vtkExtentTranslator *New();
00065
00066 vtkTypeMacro(vtkExtentTranslator,vtkObject);
00067 void PrintSelf(ostream& os, vtkIndent indent);
00068
00070
00072 vtkSetVector6Macro(WholeExtent, int);
00073 vtkGetVector6Macro(WholeExtent, int);
00074 vtkSetVector6Macro(Extent, int);
00075 vtkGetVector6Macro(Extent, int);
00076 vtkSetMacro(Piece,int);
00077 vtkGetMacro(Piece,int);
00078 vtkSetMacro(NumberOfPieces,int);
00079 vtkGetMacro(NumberOfPieces,int);
00080 vtkSetMacro(GhostLevel, int);
00081 vtkGetMacro(GhostLevel, int);
00083
00085
00090 virtual int PieceToExtent();
00091 virtual int PieceToExtentByPoints();
00092 virtual int PieceToExtentThreadSafe(int piece, int numPieces,
00093 int ghostLevel, int *wholeExtent,
00094 int *resultExtent, int splitMode,
00095 int byPoints);
00097
00098
00099
00101
00105 void SetSplitModeToBlock()
00106 {this->SplitMode = vtkExtentTranslator::BLOCK_MODE;}
00107 void SetSplitModeToXSlab()
00108 {this->SplitMode = vtkExtentTranslator::X_SLAB_MODE;}
00109 void SetSplitModeToYSlab()
00110 {this->SplitMode = vtkExtentTranslator::Y_SLAB_MODE;}
00111 void SetSplitModeToZSlab()
00112 {this->SplitMode = vtkExtentTranslator::Z_SLAB_MODE;}
00113 vtkGetMacro(SplitMode,int);
00115
00116 protected:
00117 vtkExtentTranslator();
00118 ~vtkExtentTranslator();
00119
00121
00123 int SplitExtent(int piece, int numPieces, int *extent, int splitMode);
00124 int SplitExtentByPoints(int piece, int numPieces, int *extent,
00125 int splitMode);
00127
00128 int Piece;
00129 int NumberOfPieces;
00130 int GhostLevel;
00131 int Extent[6];
00132 int WholeExtent[6];
00133 int SplitMode;
00134
00135
00136
00137
00138 enum Modes {
00139 X_SLAB_MODE=0,
00140 Y_SLAB_MODE=1,
00141 Z_SLAB_MODE=2,
00142 BLOCK_MODE= 3
00143 };
00144
00145
00146 private:
00147 vtkExtentTranslator(const vtkExtentTranslator&);
00148 void operator=(const vtkExtentTranslator&);
00149 };
00150
00151 #endif
00152