24#ifndef vtkOverlappingAMRMetaData_h
25#define vtkOverlappingAMRMetaData_h
30#include "vtkCommonDataModelModule.h"
33VTK_ABI_NAMESPACE_BEGIN
54 void Initialize(
const std::vector<unsigned int>& blocksPerLevel)
override;
76 void GetBounds(
unsigned int level,
unsigned int id,
double* bb);
83 void SetBounds(
unsigned int level,
unsigned int id,
double* bb);
90 bool GetOrigin(
unsigned int level,
unsigned int id,
double* origin);
191 unsigned int*
GetParents(
unsigned int level,
unsigned int index,
unsigned int& numParents);
198 unsigned int*
GetChildren(
unsigned int level,
unsigned int index,
unsigned int& numChildren);
225 bool FindCell(
double q[3],
unsigned int level,
unsigned int index,
int& cellIdx);
230 bool FindGrid(
double q[3],
int level,
unsigned int& gridId);
235 bool FindGrid(
double q[3],
unsigned int& level,
unsigned int& gridId);
243 return this->AllChildren[i];
250 [[nodiscard]] vtkGetMacro(GridType,
unsigned int);
251 vtkSetMacro(GridType,
unsigned int);
268 bool HasValidOrigin()
const;
269 bool HasValidBounds()
const;
270 void UpdateBounds(
int level,
int id);
271 void AllocateBoxes(
unsigned int n);
272 void AllocateBlockBounds(
unsigned int n);
273 void CalculateParentChildRelationShip(
unsigned int level,
274 std::vector<std::vector<unsigned int>>& children,
275 std::vector<std::vector<unsigned int>>& parents);
286 std::vector<vtkAMRBox> Boxes;
289 std::vector<vtkBoundingBox> BlockBounds;
309 std::vector<std::vector<std::vector<unsigned int>>> AllChildren;
310 std::vector<std::vector<std::vector<unsigned int>>> AllParents;
Encloses a rectangular region of voxel like cells.
dynamic, self-adjusting array of double
a simple class to control print indentation
dynamic, self-adjusting array of int
Allocate and hold a VTK object.
Computes the portion of a dataset which is inside a selection.
Hold a reference to a vtkObjectBase instance.