From 8014dac407f1cce2ce4082902adb1409e4987013 Mon Sep 17 00:00:00 2001 From: ROUVREAU Vincent Date: Tue, 16 Jun 2020 11:22:30 +0200 Subject: Code review: check point is not empty. vector reserve. Kernel and Point type for all classes --- src/python/include/Alpha_complex_factory.h | 48 +++++++++++++--------------- src/python/include/Alpha_complex_interface.h | 2 +- 2 files changed, 24 insertions(+), 26 deletions(-) (limited to 'src/python/include') diff --git a/src/python/include/Alpha_complex_factory.h b/src/python/include/Alpha_complex_factory.h index d7bf3617..69b584c5 100644 --- a/src/python/include/Alpha_complex_factory.h +++ b/src/python/include/Alpha_complex_factory.h @@ -34,6 +34,7 @@ namespace alpha_complex { template std::vector pt_cgal_to_cython(CgalPointType const& point) { std::vector vd; + vd.reserve(point.dimension()); for (auto coord = point.cartesian_begin(); coord != point.cartesian_end(); coord++) vd.push_back(CGAL::to_double(*coord)); return vd; @@ -53,87 +54,84 @@ class Abstract_alpha_complex { class Exact_Alphacomplex_dD : public Abstract_alpha_complex { private: - using Exact_kernel = CGAL::Epeck_d; - using Point_exact_kernel = typename Exact_kernel::Point_d; + using Kernel = CGAL::Epeck_d; + using Point = typename Kernel::Point_d; public: Exact_Alphacomplex_dD(const std::vector>& points, bool exact_version) - : exact_version_(exact_version) { - ac_exact_ptr_ = std::make_unique>( - boost::adaptors::transform(points, pt_cython_to_cgal)); + : exact_version_(exact_version), + alpha_complex_(boost::adaptors::transform(points, pt_cython_to_cgal)) { } std::vector get_point(int vh) { - Point_exact_kernel const& point = ac_exact_ptr_->get_point(vh); + Point const& point = alpha_complex_.get_point(vh); return pt_cgal_to_cython(point); } void create_simplex_tree(Simplex_tree_interface<>* simplex_tree, double max_alpha_square, bool default_filtration_value){ - ac_exact_ptr_->create_complex(*simplex_tree, max_alpha_square, exact_version_, default_filtration_value); + alpha_complex_.create_complex(*simplex_tree, max_alpha_square, exact_version_, default_filtration_value); } private: bool exact_version_; - std::unique_ptr> ac_exact_ptr_; + Alpha_complex alpha_complex_; }; class Inexact_Alphacomplex_dD : public Abstract_alpha_complex { private: - using Inexact_kernel = CGAL::Epick_d; - using Point_inexact_kernel = typename Inexact_kernel::Point_d; + using Kernel = CGAL::Epick_d; + using Point = typename Kernel::Point_d; public: Inexact_Alphacomplex_dD(const std::vector>& points, bool exact_version) - : exact_version_(exact_version) { - ac_inexact_ptr_ = std::make_unique>( - boost::adaptors::transform(points, pt_cython_to_cgal)); + : exact_version_(exact_version), + alpha_complex_(boost::adaptors::transform(points, pt_cython_to_cgal)) { } std::vector get_point(int vh) { - Point_inexact_kernel const& point = ac_inexact_ptr_->get_point(vh); + Point const& point = alpha_complex_.get_point(vh); return pt_cgal_to_cython(point); } void create_simplex_tree(Simplex_tree_interface<>* simplex_tree, double max_alpha_square, bool default_filtration_value){ - ac_inexact_ptr_->create_complex(*simplex_tree, max_alpha_square, exact_version_, default_filtration_value); + alpha_complex_.create_complex(*simplex_tree, max_alpha_square, exact_version_, default_filtration_value); } private: bool exact_version_; - std::unique_ptr> ac_inexact_ptr_; + Alpha_complex alpha_complex_; }; template class Alphacomplex_3D : public Abstract_alpha_complex { private: - using Point_3 = typename Alpha_complex_3d::Bare_point_3; + using Point = typename Alpha_complex_3d::Bare_point_3; - static Point_3 pt_cython_to_cgal_3(std::vector const& vec) { - return Point_3(vec[0], vec[1], vec[2]); + static Point pt_cython_to_cgal_3(std::vector const& vec) { + return Point(vec[0], vec[1], vec[2]); } public: - Alphacomplex_3D(const std::vector>& points) { - alpha3d_ptr_ = std::make_unique>( - boost::adaptors::transform(points, pt_cython_to_cgal_3)); + Alphacomplex_3D(const std::vector>& points) + : alpha_complex_(boost::adaptors::transform(points, pt_cython_to_cgal_3)) { } std::vector get_point(int vh) { - Point_3 const& point = alpha3d_ptr_->get_point(vh); + Point const& point = alpha_complex_.get_point(vh); return pt_cgal_to_cython(point); } void create_simplex_tree(Simplex_tree_interface<>* simplex_tree, double max_alpha_square, bool default_filtration_value){ - alpha3d_ptr_->create_complex(*simplex_tree, max_alpha_square); + alpha_complex_.create_complex(*simplex_tree, max_alpha_square); if (default_filtration_value) { // TODO } } private: - std::unique_ptr> alpha3d_ptr_; + Alpha_complex_3d alpha_complex_; }; diff --git a/src/python/include/Alpha_complex_interface.h b/src/python/include/Alpha_complex_interface.h index c4b9df4b..0b946f8e 100644 --- a/src/python/include/Alpha_complex_interface.h +++ b/src/python/include/Alpha_complex_interface.h @@ -28,7 +28,7 @@ namespace alpha_complex { class Alpha_complex_interface { public: Alpha_complex_interface(const std::vector>& points, bool fast_version, bool exact_version) { - if (points[0].size() == 3) { + if (points.size() > 0 && points[0].size() == 3) { if (fast_version) alpha_ptr_ = std::make_unique>(points); else if (exact_version) -- cgit v1.2.3