You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

204 lines
5.7 KiB
C++

/*=========================================================================
Program: Visualization Toolkit
Module: vtkHyperTreeGridPlaneCutter.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.
=========================================================================*/
/**
* @class vtkHyperTreeGridPlaneCutter
* @brief cut an hyper tree grid volume with
* a plane and generate a polygonal cut surface.
*
*
* vtkHyperTreeGridPlaneCutter is a filter that takes as input an hyper tree
* grid and a single plane and generates the polygonal data intersection surface.
* This cut is computed at the leaf cells of the hyper tree.
* It is left as an option to decide whether the cut should be computed over
* the original AMR mesh or over its dual; in the latter case, perfect
* connectivity (i.e., mesh conformity in the FE sense) is achieved at the
* cost of interpolation to the dual of the input AMR mesh, and therefore
* of missing intersection plane pieces near the primal boundary.
*
* @sa
* vtkHyperTreeGrid vtkHyperTreeGridAlgorithm
*
* @par Thanks:
* This class was written by Philippe Pebay on a idea of Guenole Harel and Jacques-Bernard Lekien,
* 2016 This class was modified by Rogeli Grima Torres, 2016 This class was modified by
* Jacques-Bernard Lekien, 2018 This work was supported by Commissariat a l'Energie Atomique CEA,
* DAM, DIF, F-91297 Arpajon, France.
*/
#ifndef vtkHyperTreeGridPlaneCutter_h
#define vtkHyperTreeGridPlaneCutter_h
#include "vtkFiltersHyperTreeModule.h" // For export macro
#include "vtkHyperTreeGridAlgorithm.h"
class vtkCellArray;
class vtkCutter;
class vtkIdList;
class vtkPoints;
class vtkHyperTreeGridNonOrientedGeometryCursor;
class vtkHyperTreeGridNonOrientedMooreSuperCursor;
class VTKFILTERSHYPERTREE_EXPORT vtkHyperTreeGridPlaneCutter : public vtkHyperTreeGridAlgorithm
{
public:
static vtkHyperTreeGridPlaneCutter* New();
vtkTypeMacro(vtkHyperTreeGridPlaneCutter, vtkHyperTreeGridAlgorithm);
void PrintSelf(ostream&, vtkIndent) override;
//@{
/**
* Specify the plane with its [a,b,c,d] Cartesian coefficients:
* a*x + b*y + c*z = d
*/
void SetPlane(double a, double b, double c, double d);
vtkGetVector4Macro(Plane, double);
//@}
//@{
/**
* Returns 0 if plane's normal is aligned with X axis, 1 if it is aligned with Y axis, 2 if it
* is aligned with Z axis. Returns -1 if not aligned with any principal axis.
*/
vtkGetMacro(AxisAlignment, int);
//@}
//@{
/**
* Returns true if plane's normal is aligned with the corresponding axis, false elsewise.
*/
bool IsPlaneOrthogonalToXAxis() { return this->AxisAlignment == 0; }
bool IsPlaneOrthogonalToYAxis() { return this->AxisAlignment == 1; }
bool IsPlaneOrthogonalToZAxis() { return this->AxisAlignment == 2; }
//}@
//@{
/**
* Set/Get whether output mesh should be computed on dual grid
*/
vtkSetMacro(Dual, int);
vtkGetMacro(Dual, int);
vtkBooleanMacro(Dual, int);
//@}
protected:
vtkHyperTreeGridPlaneCutter();
~vtkHyperTreeGridPlaneCutter() override;
/**
* Resets every attributes to a minimal state needed for the algorithm to execute
*/
virtual void Reset();
/**
* For this algorithm the output is a vtkPolyData instance
*/
int FillOutputPortInformation(int, vtkInformation*) override;
/**
* Top-level routine to generate plane cut
*/
int ProcessTrees(vtkHyperTreeGrid*, vtkDataObject*) override;
/**
* Recursively descend into tree down to leaves, cutting primal cells
*/
void RecursivelyProcessTreePrimal(vtkHyperTreeGridNonOrientedGeometryCursor*);
/**
* Recursively decide whether cell is intersected by plane
*/
bool RecursivelyPreProcessTree(vtkHyperTreeGridNonOrientedGeometryCursor*);
/**
* Recursively descend into tree down to leaves, cutting dual cells
*/
void RecursivelyProcessTreeDual(vtkHyperTreeGridNonOrientedMooreSuperCursor*);
/**
* Check if a cursor is intersected by a plane
*/
bool CheckIntersection(double[8][3], double[8]);
// Check if a cursor is intersected by a plane.
// Don't return function evaluations
bool CheckIntersection(double[8][3]);
/**
* Compute the intersection between an edge and a plane
*/
void PlaneCut(int, int, double[8][3], int&, double[][3]);
/**
* Reorder cut points following the perimeter of the cut.
*/
void ReorderCutPoints(int, double[][3]);
/**
* Storage for the plane cutter parameters
*/
double Plane[4];
/**
* Decide whether output mesh should be a computed on dual grid
*/
int Dual;
/**
* Storage for pre-selected cells to be processed in dual mode
*/
vtkBitArray* SelectedCells;
/**
* Storage for points of output unstructured mesh
*/
vtkPoints* Points;
/**
* Storage for cells of output unstructured mesh
*/
vtkCellArray* Cells;
/**
* Storage for dual vertex indices
*/
vtkIdList* Leaves;
/**
* Storage for dual vertices at center of primal cells
*/
vtkPoints* Centers;
/**
* Cutter to be used on dual cells
*/
vtkCutter* Cutter;
/**
* material Mask
*/
vtkBitArray* InMask;
/**
* Flag computed at plane creation to know wether it is aligned with x, y or z axis
*/
int AxisAlignment;
private:
vtkHyperTreeGridPlaneCutter(const vtkHyperTreeGridPlaneCutter&) = delete;
void operator=(const vtkHyperTreeGridPlaneCutter&) = delete;
};
#endif /* vtkHyperTreeGridPlaneCutter_h */