/usr/include/vtk-6.3/vtkAMRInformation.h is in libvtk6-dev 6.3.0+dfsg1-5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkAMRInformation.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
// .NAME vtkAMRInformation - Meta data that describes the structure of an AMR data set
//
// .SECTION Description
// vtkAMRInformation encaspulates the following meta information for an AMR data set
// - a list of vtkAMRBox objects
// - Refinement ratio between AMR levels
// - Grid spacing for each level
// - The file block index for each block
// - parent child information, if requested
//
// .SECTION See Also
// vtkOverlappingAMR, vtkAMRBox
#ifndef vtkAMRInformation_h
#define vtkAMRInformation_h
#include "vtkCommonDataModelModule.h" // For export macro
#include "vtkObject.h"
#include "vtkAMRBox.h" //for storing AMR Boxes
#include "vtkSmartPointer.h" //for ivars
#include <vector> //for storing AMR Boxes
typedef std::vector<vtkAMRBox> vtkAMRBoxList;
class vtkUnsignedIntArray;
class vtkIntArray;
class vtkDoubleArray;
class vtkAMRIndexIterator;
class VTKCOMMONDATAMODEL_EXPORT vtkAMRInformation : public vtkObject
{
public:
static vtkAMRInformation* New();
vtkTypeMacro(vtkAMRInformation, vtkObject);
void PrintSelf(ostream& os, vtkIndent indent);
bool operator==(const vtkAMRInformation& other);
//Description
//Initialize the meta information
// numLevels is the number of levels
// blocksPerLevel[i] is the number of blocks at level i
void Initialize(int numLevels, const int* blocksPerLevel);
// Description:
// returns the value of vtkUniformGrid::GridDescription() of any block
vtkGetMacro( GridDescription, int );
void SetGridDescription(int description);
// Description:
// Get the AMR dataset origin
// The origin is essentially the minimum of all the grids.
void GetOrigin( double origin[3] );
double* GetOrigin();
void SetOrigin(const double* origin);
// Description:
// Return the number of levels
unsigned int GetNumberOfLevels() const
{ return static_cast<unsigned int>(this->NumBlocks.size()-1);}
// Description:
// Returns the number of datasets at the given levelx
unsigned int GetNumberOfDataSets(unsigned int level) const;
// Description:
// Returns total number of datasets
unsigned int GetTotalNumberOfBlocks()
{ return this->NumBlocks.back();}
// Description:
// Returns the single index from a pair of indices
int GetIndex(unsigned int level, unsigned int id) const
{ return this->NumBlocks[level] + id;}
// Description:
// Returns the an index pair given a single index
void ComputeIndexPair(unsigned int index, unsigned int& level, unsigned int& id);
// Description
// Returns the bounds of the entire domain
const double* GetBounds();
// Description
// Returns the bounding box of a given box
void GetBounds(unsigned int level, unsigned int id, double* bb);
// Description
// Returns the origin of the grid at (level,id)
bool GetOrigin(unsigned int level, unsigned int id, double* origin);
//Description
//Return the spacing at the given fiven
void GetSpacing(unsigned int level, double spacing[3]);
bool HasSpacing(unsigned int level);
// Description:
// Methods to set and get the AMR box at a given position
void SetAMRBox(unsigned int level, unsigned int id, const vtkAMRBox& box);
const vtkAMRBox& GetAMRBox(unsigned int level, unsigned int id) const;
// Description
// return the amr box coarsened to the previous level
bool GetCoarsenedAMRBox(unsigned int level, unsigned int id, vtkAMRBox& box) const;
// Description:
// Get/Set the SourceIndex of a block. Typically, this is a file-type specific index
// that can be used by a reader to load a particular file block
int GetAMRBlockSourceIndex(int index);
void SetAMRBlockSourceIndex(int index, int sourceId);
// Description:
// This method computes the refinement ratio at each level.
// At each level, l, the refinement ratio r_l is computed by
// r_l = D_{l} / D_{l+1}, where D_{l+1} and D_{l} are the grid
// spacings at the next and current level respectively.
//
// .SECTION Assumptions
// 1) Within each level, the refinement ratios are the same for all blocks.
// 2) The refinement ratio is uniform along each dimension of the block.
void GenerateRefinementRatio();
// Description:
// Returns Wether refinement ratio has been set (either by calling
// GenerateRefinementRatio() or by calling SetRefinementRatio()
bool HasRefinementRatio();
// Description:
// Set the refinement ratio at a level. This method should be
// called for all levels, if called at all.
void SetRefinementRatio(unsigned int level, int ratio);
// Description:
// Returns the refinement of a given level.
int GetRefinementRatio(unsigned int level) const;
// Description:
// Set the spacing at a given level
void SetSpacing(unsigned int level,const double* h);
//Description:
//Return whether parent child information has been generated
bool HasChildrenInformation();
// Description:
// Return a pointer to Parents of a block. The first entry is the number
// of parents the block has followed by its parent ids in level-1.
// If none exits it returns NULL.
unsigned int *GetParents(unsigned int level, unsigned int index, unsigned int& numParents);
// Description:
// Return a pointer to Children of a block. The first entry is the number
// of children the block has followed by its childern ids in level+1.
// If none exits it returns NULL.
unsigned int *GetChildren(unsigned int level, unsigned int index, unsigned int& numChildren);
// Description:
// Prints the parents and children of a requested block (Debug Routine)
void PrintParentChildInfo(unsigned int level, unsigned int index);
//Description:
// Generate the parent/child relationships - needed to be called
// before GetParents or GetChildren can be used!
void GenerateParentChildInformation();
// Description:
// Checks whether the meta data is internally consistent.
bool Audit();
// Description:
//Given a point q, find whether q is bounded by the data set at
//(level,index). If it is, set cellIdx to the cell index and return
//true; otherwise return false
bool FindCell(double q[3],unsigned int level, unsigned int index,int &cellIdx);
// Description:
//find the grid that contains the point q at the specified level
bool FindGrid(double q[3], int level, unsigned int& gridId);
//Description
//Given a point q, find the highest level grid that contains it.
bool FindGrid(double q[3], unsigned int& level, unsigned int& gridId);
// Description:
// Returns internal arrays.
const std::vector<int>& GetNumBlocks() const
{ return this->NumBlocks;}
std::vector<std::vector<unsigned int> >& GetChildrenAtLevel(unsigned int i)
{ return this->AllChildren[i];}
void DeepCopy(vtkAMRInformation *other);
private:
vtkAMRInformation();
~vtkAMRInformation();
vtkAMRInformation(const vtkAMRInformation&); // Not implemented.
void operator=(const vtkAMRInformation&); // Not implemented.
bool HasValidOrigin();
bool HasValidBounds();
void UpdateBounds(const int level, const int id);
void AllocateBoxes(unsigned int n);
void GenerateBlockLevel();
void CalculateParentChildRelationShip( unsigned int level,
std::vector<std::vector<unsigned int> >& children,
std::vector<std::vector<unsigned int> >& parents );
//-------------------------------------------------------------------------
// Essential information that determines an AMR structure. Must be copied
//-------------------------------------------------------------------------
int GridDescription; //example: VTK_XYZ_GRID
double Origin[3]; //the origin of the whole data set
vtkAMRBoxList Boxes; // vtkAMRBoxes, one per data set
std::vector<int> NumBlocks; //NumBlocks[i] stores the total number of blocks from level 0 to level i-1
vtkSmartPointer<vtkIntArray> SourceIndex; //Typically, this maps to a file block index used by the reader
vtkSmartPointer<vtkDoubleArray> Spacing; //The grid spacing for all levels
double Bounds[6]; //the bounds of the entire domain
//-------------------------------------------------------------------------
// Auxillary information that be computed
//-------------------------------------------------------------------------
vtkSmartPointer<vtkIntArray> Refinement; //refinement ratio between two adjacent levels
vtkSmartPointer<vtkUnsignedIntArray> BlockLevel; //only necessary if need to call ComputeIndexPair
//parent child information
std::vector<std::vector<std::vector<unsigned int> > > AllChildren;
std::vector<std::vector<std::vector<unsigned int> > > AllParents;
};
#endif
|