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
|
/*=========================================================================
Program: Visualization Toolkit
Module: vtkPMergeConnected.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 vtkPMergeConnected.h -- Merges connected voronoi tesselation regions.
//
// .SECTION Description
// This filter merges connected voroni tesselation regions based on the
// global region ID.
#ifndef vtkPMergeConnected_h
#define vtkPMergeConnected_h
#include "vtkMultiBlockDataSetAlgorithm.h"
#include "vtkPVVTKExtensionsCosmoToolsModule.h" // For export macro
class vtkMultiProcessController;
class vtkUnstructuredGrid;
class vtkIdList;
class vtkFloatArray;
class vtkIdTypeArray;
class VTKPVVTKEXTENSIONSCOSMOTOOLS_EXPORT vtkPMergeConnected :
public vtkMultiBlockDataSetAlgorithm
{
public:
static vtkPMergeConnected* New();
vtkTypeMacro(vtkPMergeConnected, vtkMultiBlockDataSetAlgorithm);
void PrintSelf(ostream& os, vtkIndent indent);
struct FaceWithKey
{
int num_pts;
vtkIdType *key, *orig;
};
struct cmp_ids;
protected:
vtkPMergeConnected();
~vtkPMergeConnected();
int RequestData(vtkInformation*, vtkInformationVector**, vtkInformationVector*);
int FillOutputPortInformation(int port, vtkInformation* info);
private:
vtkPMergeConnected(const vtkPMergeConnected&); // Not implemented.
void operator=(const vtkPMergeConnected&); // Not implemented.
//parallelism
int NumProcesses;
int MyId;
vtkMultiProcessController *Controller;
void SetController(vtkMultiProcessController *c);
//filter
void LocalToGlobalRegionId(vtkMultiProcessController *contr, vtkMultiBlockDataSet *data);
void MergeCellsOnRegionId(vtkUnstructuredGrid *ugrid, int target, vtkIdList* facestream);
float MergeCellDataOnRegionId(vtkFloatArray *data_array, vtkIdTypeArray *rid_array, vtkIdType target);
void delete_key(FaceWithKey *key);
FaceWithKey* IdsToKey(vtkIdList* ids);
};
#endif
|