#include <fstream>
#include <iostream>
 
#include <CGAL/Simple_cartesian.h>
#include <CGAL/Octree.h>
#include <CGAL/Point_set_3.h>
#include <CGAL/Point_set_3/IO.h>
 
using FT = Kernel::FT;
using Point_map = Point_set::Point_map;
 
struct Split_by_ratio {
 
  std::size_t ratio;
 
  explicit Split_by_ratio(std::size_t ratio) : ratio(ratio) {}
 
  template<typename Node_index, typename Tree>
  bool operator()(Node_index i, const Tree &tree) const {
    std::size_t num_points = tree.data(i).size();
    std::size_t depth = tree.depth(i);
    return num_points > (ratio * depth);
  }
};
 
int main(int argc, char **argv) {
 
  
  Point_set points;
 
  
  std::ifstream stream((argc > 1) ? argv[1] : CGAL::data_file_path("points_3/cube.pwn"));
  stream >> points;
  if (0 == points.number_of_points()) {
 
    std::cerr << "Error: cannot read file" << std::endl;
    return EXIT_FAILURE;
  }
  std::cout << "loaded " << points.number_of_points() << " points" << std::endl;
 
  
  Octree octree(points, points.point_map());
 
 
  
  octree.refine(Split_by_ratio(2));
 
  
  std::cout << octree;
 
  return EXIT_SUCCESS;
}
A data structure using an axis-aligned hyperrectangle decomposition of dD space for efficient access ...
Definition: Orthtree.h:117
Orthtree< Orthtree_traits_point< GeomTraits, PointRange, PointMap, cubic_nodes, 3 > > Octree
Alias that specializes the Orthtree class to a 3D octree storing 3D points.
Definition: Octree.h:38