indexedOctree< Type > Class Template Reference

Non-pointer based hierarchical recursive searching. More...

Inheritance diagram for indexedOctree< Type >:
[legend]
Collaboration diagram for indexedOctree< Type >:
[legend]

Classes

class  node
 Tree node. Has up pointer and down pointers. More...
 

Public Member Functions

 indexedOctree (const Type &shapes)
 Construct null. More...
 
 indexedOctree (const Type &shapes, const List< node > &nodes, const labelListList &contents)
 Construct from components. More...
 
 indexedOctree (const Type &shapes, const treeBoundBox &bb, const label maxLevels, const scalar maxLeafRatio, const scalar maxDuplicity)
 Construct from shapes. More...
 
 indexedOctree (const Type &shapes, Istream &is)
 Construct from Istream. More...
 
autoPtr< indexedOctree< Type > > clone () const
 Clone. More...
 
const Type & shapes () const
 Reference to shape. More...
 
const List< node > & nodes () const
 List of all nodes. More...
 
const labelListListcontents () const
 List of all contents (referenced by those nodes that are. More...
 
const treeBoundBoxbb () const
 Top bounding box. More...
 
PackedList< 2 > & nodeTypes () const
 Per node, per octant whether is fully inside/outside/mixed. More...
 
pointIndexHit findNearest (const point &sample, const scalar nearestDistSqr) const
 
template<class FindNearestOp >
pointIndexHit findNearest (const point &sample, const scalar nearestDistSqr, const FindNearestOp &fnOp) const
 Calculate nearest point on nearest shape. More...
 
template<class FindNearestOp >
void findNearest (const label nodeI, const point &, scalar &nearestDistSqr, label &nearestShapeI, point &nearestPoint, const FindNearestOp &fnOp) const
 Low level: calculate nearest starting from subnode. More...
 
pointIndexHit findNearest (const linePointRef &ln, treeBoundBox &tightest, point &linePoint) const
 Find nearest to line. More...
 
template<class FindNearestOp >
pointIndexHit findNearest (const linePointRef &ln, treeBoundBox &tightest, point &linePoint, const FindNearestOp &fnOp) const
 
pointIndexHit findLine (const point &start, const point &end) const
 Find nearest intersection of line between start and end. More...
 
pointIndexHit findLineAny (const point &start, const point &end) const
 Find any intersection of line between start and end. More...
 
template<class FindIntersectOp >
pointIndexHit findLine (const point &start, const point &end, const FindIntersectOp &fiOp) const
 Find nearest intersection of line between start and end. More...
 
template<class FindIntersectOp >
pointIndexHit findLineAny (const point &start, const point &end, const FindIntersectOp &fiOp) const
 Find any intersection of line between start and end. More...
 
labelList findBox (const treeBoundBox &bb) const
 Find (in no particular order) indices of all shapes inside or. More...
 
labelList findSphere (const point &centre, const scalar radiusSqr) const
 Find (in no particular order) indices of all shapes inside or. More...
 
labelBits findNode (const label nodeI, const point &) const
 Find deepest node (as parent+octant) containing point. Starts. More...
 
label findInside (const point &) const
 Find shape containing point. Only implemented for certain. More...
 
const labelListfindIndices (const point &) const
 Find the shape indices that occupy the result of findNode. More...
 
volumeType getVolumeType (const point &) const
 Determine type (inside/outside/mixed) for point. unknown if. More...
 
template<class CompareOp >
void findNear (const scalar nearDist, const indexedOctree< Type > &tree2, CompareOp &cop) const
 Find near pairs and apply CompareOp to them. More...
 
void print (prefixOSstream &, const bool printContents, const label) const
 Print tree. Either print all indices (printContent = true) or. More...
 
bool write (Ostream &os) const
 
template<class FindIntersectOp >
Foam::pointIndexHit findLine (const bool findAny, const point &treeStart, const point &treeEnd, const label startNodeI, const direction startOctant, const FindIntersectOp &fiOp, const bool verbose) const
 
template<class FindIntersectOp >
Foam::pointIndexHit findLine (const bool findAny, const point &start, const point &end, const FindIntersectOp &fiOp) const
 
template<class FindNearestOp >
Foam::pointIndexHit findNearest (const point &sample, const scalar startDistSqr, const FindNearestOp &fnOp) const
 
template<class FindNearestOp >
Foam::pointIndexHit findNearest (const linePointRef &ln, treeBoundBox &tightest, point &linePoint, const FindNearestOp &fnOp) const
 
template<class FindIntersectOp >
Foam::pointIndexHit findLine (const point &start, const point &end, const FindIntersectOp &fiOp) const
 
template<class FindIntersectOp >
Foam::pointIndexHit findLineAny (const point &start, const point &end, const FindIntersectOp &fiOp) const
 

Static Public Member Functions

static scalar & perturbTol ()
 Get the perturbation tolerance. More...
 
static bool isContent (const labelBits i)
 
static bool isEmpty (const labelBits i)
 
static bool isNode (const labelBits i)
 
static label getContent (const labelBits i)
 
static label getNode (const labelBits i)
 
static direction getOctant (const labelBits i)
 
static volumeType getSide (const vector &outsideNormal, const vector &vec)
 Helper function to return the side. Returns outside if. More...
 
static bool overlaps (const point &bbMin, const point &bbMax, const scalar nearestDistSqr, const point &sample)
 Helper: does bb intersect a sphere around sample? Or is any. More...
 

Friends

Ostreamoperator (Ostream &, const indexedOctree< Type > &)
 

Detailed Description

template<class Type>
class Foam::indexedOctree< Type >

Non-pointer based hierarchical recursive searching.

Source files

Definition at line 71 of file indexedOctree.H.

Constructor & Destructor Documentation

◆ indexedOctree() [1/4]

indexedOctree ( const Type &  shapes)

Construct null.

Definition at line 2170 of file indexedOctree.C.

◆ indexedOctree() [2/4]

indexedOctree ( const Type &  shapes,
const List< node > &  nodes,
const labelListList contents 
)

Construct from components.

Definition at line 2180 of file indexedOctree.C.

◆ indexedOctree() [3/4]

indexedOctree ( const Type &  shapes,
const treeBoundBox bb,
const label  maxLevels,
const scalar  maxLeafRatio,
const scalar  maxDuplicity 
)

Construct from shapes.

Definition at line 2195 of file indexedOctree.C.

References List< T >::append(), indexedOctree< Type >::bb(), indexedOctree< Type >::contents(), Foam::endl(), forAll, Foam::identity(), Foam::max(), Foam::nl, indexedOctree< Type >::nodes(), Foam::Pout, List< T >::setSize(), indexedOctree< Type >::shapes(), memInfo::size(), and UList< T >::size().

Here is the call graph for this function:

◆ indexedOctree() [4/4]

indexedOctree ( const Type &  shapes,
Istream is 
)

Construct from Istream.

Definition at line 2367 of file indexedOctree.C.

Member Function Documentation

◆ perturbTol()

Foam::scalar & perturbTol
static

Get the perturbation tolerance.

Definition at line 2383 of file indexedOctree.C.

Referenced by triSurfaceMesh::edgeTree(), triSurfaceSearch::findLine(), triSurfaceSearch::findLineAll(), triSurfaceSearch::findLineAny(), triSurfaceSearch::findNearest(), triSurfaceMesh::getVolumeType(), triSurfaceSearch::tree(), and triSurfaceSearch::triSurfaceSearch().

Here is the caller graph for this function:

◆ clone()

autoPtr< indexedOctree< Type > > clone ( ) const
inline

Clone.

Definition at line 434 of file indexedOctree.H.

References Foam::New().

Here is the call graph for this function:

◆ shapes()

const Type & shapes ( ) const
inline

◆ nodes()

const List< node > & nodes ( ) const
inline

List of all nodes.

Definition at line 450 of file indexedOctree.H.

Referenced by distributedTriSurfaceMesh::getVolumeType(), and indexedOctree< Type >::indexedOctree().

Here is the caller graph for this function:

◆ contents()

const labelListList & contents ( ) const
inline

List of all contents (referenced by those nodes that are.

contents)

Definition at line 457 of file indexedOctree.H.

Referenced by indexedOctree< Type >::indexedOctree().

Here is the caller graph for this function:

◆ bb()

const treeBoundBox & bb ( ) const
inline

Top bounding box.

Definition at line 463 of file indexedOctree.H.

References Foam::abort(), UList< T >::empty(), Foam::FatalError, and FatalErrorInFunction.

Referenced by patchProbes::findElements(), indexedOctree< Type >::findNear(), meshSearch::findNearestBoundaryFace(), indexedOctree< Type >::indexedOctree(), and surfaceFeatures::nearestSamples().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ nodeTypes()

PackedList< 2 > & nodeTypes ( ) const
inline

Per node, per octant whether is fully inside/outside/mixed.

Definition at line 474 of file indexedOctree.H.

Referenced by distributedTriSurfaceMesh::getVolumeType().

Here is the caller graph for this function:

◆ isContent()

static bool isContent ( const labelBits  i)
inlinestatic

Definition at line 482 of file indexedOctree.H.

References labelBits::val().

Referenced by indexedOctree< Type >::getContent().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ isEmpty()

static bool isEmpty ( const labelBits  i)
inlinestatic

Definition at line 487 of file indexedOctree.H.

References labelBits::val().

Here is the call graph for this function:

◆ isNode()

static bool isNode ( const labelBits  i)
inlinestatic

Definition at line 492 of file indexedOctree.H.

References labelBits::val().

Referenced by indexedOctree< Type >::getNode().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ getContent()

static label getContent ( const labelBits  i)
inlinestatic

Definition at line 497 of file indexedOctree.H.

References Foam::abort(), Foam::FatalError, FatalErrorInFunction, indexedOctree< Type >::isContent(), and labelBits::val().

Here is the call graph for this function:

◆ getNode()

static label getNode ( const labelBits  i)
inlinestatic

Definition at line 507 of file indexedOctree.H.

References Foam::abort(), Foam::FatalError, FatalErrorInFunction, indexedOctree< Type >::isNode(), and labelBits::val().

Here is the call graph for this function:

◆ getOctant()

static direction getOctant ( const labelBits  i)
inlinestatic

Definition at line 517 of file indexedOctree.H.

References labelBits::bits().

Here is the call graph for this function:

◆ findNearest() [1/7]

Foam::pointIndexHit findNearest ( const point sample,
const scalar  nearestDistSqr 
) const

Definition at line 2390 of file indexedOctree.C.

◆ findNearest() [2/7]

pointIndexHit findNearest ( const point sample,
const scalar  nearestDistSqr,
const FindNearestOp &  fnOp 
) const

Calculate nearest point on nearest shape.

Returns

  • bool : any point found nearer than nearestDistSqr
  • label: index in shapes
  • point: actual nearest point found

◆ findNearest() [3/7]

void findNearest ( const label  nodeI,
const point sample,
scalar &  nearestDistSqr,
label &  nearestShapeI,
point nearestPoint,
const FindNearestOp &  fnOp 
) const

Low level: calculate nearest starting from subnode.

Definition at line 488 of file indexedOctree.C.

References indexedOctree< Type >::node::bb_, boundBox::max(), boundBox::min(), treeBoundBox::searchOrder(), and indexedOctree< Type >::node::subNodes_.

Here is the call graph for this function:

◆ findNearest() [4/7]

Foam::pointIndexHit findNearest ( const linePointRef ln,
treeBoundBox tightest,
point linePoint 
) const

Find nearest to line.

Returns

  • bool : any point found?
  • label: index in shapes
  • point: actual nearest point found sets:
  • linePoint : corresponding nearest point on line

Definition at line 2439 of file indexedOctree.C.

References Foam::ln().

Here is the call graph for this function:

◆ findNearest() [5/7]

pointIndexHit findNearest ( const linePointRef ln,
treeBoundBox tightest,
point linePoint,
const FindNearestOp &  fnOp 
) const

◆ findLine() [1/5]

Foam::pointIndexHit findLine ( const point start,
const point end 
) const

Find nearest intersection of line between start and end.

Definition at line 2491 of file indexedOctree.C.

◆ findLineAny() [1/3]

Foam::pointIndexHit findLineAny ( const point start,
const point end 
) const

Find any intersection of line between start and end.

Definition at line 2508 of file indexedOctree.C.

Referenced by triSurfaceSearch::findLineAny().

Here is the caller graph for this function:

◆ findLine() [2/5]

pointIndexHit findLine ( const point start,
const point end,
const FindIntersectOp &  fiOp 
) const

Find nearest intersection of line between start and end.

◆ findLineAny() [2/3]

pointIndexHit findLineAny ( const point start,
const point end,
const FindIntersectOp &  fiOp 
) const

Find any intersection of line between start and end.

◆ findBox()

Foam::labelList findBox ( const treeBoundBox bb) const

Find (in no particular order) indices of all shapes inside or.

overlapping bounding box (i.e. all shapes not outside box)

Definition at line 2551 of file indexedOctree.C.

References HashTable< T, Key, Hash >::toc().

Here is the call graph for this function:

◆ findSphere()

Foam::labelList findSphere ( const point centre,
const scalar  radiusSqr 
) const

Find (in no particular order) indices of all shapes inside or.

overlapping a bounding sphere (i.e. all shapes not outside sphere)

Definition at line 2571 of file indexedOctree.C.

References HashTable< T, Key, Hash >::toc().

Here is the call graph for this function:

◆ findNode()

Foam::labelBits findNode ( const label  nodeI,
const point sample 
) const

Find deepest node (as parent+octant) containing point. Starts.

off from starting index in nodes_ (use 0 to start from top) Use getNode and getOctant to extract info, or call findIndices.

Definition at line 2592 of file indexedOctree.C.

References indexedOctree< Type >::node::bb_, indexedOctree< Type >::node::subNodes_, and treeBoundBox::subOctant().

Here is the call graph for this function:

◆ findInside()

Foam::label findInside ( const point sample) const

Find shape containing point. Only implemented for certain.

shapes.

Definition at line 2629 of file indexedOctree.C.

References forAll, Foam::getOctant(), and indexedOctree< Type >::node::subNodes_.

Referenced by polyMesh::findCellFacePt(), mappedPatchBase::findLocalSamples(), and propellerInfo::updateSampleDiskCells().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ findIndices()

const Foam::labelList & findIndices ( const point sample) const

Find the shape indices that occupy the result of findNode.

Definition at line 2663 of file indexedOctree.C.

References Foam::getOctant(), List< label >::null(), and indexedOctree< Type >::node::subNodes_.

Here is the call graph for this function:

◆ getVolumeType()

Foam::volumeType getVolumeType ( const point sample) const

Determine type (inside/outside/mixed) for point. unknown if.

cannot be determined (e.g. non-manifold surface)

Definition at line 2690 of file indexedOctree.C.

References Foam::abort(), Foam::endl(), Foam::FatalError, FatalErrorInFunction, forAll, volumeType::INSIDE, volumeType::MIXED, volumeType::OUTSIDE, Foam::Pout, Foam::type(), and volumeType::UNKNOWN.

Here is the call graph for this function:

◆ getSide()

Foam::volumeType getSide ( const vector outsideNormal,
const vector vec 
)
static

Helper function to return the side. Returns outside if.

outsideNormal&vec >= 0, inside otherwise

Definition at line 469 of file indexedOctree.C.

Referenced by treeDataFace::getVolumeType(), and treeDataPrimitivePatch< PatchType >::getVolumeType().

Here is the caller graph for this function:

◆ overlaps()

bool overlaps ( const point bbMin,
const point bbMax,
const scalar  nearestDistSqr,
const point sample 
)
static

Helper: does bb intersect a sphere around sample? Or is any.

corner point of bb closer than nearestDistSqr to sample.

Definition at line 44 of file indexedOctree.C.

References boundBox::overlaps(), and p0.

Here is the call graph for this function:

◆ findNear()

void findNear ( const scalar  nearDist,
const indexedOctree< Type > &  tree2,
CompareOp &  cop 
) const

Find near pairs and apply CompareOp to them.

tree2 can be *this or different tree.

Definition at line 2760 of file indexedOctree.C.

References indexedOctree< Type >::bb().

Here is the call graph for this function:

◆ print()

void print ( prefixOSstream os,
const bool  printContents,
const label  nodeI 
) const

Print tree. Either print all indices (printContent = true) or.

just size of contents nodes.

Definition at line 2786 of file indexedOctree.C.

References indexedOctree< Type >::node::bb_, Foam::endl(), forAll, Foam::nl, os(), indexedOctree< Type >::node::parent_, UList< T >::size(), treeBoundBox::subBbox(), and indexedOctree< Type >::node::subNodes_.

Here is the call graph for this function:

◆ write()

bool write ( Ostream os) const

Definition at line 2864 of file indexedOctree.C.

References IOstream::good(), and os().

Here is the call graph for this function:

◆ findLine() [3/5]

Foam::pointIndexHit findLine ( const bool  findAny,
const point treeStart,
const point treeEnd,
const label  startNodeI,
const direction  startOctant,
const FindIntersectOp &  fiOp,
const bool  verbose 
) const

Definition at line 1554 of file indexedOctree.C.

References Foam::abort(), Foam::endl(), treeBoundBox::faceBits(), Foam::FatalError, FatalErrorInFunction, PointIndexHit< PointType >::hit(), Foam::nl, Foam::Pout, PointIndexHit< PointType >::rawPoint(), and WarningInFunction.

Here is the call graph for this function:

◆ findLine() [4/5]

Foam::pointIndexHit findLine ( const bool  findAny,
const point start,
const point end,
const FindIntersectOp &  fiOp 
) const

Definition at line 1746 of file indexedOctree.C.

References treeBoundBox::intersects(), and treeBoundBox::posBits().

Here is the call graph for this function:

◆ findNearest() [6/7]

Foam::pointIndexHit findNearest ( const point sample,
const scalar  startDistSqr,
const FindNearestOp &  fnOp 
) const

Definition at line 2407 of file indexedOctree.C.

References Foam::Zero.

◆ findNearest() [7/7]

Foam::pointIndexHit findNearest ( const linePointRef ln,
treeBoundBox tightest,
point linePoint,
const FindNearestOp &  fnOp 
) const

Definition at line 2458 of file indexedOctree.C.

References Foam::ln(), and Foam::Zero.

Here is the call graph for this function:

◆ findLine() [5/5]

Foam::pointIndexHit findLine ( const point start,
const point end,
const FindIntersectOp &  fiOp 
) const

Definition at line 2526 of file indexedOctree.C.

◆ findLineAny() [3/3]

Foam::pointIndexHit findLineAny ( const point start,
const point end,
const FindIntersectOp &  fiOp 
) const

Definition at line 2539 of file indexedOctree.C.

Friends And Related Function Documentation

◆ operator

Ostream & operator ( Ostream ,
const indexedOctree< Type > &   
)
friend

The documentation for this class was generated from the following files: