GDAL
cpl_quad_tree.h
Go to the documentation of this file.
1/**********************************************************************
2 *
3 * Project: CPL - Common Portability Library
4 * Purpose: Implementation of quadtree building and searching functions.
5 * Derived from shapelib and mapserver implementations
6 * Author: Frank Warmerdam, warmerdam@pobox.com
7 * Even Rouault, <even dot rouault at spatialys.com>
8 *
9 ******************************************************************************
10 * Copyright (c) 1999-2008, Frank Warmerdam
11 * Copyright (c) 2008-2014, Even Rouault <even dot rouault at spatialys.com>
12 *
13 * SPDX-License-Identifier: MIT
14 ****************************************************************************/
15
16#ifndef CPL_QUAD_TREE_H_INCLUDED
17#define CPL_QUAD_TREE_H_INCLUDED
18
19#include "cpl_port.h"
20
21#include <stdbool.h>
22
33
35
36/* Types */
37
39typedef struct
40{
41 double minx;
42 double miny;
43 double maxx;
44 double maxy;
46
48typedef struct _CPLQuadTree CPLQuadTree;
49
51typedef void (*CPLQuadTreeGetBoundsFunc)(const void *hFeature,
52 CPLRectObj *pBounds);
54typedef void (*CPLQuadTreeGetBoundsExFunc)(const void *hFeature,
55 void *pUserData,
56 CPLRectObj *pBounds);
58typedef int (*CPLQuadTreeForeachFunc)(void *pElt, void *pUserData);
60typedef void (*CPLQuadTreeDumpFeatureFunc)(const void *hFeature,
61 int nIndentLevel, void *pUserData);
62
63/* Functions */
64
65CPLQuadTree CPL_DLL *CPLQuadTreeCreate(const CPLRectObj *pGlobalBounds,
66 CPLQuadTreeGetBoundsFunc pfnGetBounds);
67CPLQuadTree CPL_DLL *
68CPLQuadTreeCreateEx(const CPLRectObj *pGlobalBounds,
69 CPLQuadTreeGetBoundsExFunc pfnGetBounds, void *pUserData);
70void CPL_DLL CPLQuadTreeDestroy(CPLQuadTree *hQuadtree);
71
72void CPL_DLL CPLQuadTreeSetBucketCapacity(CPLQuadTree *hQuadtree,
73 int nBucketCapacity);
74void CPL_DLL CPLQuadTreeForceUseOfSubNodes(CPLQuadTree *hQuadTree);
75int CPL_DLL CPLQuadTreeGetAdvisedMaxDepth(int nExpectedFeatures);
76void CPL_DLL CPLQuadTreeSetMaxDepth(CPLQuadTree *hQuadtree, int nMaxDepth);
77
78void CPL_DLL CPLQuadTreeInsert(CPLQuadTree *hQuadtree, void *hFeature);
79void CPL_DLL CPLQuadTreeInsertWithBounds(CPLQuadTree *hQuadtree, void *hFeature,
80 const CPLRectObj *psBounds);
81
82void CPL_DLL CPLQuadTreeRemove(CPLQuadTree *hQuadtree, void *hFeature,
83 const CPLRectObj *psBounds);
84
85void CPL_DLL **CPLQuadTreeSearch(const CPLQuadTree *hQuadtree,
86 const CPLRectObj *pAoi, int *pnFeatureCount);
87
88bool CPL_DLL CPLQuadTreeHasMatch(const CPLQuadTree *hQuadtree,
89 const CPLRectObj *pAoi);
90
91void CPL_DLL CPLQuadTreeForeach(const CPLQuadTree *hQuadtree,
92 CPLQuadTreeForeachFunc pfnForeach,
93 void *pUserData);
94
95void CPL_DLL CPLQuadTreeDump(const CPLQuadTree *hQuadtree,
96 CPLQuadTreeDumpFeatureFunc pfnDumpFeatureFunc,
97 void *pUserData);
98void CPL_DLL CPLQuadTreeGetStats(const CPLQuadTree *hQuadtree,
99 int *pnFeatureCount, int *pnNodeCount,
100 int *pnMaxDepth, int *pnMaxBucketCapacity);
101
103
104#endif
Core portability definitions for CPL.
#define CPL_C_END
Macro to end a block of C symbols.
Definition cpl_port.h:289
#define CPL_C_START
Macro to start a block of C symbols.
Definition cpl_port.h:285
CPLQuadTree * CPLQuadTreeCreateEx(const CPLRectObj *pGlobalBounds, CPLQuadTreeGetBoundsExFunc pfnGetBounds, void *pUserData)
Create a new quadtree.
Definition cpl_quad_tree.cpp:187
void CPLQuadTreeRemove(CPLQuadTree *hQuadtree, void *hFeature, const CPLRectObj *psBounds)
Remove a feature from a quadtree.
Definition cpl_quad_tree.cpp:447
CPLQuadTree * CPLQuadTreeCreate(const CPLRectObj *pGlobalBounds, CPLQuadTreeGetBoundsFunc pfnGetBounds)
Create a new quadtree.
Definition cpl_quad_tree.cpp:138
bool CPLQuadTreeHasMatch(const CPLQuadTree *hQuadtree, const CPLRectObj *pAoi)
Returns whether the quadtree has at least one element whose bounding box intersects the provided area...
Definition cpl_quad_tree.cpp:980
void(* CPLQuadTreeGetBoundsExFunc)(const void *hFeature, void *pUserData, CPLRectObj *pBounds)
CPLQuadTreeGetBoundsExFunc.
Definition cpl_quad_tree.h:54
void CPLQuadTreeInsert(CPLQuadTree *hQuadtree, void *hFeature)
Insert a feature into a quadtree.
Definition cpl_quad_tree.cpp:330
int(* CPLQuadTreeForeachFunc)(void *pElt, void *pUserData)
CPLQuadTreeForeachFunc.
Definition cpl_quad_tree.h:58
void ** CPLQuadTreeSearch(const CPLQuadTree *hQuadtree, const CPLRectObj *pAoi, int *pnFeatureCount)
Returns all the elements inserted whose bounding box intersects the provided area of interest.
Definition cpl_quad_tree.cpp:896
void(* CPLQuadTreeGetBoundsFunc)(const void *hFeature, CPLRectObj *pBounds)
CPLQuadTreeGetBoundsFunc.
Definition cpl_quad_tree.h:51
void CPLQuadTreeGetStats(const CPLQuadTree *hQuadtree, int *pnFeatureCount, int *pnNodeCount, int *pnMaxDepth, int *pnMaxBucketCapacity)
Get stats.
Definition cpl_quad_tree.cpp:1128
void CPLQuadTreeDump(const CPLQuadTree *hQuadtree, CPLQuadTreeDumpFeatureFunc pfnDumpFeatureFunc, void *pUserData)
Dump quad tree.
Definition cpl_quad_tree.cpp:1095
void CPLQuadTreeForeach(const CPLQuadTree *hQuadtree, CPLQuadTreeForeachFunc pfnForeach, void *pUserData)
Walk through the quadtree and runs the provided function on all the elements.
Definition cpl_quad_tree.cpp:1032
void CPLQuadTreeSetBucketCapacity(CPLQuadTree *hQuadtree, int nBucketCapacity)
Set the maximum capacity of a node of a quadtree.
Definition cpl_quad_tree.cpp:296
void CPLQuadTreeSetMaxDepth(CPLQuadTree *hQuadtree, int nMaxDepth)
Set the maximum depth of a quadtree.
Definition cpl_quad_tree.cpp:278
void CPLQuadTreeDestroy(CPLQuadTree *hQuadtree)
Destroy a quadtree.
Definition cpl_quad_tree.cpp:503
struct _CPLQuadTree CPLQuadTree
Opaque type for a quad tree.
Definition cpl_quad_tree.h:48
void CPLQuadTreeInsertWithBounds(CPLQuadTree *hQuadtree, void *hFeature, const CPLRectObj *psBounds)
Insert a feature into a quadtree.
Definition cpl_quad_tree.cpp:359
void(* CPLQuadTreeDumpFeatureFunc)(const void *hFeature, int nIndentLevel, void *pUserData)
CPLQuadTreeDumpFeatureFunc.
Definition cpl_quad_tree.h:60
void CPLQuadTreeForceUseOfSubNodes(CPLQuadTree *hQuadTree)
Force the quadtree to insert as much as possible a feature whose bbox spread over multiple subnodes i...
Definition cpl_quad_tree.cpp:314
int CPLQuadTreeGetAdvisedMaxDepth(int nExpectedFeatures)
Returns the optimal depth of a quadtree to hold nExpectedFeatures.
Definition cpl_quad_tree.cpp:231
Describe a rectangle.
Definition cpl_quad_tree.h:40
double minx
Minimum x.
Definition cpl_quad_tree.h:41
double maxy
Maximum y.
Definition cpl_quad_tree.h:44
double miny
Minimum y.
Definition cpl_quad_tree.h:42
double maxx
Maximum x.
Definition cpl_quad_tree.h:43