Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035 #pragma once
00036
00037 #include <cstdlib>
00038 #include <vector>
00039 #include "PointMatcher.h"
00040
00041 #include "utils.h"
00042
00077 template < typename T, std::size_t dim >
00078 class Octree_
00079 {
00080 public:
00081 using PM = PointMatcher<T>;
00082 using DP = typename PM::DataPoints;
00083 using Id = typename DP::Index;
00084
00085 using Data = typename DP::Index;
00086 using DataContainer = std::vector<Data>;
00087
00088 using Point = Eigen::Matrix<T,dim,1>;
00089
00090
00091 static constexpr std::size_t nbCells = PointMatcherSupport::pow(2, dim);
00092
00093 private:
00094 struct BoundingBox
00095 {
00096 Point center;
00097 T radius;
00098 };
00099
00100 Octree_* parent;
00101 Octree_* cells[nbCells];
00102
00103
00104
00105
00106
00107
00108
00109
00110
00111
00112
00113
00114
00115
00116 BoundingBox bb;
00117
00118 DataContainer data;
00119
00120 std::size_t depth;
00121
00122 public:
00123 Octree_();
00124 Octree_(const Octree_<T,dim>& o);
00125 Octree_(Octree_<T,dim>&& o);
00126
00127 virtual ~Octree_();
00128
00129 Octree_<T,dim>& operator=(const Octree_<T,dim>& o);
00130 Octree_<T,dim>& operator=(Octree_<T,dim>&& o);
00131
00132 bool isLeaf() const;
00133 bool isRoot() const;
00134 bool isEmpty()const;
00135
00136 inline std::size_t idx(const Point& pt) const;
00137 inline std::size_t idx(const DP& pts, const Data d) const;
00138
00139 std::size_t getDepth() const;
00140
00141 T getRadius() const;
00142 Point getCenter() const;
00143
00144 DataContainer * getData();
00145 Octree_<T, dim>* operator[](std::size_t idx);
00146
00147
00148 bool build(const DP& pts, size_t maxDataByNode=1, T maxSizeByNode=T(0.), bool parallelBuild=false);
00149
00150 protected:
00151
00152 bool build(const DP& pts, DataContainer&& datas, BoundingBox&& bb, size_t maxDataByNode=1, T maxSizeByNode=T(0.), bool parallelBuild=false);
00153
00154 inline DataContainer toData(const DP& pts, const std::vector<Id>& ids);
00155
00156 public:
00157 template < typename Callback >
00158 bool visit(Callback& cb);
00159 };
00160
00161 #include "octree.hpp"
00162
00163 template<typename T> using Quadtree = Octree_<T,2>;
00164 template<typename T> using Octree = Octree_<T,3>;
00165