/usr/include/paraview/vtkRectilinearGridConnectivity.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 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 | /*=========================================================================
Program: Visualization Toolkit
Module: vtkRectilinearGridConnectivity.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 vtkRectilinearGridConnectivity - Extracts material fragments from
// multi-block vtkRectilinearGrid datasets based on the selected volume
// fraction array(s) and a fraction isovalue and integrates the associated
// attributes.
//
// .SECTION Description
// Given one or multiple vtkRectilinearGrid datasets with one or multiple
// volume fraction arrays (representing some materials) and possibly other
// attributes (like pressure, density, and et al) as the cell data, this
// filter extracts fragments from the dual grids (with the aforementioned
// values as the point data) based on the (at least one) selected fraction
// array(s) in combination with a specified fraction value and integrates
// the attributes (e.g., volume, pressure, density) across the surface of
// each fragment. Each material, made up of one or multiple disconnected
// fragments, is exported to the output vtkMultiBlockDataSet as a single
// block that is a vtkPolyData storing the exterior polygons of the fragment
// (s) and the associated cell data attributes as the integrated result (of
// the fragment) in terms of the volume, pressure, density, and et al.
//
// This filter differs from a closely related filter vtkGridConnectivity in
// that the former extracts fragments at a sub-cell resolution to create
// relatively smooth surfaces while the latter works at the cell granularity
// (a whole cell is taken as either inside or outside a fragment) to cause
// staircasing artifacts. In fact, an extended 256-entry marching cubes
// LUT is designed for generating cube faces (either truncated by iso-lines
// or not) in addition to iso-triangles. These two kinds of polygons in
// combination represent the surface(s) of the greater-than-isovalue sub-
// volume(s) extracted in a cube.
//
// vtkRectilinearGridConnectivity performs fragments extraction using a
// three-level mechanism, i.e., intra-process intra-block, intra-process
// inter-block, and inter-process in increasing order, with the fragments
// extracted (in the form of polygons stored as a vtkPolyData) at a lower
// level submitted to its upper level for further extraction (specifically
// by combining multiple disconnected fragments into a single one wherever
// possible). Since a fragment is represented by means of its exterior faces
// / polygons, extracting fragments turns into the task of detecting and
// removing internal faces (an internal face is the one shared by two sub-
// volumes or fragments) in a way of combining the associated sub-volumes or
// fragments. For the fragemnts extraction conducted at any level, the
// polygons of the input (e.g., greater-than-isovalue sub-volumes resulting
// from marching cubes for the lowest level extraction) are pushed to a face
// hash (that accepts the three smallest point Ids of a polygon: triangle,
// quad, or pentagon) on a per sub-volume or fragment basis. Once the face
// hash detects an internal face, an entry is added to an equivalence set
// (by means of class vtkEquivalenceSet) to correlate the two fragment Ids
// that are attached to the two associated sub-volumes or fragments' polygons.
// After resolving the equivalence set, each face that remains in the face
// hash (internal faces are masked as invalid) is updated with a resolved
// fragment Id. In this way the original complete polygons (triangles, quads,
// pentagons) pointed to by the remaining hashed faces with the same resolved
// fragment Id are retrieved from the input vtkPolyData and hence combined by
// means of the same fragemnt Id.
//
// .SECTION See Also
// vtkGridConnectivity vtkExtractCTHPart vtkPolyData vtkRectilinearGrid
// vtkMultiBlockDataSetAlgorithm
#ifndef __vtkRectilinearGridConnectivity_h
#define __vtkRectilinearGridConnectivity_h
#include "vtkPVVTKExtensionsDefaultModule.h" //needed for exports
#include "vtkMultiBlockDataSetAlgorithm.h"
class vtkPolyData;
class vtkDoubleArray;
class vtkInformation;
class vtkEquivalenceSet;
class vtkRectilinearGrid;
class vtkInformationVector;
class vtkMultiProcessController;
class vtkIncrementalOctreePointLocator;
class vtkRectilinearGridConnectivityFaceHash;
class vtkRectilinearGridConnectivityInternal;
class VTKPVVTKEXTENSIONSDEFAULT_EXPORT vtkRectilinearGridConnectivity :
public vtkMultiBlockDataSetAlgorithm
{
public:
vtkTypeMacro( vtkRectilinearGridConnectivity,
vtkMultiBlockDataSetAlgorithm );
static vtkRectilinearGridConnectivity * New();
void PrintSelf( ostream & os, vtkIndent indent );
// Description:
// Set / get the volume fraction value [0, 1] used for extracting fragments.
vtkSetClampMacro( VolumeFractionSurfaceValue, double, 0.0, 1.0 );
vtkGetMacro( VolumeFractionSurfaceValue, double );
// Description:
// Remove all volume array names.
void RemoveAllVolumeArrayNames();
// Description:
// Remove double-type volume array names.
void RemoveDoubleVolumeArrayNames();
// Description:
// Remove float-type volume array names.
void RemoveFloatVolumeArrayNames();
// Description:
// Remove unsigned char-type volume array names.
void RemoveUnsignedCharVolumeArrayNames();
// Description:
// Add a double-type volume array name to the selection list.
void AddDoubleVolumeArrayName( char * arayName );
// Description:
// Add a float-type volume array name to the selection list.
void AddFloatVolumeArrayName( char * arayName );
// Description:
// Add an unsigned char-type volume array name to the selection list.
void AddUnsignedCharVolumeArrayName( char * arayName );
// Description:
// Add a volume array (of any type) name to the selection list.
void AddVolumeArrayName( char * arayName );
protected:
vtkRectilinearGridConnectivity();
~vtkRectilinearGridConnectivity();
int DualGridsReady;
int NumberOfBlocks;
double DataBlocksTime;
double DualGridBounds[6];
double VolumeFractionSurfaceValue;
vtkDoubleArray * FragmentValues;
vtkEquivalenceSet * EquivalenceSet;
vtkRectilinearGrid ** DualGridBlocks;
vtkMultiProcessController * Controller;
vtkRectilinearGridConnectivityFaceHash * FaceHash;
vtkRectilinearGridConnectivityInternal * Internal;
virtual vtkExecutive * CreateDefaultExecutive();
virtual int FillInputPortInformation( int, vtkInformation * );
virtual int RequestData( vtkInformation * request,
vtkInformationVector ** inputVector,
vtkInformationVector * outputVector );
// ---------------------------------------------------------------------- //
// --------------------------- Volume arrays --------------------------- //
// ---------------------------------------------------------------------- //
// Description:
// Get the number of selected volume fraction arrays.
int GetNumberOfVolumeFractionArrays();
// Description:
// Get the number of all volume arrays (not necessarily selected as the
// ones for extracting fragemnts).
int GetNumberOfVolumeArrays();
// Description:
// Get the name of a selected volume fraction array specified by arrayIdx.
const char* GetVolumeFractionArrayName( int arrayIdx );
// Description:
// This function determines whether the specified name (arayName) refers to
// a selected volume fraction array (1) or not (0).
bool IsVolumeFractionArray( const char * arayName );
// Description:
// This function determines whether the specified name (arayName) refers to
// a volume array (1) or not (0). Note the array is not necessarily a
// selected one used for extracting fragments.
bool IsVolumeArray( const char * arayName );
// Description:
// This function checks the consistency between a number (numGrids) of
// vtkRectilinearGrid blocks (recGrids, the original ones still with cell
// data attributes) in terms of the number of data attributes and specific
// data attribute array names. It also checks the consistency of multiple
// (unless one) volume fraction arrays in the data type. This function
// returns 1 for consistency and 0 for inconsistency.
int CheckVolumeDataArrays( vtkRectilinearGrid ** recGrids, int numGrids );
// ---------------------------------------------------------------------- //
// ----------- Dual grids generation and fragments extraction ----------- //
// ---------------------------------------------------------------------- //
// Description:
// Given an input vtkRectilinearGrid dataset (rectGrid) with cell data
// attributes, this function creates a dual vtkRectilinearGrid dataset with
// point data attributes.
void CreateDualRectilinearGrid
( vtkRectilinearGrid * rectGrid, vtkRectilinearGrid * dualGrid );
// Description:
// Given numBlcks vtkRectilinearGrid blocks with point data attributes
// (i.e.,the dual grid version of the original blocks with cell data
// attributes), the bounding box (boundBox) covering these blocks, and
// a selected volume fraction array specified by the material index
// (partIndx), this function extracts fragments based on this volume
// fraction array and exports the result to a vtkPolyData (polyData).
void ExtractFragments( vtkRectilinearGrid ** dualGrds, int numBlcks,
double boundBox[6], unsigned char partIndx, vtkPolyData * polyData );
// ---------------------------------------------------------------------- //
// ------------- Common functions for fragments extraction ------------- //
// ---------------------------------------------------------------------- //
// Description:
// Given the raw fragment index (fragIndx) of either an original sub-volume
// extracted from marching cubes of a block or a macro-volume (combination
// of intra-process inter-block sub-volumes), the number (numComps) of all
// integrated components (of multiple cell data attributes), and the array
// (attrVals) storing the specific integrated values, this function
// integrates the attributes based on the fragment index, specifically by
// accumulating the input integration values to the target entry (specified
// by the fragment index) of a global integration array. In this way,
// different sub-volumes or macro-volumes belonging to the same fragment
// have their integrated results summed together.
void IntegrateFragmentAttributes
( int fragIndx, int numComps, double * attrVals );
// Description:
// This function resolves the equivalence set (intra-process intra-block,
// intra-process inter-block, or inter-process), followed by the face
// fragment Ids and integrated fragment attributes.
void ResolveEquivalentFragments();
// Description:
// With the equivalence set (intra-process intra-block, intra-process inter-
// block, or inter-process) resolved in advance, this function updates each
// face / polygon stored in the face hash with a resolved fragment Id. In
// this way, polygons of multiple sub-volumes or macro-volumes that have
// different (old) fragment Ids are automatically grouped into a single
// entity (macro-volume or fragment, respectively) by being assigned with the
// same (new) fragment Id.
void ResolveFaceFragmentIds();
// Description:
// With the equivalence set (intra-process intra-block, intra-process inter-
// block, or inter-process) resolved in advance, this function integrates
// cell data attributes based on the fragment Id. Specifically, multiple
// entries (of the old array of integrated attributes) with the same fragment
// Id have their integration results summed together and are then combined
// into a single entry (of the new shortened array of integrated attributes).
void ResolveIntegratedFragmentAttributes();
// ---------------------------------------------------------------------- //
// ----------- Intra-process intra-block fragments extraction ----------- //
// ---------------------------------------------------------------------- //
// Descrption:
// Give a vtkRectilinearGrid data block (rectGrid, the dual version of an
// original input block) with point data attributes (including some volume
// fraction arrays and others like pressure, density, or velocity vector),
// the name of a selected volume fraction array (fracName, through which to
// extract fragments), and a specified volume fraction iso-value (isoValue),
// this function performs the marching-cubes algorithm based on the volume
// fraction array and the iso-value to produce greater-than-isovalue sub-
// volumes (or polyhedra) by employing an extended 256-entry lookup table.
// These resulting polyhedra are stored in the output vtkPolyData (plyHedra).
// All point data attribues except for non-selected volume fraction arrays
// are integrated when marching cubes. The integrated attribute arrays are
// attached to the polyhedra's faces as the cell data.
void ExtractFragmentPolyhedra( vtkRectilinearGrid * rectGrid,
const char * fracName, double isoValue, vtkPolyData * plyHedra );
// Description:
// Given a vtkPolyData (plyHedra) storing the polygons of the greater-than-
// isovalue sub-volumes (or polyhedra) extracted from a data block, this
// function initializes the size of the face hash (with the number of points
// of the polyhedra) used to maintain the polygons of the polyhedra.
void InitializeFaceHash( vtkPolyData * plyHedra );
// Description:
// Given a data block index (blockIdx) and a vtkPolyData (plyHedra) storing
// the polygons of the greater-than-isovalue sub-volumes (or polyhedra) that
// are extracted from the block, this function pushes the polygons on a per
// sub-volume basis to the face hash (the sub-volume Ids are used to group
// polygons into sub-volumes). For each internal polygon / face shared by
// two sub-volumes, an entry is added to the (intra-process intra-block)
// equivalence set to associate the fragment Ids assigned to the two sub-
// volumes' polygons.
void AddPolygonsToFaceHash( int blockIdx, vtkPolyData * plyHedra );
// Description:
// Given the index of the data block (blockIdx), the vtkPolyData (plyHedra)
// storing the polygons / faces of the greater-than-isovalue sub-volumes
// (or polyhedra) extracted from this block via marching cubes, and a global
// (intra-process inter-block) point locator, the function extracts fragments
// from this block by initializing the face hash with the raw polygons
// extracted from the block (via marching cubes), pushing these polygons to
// the face hash on a per sub-volume basis, detecting internal faces or
// polygons, registering faces to the intra-process intra-block equivalence
// set by the intermediate fragment Id, resolving the equivalence set,
// updating the fragment Id of each polygon, and integrating cell data
// attributes based on the fragment Id, grouping / re-arranging the 'valid'
// faces (as opposed to those removed internal faces) in the face hash by the
// fragment Id (to construct macro-volumes), accessing the full version of
// each valid face from the original polyhedra, and attaching the fragment Id
// as well as other integrated cell data attributes to each cell in the output
// vtkPolyData data (polygons) where each point is assigned with a global
// (intra-process inter-block) Id (via a global point locator gPtIdGen) used
// for subsequent combination of fragments extracted from multiple blocks.
// Argument maxFSize returns the maximum number of faces a macro-volume
// (combination of sub-volumes) may contain in a block.
void ExtractFragmentPolygons( int blockIdx, int & maxFsize,
vtkPolyData * plyHedra, vtkPolyData * polygons,
vtkIncrementalOctreePointLocator * gPtIdGen );
// ---------------------------------------------------------------------- //
// ----------- Intra-process inter-block fragments extraction ----------- //
// ---------------------------------------------------------------------- //
// Description:
// Given a number (numPolys) of vtkPolyData objects (plyDatas) storing the
// fragments extracted from the multiple data blocks, this function inits
// the face hash (with the maximum global inter-block point Id: a point data
// attribute attached to each point of these vtkPolyData objects) that is
// used to combine these intermediate fragments.
void InitializeFaceHash( vtkPolyData ** plyDatas, int numPolys );
// Description:
// Given a number (numPolys) of vtkPolyData objects (plyDatas) storing the
// initial fragments (macro-volumes --- combination of greater-than-isovalue
// sub-volumes) extracted from multiple blocks and an array of values
// (maxFsize) storing the maximum number of faces that a macro-volume may
// contain in each block (used to allocate appropriate memory for buffering
// the polygons of a macro-volume), this function pushes these polygons on a
// per macro-volume basis to the face hash (fragment Ids are used to group
// polygons to macro-volumes), detects internal faces / polygons, and then
// registers polygons to the (intra-process inter-block) equivalence set by
// the intermediate fragment Id. For each internal polygon / face shared by
// two macro-volumes, an entry is added to the equivalence set to associate
// the fragment Ids assigned to the two macro-volumes' polygons.
void AddPolygonsToFaceHash
( vtkPolyData ** plyDatas, int * maxFsize, int numPolys );
// Description:
// With the intra-process inter-block equivalence set resolved, intra-process
// inter-block fragment Ids resolved, and cell data attributes integrated by
// the fragment Id, this function retrieves the face hash for the 'valid'
// faces (as opposed to those removed internal faces), accesses their full
// version from the vtkPolyData objects ('surfaces') that store the polygons
// of intermediate fragments extracted from multiple ('numSurfs') data blocks,
// and exports these complete yet 'valid' polygons to the output vtkPolyData
// ('polyData') while attaching the index of the material (partIndx, i.e. the
// volume fraction array used to extract fragments) to each polygon as a cell
// data attribute. In a word, this function exports a combined version of the
// fragements extracted from multiple blocks assigned to a single process.
void GenerateOutputFromSingleProcess( vtkPolyData ** surfaces, int numSurfs,
unsigned char partIndx, vtkPolyData * polyData );
// ---------------------------------------------------------------------- //
// ----------------- Inter-process fragments extraction ----------------- //
// ---------------------------------------------------------------------- //
// Description:
// Given the vtkPolyData (fragPoly) storing the fragments extracted from a
// single process (assigned with either one block or multiple blocks), this
// function groups / re-arranges the polygons by the (intra-process inter-
// block) fragment Id, determines the maximum number (maxFsize) of polygons
// (belonging to a fragment) with the same fragment Id, and exports the re-
// arranged polygons with the associated fragment Ids and all integrated cell
// data attributes to the output inter-process vtkPolyData (procPoly) where
// each point is assigned with a global inter-process point Id (through a
// global point locator 'gPtIdGen') as the point data attribute used later
// for combining the fragments across multiple processes.
void CreateInterProcessPolygons
( vtkPolyData * fragPoly, vtkPolyData * procPoly,
vtkIncrementalOctreePointLocator * gPtIdGen, int & maxFsize );
// Description:
// Given a number (numProcs) of vtkPolyData objects (procPlys) storing the
// (initial) fragments extracted from multiple processes and an array of
// values (maxFsize) storing the maximum number of faces that an initial
// fragment may contain on each process (used to allocate appropriate memory
// for buffering the polygons of an intial fragment), this function pushes
// these polygons to the face hash on a per fragment basis (the fragment Ids
// are used to group polygons into initial fragments), detects internal faces
// / polygons, and registers polygons to the inter-process equivalence set by
// the intermediate fragment Id. For each internal polygon / face shared by
// two initial fragments, an entry is added to the equivalence set in a way to
// associate the fragment Ids assigned to the two initial fragments' polygons.
// Note each face in the face hash is assigned with a process Id that is used
// later to retrieve the source vtkPolyData for the target complete polygon
// if the face remains in the face hash after removing internal faces.
void AddInterProcessPolygonsToFaceHash
( vtkPolyData ** procPlys, int * maxFsize, int numProcs );
// Description:
// With the inter-process equivalence set resolved, inter-process fragment
// Ids resolved, and cell data attributes integrated by the fragment Id, this
// function retrieves the face hash for the 'valid' faces (as opposed to the
// removed internal faces), accesses their complete version (according to the
// information stored in the face) from the vtkPolyData objects (procPlys)
// that store the polygons of the fragments extracted from multiple (numProcs)
// processes, and exports these complete 'valid' polygons to the output
// vtkPolyData (polyData) while attaching the index of the material (partIndx,
// corresponding to the volume fraction array used to extract the fragments)
// to each polygon as a cell data attribute. In a word, this function exports
// a combined version of the fragements extracted from multiple processes (of
// which each is assigned with either one block or multiple blocks).
void GenerateOutputFromMultiProcesses( vtkPolyData ** procPlys,
int numProcs, unsigned char partIndx, vtkPolyData * polyData );
private:
vtkRectilinearGridConnectivity
( const vtkRectilinearGridConnectivity & ); // Not implemented.
void operator = ( const vtkRectilinearGridConnectivity & ); // Not implemented.
};
#endif
|