/usr/include/paraview/vtkAMRDualGridHelper.h is in paraview-dev 4.0.1-1ubuntu1.
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 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkAMRDualGridHelper.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 vtkAMRDualGridHelper - Tools for processing AMR as a dual grid.
// .SECTION Description
// This helper object was developed to help the AMR dual grid connectivity
// and integration filter but I also want a dual grid iso surface filter
// so I mad it a separate class. The API needs to be improved to make
// it more generally useful.
// This class will take advantage of some meta information, if available
// from a coprocessing adaptor. If not available, it will compute the
// information.
#ifndef __vtkAMRDualGridHelper_h
#define __vtkAMRDualGridHelper_h
#include "vtkPVVTKExtensionsDefaultModule.h" //needed for exports
#include "vtkObject.h"
#include <vector>
#include <map>
class vtkDataArray;
class vtkIntArray;
class vtkIdTypeArray;
class vtkNonOverlappingAMR;
class vtkAMRDualGridHelperBlock;
class vtkAMRDualGridHelperLevel;
class vtkMultiProcessController;
class vtkImageData;
class vtkAMRDualGridHelperDegenerateRegion;
class vtkAMRDualGridHelperFace;
class vtkAMRDualGridHelperCommRequestList;
//----------------------------------------------------------------------------
class VTKPVVTKEXTENSIONSDEFAULT_EXPORT vtkAMRDualGridHelper : public vtkObject
{
public:
static vtkAMRDualGridHelper *New();
vtkTypeMacro(vtkAMRDualGridHelper,vtkObject);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// An option to turn off copying ghost values across process boundaries.
// If the ghost values are already correct, then the extra communication is
// not necessary. If this assumption is wrong, this option will produce
// cracks / seams. This is off by default.
vtkGetMacro(SkipGhostCopy, int);
vtkSetMacro(SkipGhostCopy, int);
vtkBooleanMacro(SkipGhostCopy, int);
// Description:
// Turn on/off the ability to create meshing between levels in the grid. This
// is on by default. Set this before you call initialize.
vtkGetMacro(EnableDegenerateCells, int);
vtkSetMacro(EnableDegenerateCells, int);
vtkBooleanMacro(EnableDegenerateCells, int);
// Description:
// When this option is on (the default) and a controller that supports
// asynchronous communication (like MPI) is detected, use asynchronous
// communication where appropriate. This can prevent processes from blocking
// while waiting for communication in other processes to finish.
vtkGetMacro(EnableAsynchronousCommunication, int);
vtkSetMacro(EnableAsynchronousCommunication, int);
vtkBooleanMacro(EnableAsynchronousCommunication, int);
// Description:
// The controller to use for communication.
vtkGetObjectMacro(Controller, vtkMultiProcessController);
virtual void SetController(vtkMultiProcessController *);
int Initialize(vtkNonOverlappingAMR* input);
int SetupData(vtkNonOverlappingAMR* input,
const char* arrayName);
const double* GetGlobalOrigin() { return this->GlobalOrigin;}
const double* GetRootSpacing() { return this->RootSpacing;}
int GetNumberOfBlocks() { return this->NumberOfBlocksInThisProcess;}
int GetNumberOfLevels() { return (int)(this->Levels.size());}
int GetNumberOfBlocksInLevel(int level);
vtkAMRDualGridHelperBlock* GetBlock(int level, int blockIdx);
vtkAMRDualGridHelperBlock* GetBlock(int level, int xGrid, int yGrid, int zGrid);
// Description:
// I am generalizing the code that copies lowres blocks to highres ghost regions.
// I need to do this for the clip filter (level mask).
//
// For transitions between levels, degeneracy works well to create
// and contour wedges and pyramids, but the volume fraction values
// in the high-level blocks ghost cells need to be the same
// as the closest cell in the low resolution block. These methods
// copy low values to high.
void CopyDegenerateRegionBlockToBlock(
int regionX, int regionY, int regionZ,
vtkAMRDualGridHelperBlock* lowResBlock, vtkDataArray* lowResArray,
vtkAMRDualGridHelperBlock* highResBlock, vtkDataArray* highResArray);
// Description:
// This queues up either a copy from a remote process to this process
// or a copy from this process to a remote process.
// Only the local block needs an array. LowRes block is the source.
void QueueRegionRemoteCopy(
int regionX, int regionY, int regionZ,
vtkAMRDualGridHelperBlock* lowResBlock, vtkDataArray* lowResArray,
vtkAMRDualGridHelperBlock* highResBlock, vtkDataArray* highResArray);
// Description:
// This should be called on every process. It processes the queue of region copies.
// It sends and copies the regions into blocks.
void ProcessRegionRemoteCopyQueue(bool hackLevelFlag);
// Description:
// Call this before adding regions to the queue. It clears the queue.
void ClearRegionRemoteCopyQueue();
// Description:
// It is convenient to get this here.
vtkGetStringMacro(ArrayName);
private:
vtkAMRDualGridHelper();
~vtkAMRDualGridHelper();
//BTX
char* ArrayName;
int DataTypeSize;
vtkSetStringMacro(ArrayName);
// Distributed execution
void ShareMetaData();
void ShareBlocks();
void ShareBlocksWithNeighbors(vtkIntArray *neighbors);
void ShareBlocksWithNeighborsAsynchronous(vtkIntArray *neighbors);
void ShareBlocksWithNeighborsSynchronous(vtkIntArray *neighbors);
void MarshalBlocks(vtkIntArray* buffer);
void UnmarshalBlocks(vtkIntArray *buffer);
void UnmarshalBlocksFromOne(vtkIntArray *buffer, int blockProc);
vtkMultiProcessController *Controller;
void ComputeGlobalMetaData(vtkNonOverlappingAMR* input);
void AddBlock(int level, vtkImageData* volume);
// Manage connectivity seeds between blocks.
void CreateFaces();
void FindExistingFaces(
vtkAMRDualGridHelperBlock* block,
int level, int x, int y, int z);
// Assign shared cells between blocks and meshing
// changes in level.
void AssignSharedRegions();
void AssignBlockSharedRegions(
vtkAMRDualGridHelperBlock* block, int blockLevel,
int blockX, int blockY, int blockZ);
int ClaimBlockSharedRegion(
vtkAMRDualGridHelperBlock* block,
int blockX, int blockY, int blockZ,
int regionX, int regionY, int regionZ);
int NumberOfBlocksInThisProcess;
// Cell dimension of block without ghost layers.
int StandardBlockDimensions[3];
double RootSpacing[3];
// Global origin is chosen by ignoring ghost layers.
// All indexes will be positive.
// If we complete the ghost layer on boundary blocks,
// the ghost layer will still be positive.
double GlobalOrigin[3];
// Each level will have a grid to help find neighbors.
std::vector<vtkAMRDualGridHelperLevel*> Levels;
int EnableDegenerateCells;
void ProcessRegionRemoteCopyQueueSynchronous(bool hackLevelFlag);
void SendDegenerateRegionsFromQueueSynchronous(int destProc, vtkIdType messageLength);
void ReceiveDegenerateRegionsFromQueueSynchronous(int srcProc, vtkIdType messageLength,
bool hackLevelFlag);
// NOTE: These methods are NOT DEFINED if not compiled with MPI.
void ProcessRegionRemoteCopyQueueMPIAsynchronous(bool hackLevelFlag);
void SendDegenerateRegionsFromQueueMPIAsynchronous(
int recvProc, vtkIdType messageLength,
vtkAMRDualGridHelperCommRequestList &sendList);
void ReceiveDegenerateRegionsFromQueueMPIAsynchronous(
int sendProc, vtkIdType messageLength,
vtkAMRDualGridHelperCommRequestList &receiveList);
void FinishDegenerateRegionsCommMPIAsynchronous(
bool hackLevelFlag,
vtkAMRDualGridHelperCommRequestList &sendList,
vtkAMRDualGridHelperCommRequestList &receiveList);
// Degenerate regions that span processes. We keep them in a queue
// to communicate and process all at once.
std::vector<vtkAMRDualGridHelperDegenerateRegion> DegenerateRegionQueue;
void DegenerateRegionMessageSize(vtkIdTypeArray* srcProcs, vtkIdTypeArray* destProc);
void* CopyDegenerateRegionBlockToMessage(
const vtkAMRDualGridHelperDegenerateRegion ®ion,
void* messagePtr);
const void* CopyDegenerateRegionMessageToBlock(
const vtkAMRDualGridHelperDegenerateRegion ®ion,
const void* messagePtr,
bool hackLevelFlag);
void MarshalDegenerateRegionMessage(void *messagePtr, int destProc);
void UnmarshalDegenerateRegionMessage(const void *messagePtr, int messageLength, int srcProc,
bool hackLevelFlag);
int SkipGhostCopy;
int EnableAsynchronousCommunication;
private:
vtkAMRDualGridHelper(const vtkAMRDualGridHelper&); // Not implemented.
void operator=(const vtkAMRDualGridHelper&); // Not implemented.
//ETX
};
//BTX
// I need to define this small object in the namespace of this class.
//----------------------------------------------------------------------------
// Is there a better way of defining these in the namespace?
#define vtkAMRRegionBitOwner 128
// mask: The first 7 bits are going to store the degenerate level difference.
#define vtkAMRRegionBitsDegenerateMask 127
class vtkAMRDualGridHelperBlock
{
public:
vtkAMRDualGridHelperBlock();
~vtkAMRDualGridHelperBlock();
void ResetRegionBits ();
// We assume that all blocks have ghost levels and are the same
// dimension. The vtk spy reader strips the ghost cells on
// boundary blocks (on the outer surface of the data set).
// This method adds them back.
void AddBackGhostLevels(int standardBlockDimensions[3]);
int Level;
// I am sick of looping over the grid to find the grid index
// of the blocks.
int GridIndex[3];
// This is the global index of the origin of the image.
// This is important since not all blocks have ghost layers on minimum side.
// It appears that this is the origin of the ghost pixel if the image has a ghost pixel.
int OriginIndex[3];
// The process that has the actual data (image).
int ProcessId;
// If the block is local
vtkImageData* Image;
// How are we going to index faces.
vtkAMRDualGridHelperFace* Faces[6];
void SetFace(int faceId, vtkAMRDualGridHelperFace* face);
// This is set when we have a copy of the image.
// We need to modify the ghost layers of level interfaces.
unsigned char CopyFlag;
// We have to assign cells shared between blocks so only one
// block will process them. Faces, edges and corners have to be
// considered separately (Extent does not work).
// If the two blocks are from different levels, then the higher
// level block always processes the cells. The high res cells
// are degenerate to mesh with low level neighbor cells.
// Save the assignment in the neighbor bits.
// The first bit means that this block processes these cells.
// The second bit is set when the neighbor has a lower resolution
// and points need to be placed in the lower grid.
// 3x3x3 neighborhood to get face, edge and corner neighbors.
unsigned char RegionBits[3][3][3];
// Bits 1-6 are set if faces 1-6 are on boundary of dataset
// and have no neighbors.
unsigned char BoundaryBits;
// Different algorithms need to store differnt information
// with the blocks. I could make this a vtkObject so the desctructor
// would delete it.
void* UserData;
private:
};
//----------------------------------------------------------------------------
// Material surface point in the face. The point lies on an edge of the
// dual grid and has a material fraction array.
class vtkAMRDualGridHelperSeed
{
public:
vtkAMRDualGridHelperSeed();
~vtkAMRDualGridHelperSeed(){};
// Level is supplied externally.
// This is the index of the adjacent dual point in the object.
int Index[3];
int FragmentId;
private:
};
//----------------------------------------------------------------------------
// Neighbor interfaces (Faces) default to the lowest level (resolution) block.
// We do not actually care about the neighbor blocks yet.
class vtkAMRDualGridHelperFace
{
public:
vtkAMRDualGridHelperFace();
~vtkAMRDualGridHelperFace();
// Sets Level, Origin and Normal axis from the parent block.
// Any block using the face will do as long as they have the same level.
void InheritBlockValues(vtkAMRDualGridHelperBlock* block, int faceIndex);
// This is the lowest level of the two sides of the face.
int Level;
// This is the index of the face origin.
int OriginIndex[3];
// 0 = X, 1 = Y, 2 = Z.
int NormalAxis;
// Sparse array of points for equivalence computation.
std::vector<vtkAMRDualGridHelperSeed> FragmentIds;
void AddFragmentSeed(int level, int x, int y, int z, int fragmentId);
// This is the number of blocks pointing to this face.
int UseCount;
// Decrement UseCount and delete if it hit 0.
void Unregister();
private:
};
//ETX
#endif
// VTK-HeaderTest-Exclude: vtkAMRDualGridHelper.h
|