#ifndef CGAL_KD_KERNEL_3_INTERFACE_H #define CGAL_KD_KERNEL_3_INTERFACE_H #include #include #include #include namespace CGAL { template struct Kernel_d_interface : public Base_ { CGAL_CONSTEXPR Kernel_d_interface(){} CGAL_CONSTEXPR Kernel_d_interface(int d):Base_(d){} typedef Base_ Base; typedef Kernel_d_interface Kernel; typedef Base_ R_; // for the macros typedef typename Base::Flat_orientation Flat_orientation_d; typedef typename Base::Point Point_d; typedef typename Base::Vector Vector_d; typedef typename Base::Segment Segment_d; typedef typename Base::Sphere Sphere_d; typedef typename Base::Hyperplane Hyperplane_d; typedef Vector_d Direction_d; typedef typename Base::Line Line_d; typedef typename Base::Ray Ray_d; typedef typename Base::Iso_box Iso_box_d; typedef typename Base::Aff_transformation Aff_transformation_d; typedef typename Base::template Functor::type Compute_coordinate_d; typedef typename Base::template Functor::type Compare_lexicographically_d; typedef typename Base::template Functor::type Equal_d; typedef typename Base::template Functor::type Less_lexicographically_d; typedef typename Base::template Functor::type Less_or_equal_lexicographically_d; // FIXME: and vectors? typedef typename Base::template Functor::type Orientation_d; typedef typename Base::template Functor::type Less_coordinate_d; typedef typename Base::template Functor::type Point_dimension_d; typedef typename Base::template Functor::type Side_of_oriented_sphere_d; typedef typename Base::template Functor::type Contained_in_affine_hull_d; typedef typename Base::template Functor::type Construct_flat_orientation_d; typedef typename Base::template Functor::type In_flat_orientation_d; typedef typename Base::template Functor::type In_flat_side_of_oriented_sphere_d; typedef typename Base::template Functor::type Point_to_vector_d; typedef typename Base::template Functor::type Vector_to_point_d; typedef typename Base::template Functor >::type Construct_point_d; typedef typename Base::template Functor >::type Construct_vector_d; typedef typename Base::template Functor >::type Construct_segment_d; typedef typename Base::template Functor >::type Construct_sphere_d; typedef typename Base::template Functor >::type Construct_hyperplane_d; typedef Construct_vector_d Construct_direction_d; typedef typename Base::template Functor >::type Construct_line_d; typedef typename Base::template Functor >::type Construct_ray_d; typedef typename Base::template Functor >::type Construct_iso_box_d; typedef typename Base::template Functor >::type Construct_aff_transformation_d; typedef typename Base::template Functor::type Midpoint_d; struct Component_accessor_d : private Store_kernel { CGAL_FUNCTOR_INIT_STORE(Component_accessor_d) typedef typename Base::Point Point; typedef typename Base::RT RT; typedef typename Base::FT FT; int dimension(Point const&p){ return this->kernel().point_dimension_d_object()(p); } FT cartesian(Point const&p, int i){ return this->kernel().compute_coordinate_d_object()(p); } RT homogeneous(Point const&p, int i){ throw "not implemented yet"; return 0; // FIXME //return this->kernel().compute_coordinate_d_object()(p); } }; struct Construct_cartesian_const_iterator_d : private Store_kernel { CGAL_FUNCTOR_INIT_STORE(Construct_cartesian_const_iterator_d) typedef typename Base::template Functor >::type CPI; typedef typename Base::template Functor >::type CVI; typedef typename CGAL::decay::type>::type result_type; // Kernel_d requires a common iterator type for points and vectors // TODO: provide this mixed functor in preKernel? CGAL_static_assertion((boost::is_same::type>::type, result_type>::value)); template result_type operator()(Point_d const&p, Tag t)const{ return CPI(this->kernel())(p,t); } template result_type operator()(Vector_d const&v, Tag t)const{ return CVI(this->kernel())(v,t); } template result_type operator()(Obj const&o)const{ return operator()(o, Begin_tag()); } result_type operator()(Point_d const&p, int)const{ return operator()(p, End_tag()); } result_type operator()(Vector_d const&v, int)const{ return operator()(v, End_tag()); } }; typedef typename Construct_cartesian_const_iterator_d::result_type Cartesian_const_iterator_d; typedef typename Base::template Functor::type Squared_distance_d; //typedef typename Base::template Functor::type Affine_rank_d; //typedef typename Base::template Functor::type Affinely_independent_d; //typedef typename Base::template Functor::type Contained_in_linear_hull_d; //typedef typename Base::template Functor::type Contained_in_simplex_d; //typedef typename Base::template Functor::type Has_on_positive_side_d; //typedef typename Base::template Functor::type Linear_rank_d; //typedef typename Base::template Functor::type Linearly_independent_d; //typedef typename Base::template Functor::type Oriented_side_d; //typedef typename Base::template Functor::type Side_of_bounded_sphere_d; //typedef typename Base::template Functor::type Center_of_sphere_d; //typedef typename Base::template Functor::type Value_at_d; //typedef typename Base::template Functor::type Point_of_sphere_d; typedef typename Base::template Functor::type Orthogonal_vector_d; //typedef typename Base::template Functor::type Linear_base_d; //typedef ??? Intersect_d; Compute_coordinate_d compute_coordinate_d_object()const{ return Compute_coordinate_d(*this); } Compare_lexicographically_d compare_lexicographically_d_object()const{ return Compare_lexicographically_d(*this); } Equal_d equal_d_object()const{ return Equal_d(*this); } Less_lexicographically_d less_lexicographically_d_object()const{ return Less_lexicographically_d(*this); } Less_or_equal_lexicographically_d less_or_equal_lexicographically_d_object()const{ return Less_or_equal_lexicographically_d(*this); } Less_coordinate_d less_coordinate_d_object()const{ return Less_coordinate_d(*this); } Orientation_d orientation_d_object()const{ return Orientation_d(*this); } Point_dimension_d point_dimension_d_object()const{ return Point_dimension_d(*this); } Side_of_oriented_sphere_d side_of_oriented_sphere_d_object()const{ return Side_of_oriented_sphere_d(*this); } Contained_in_affine_hull_d contained_in_affine_hull_d_object()const{ return Contained_in_affine_hull_d(*this); } Construct_flat_orientation_d construct_flat_orientation_d_object()const{ return Construct_flat_orientation_d(*this); } In_flat_orientation_d in_flat_orientation_d_object()const{ return In_flat_orientation_d(*this); } In_flat_side_of_oriented_sphere_d in_flat_side_of_oriented_sphere_d_object()const{ return In_flat_side_of_oriented_sphere_d(*this); } Point_to_vector_d point_to_vector_d_object()const{ return Point_to_vector_d(*this); } Vector_to_point_d vector_to_point_d_object()const{ return Vector_to_point_d(*this); } Midpoint_d midpoint_d_object()const{ return Midpoint_d(*this); } Component_accessor_d component_accessor_d_object()const{ return Component_accessor_d(*this); } Orthogonal_vector_d orthogonal_vector_d_object()const{ return Orthogonal_vector_d(*this); } Construct_cartesian_const_iterator_d construct_cartesian_const_iterator_d_object()const{ return Construct_cartesian_const_iterator_d(*this); } Construct_point_d construct_point_d_object()const{ return Construct_point_d(*this); } Construct_vector_d construct_vector_d_object()const{ return Construct_vector_d(*this); } Construct_segment_d construct_segment_d_object()const{ return Construct_segment_d(*this); } Construct_sphere_d construct_sphere_d_object()const{ return Construct_sphere_d(*this); } Construct_hyperplane_d construct_hyperplane_d_object()const{ return Construct_hyperplane_d(*this); } Squared_distance_d squared_distance_d_object()const{ return Squared_distance_d(*this); } Construct_direction_d construct_direction_d_object()const{ return Construct_direction_d(*this); } Construct_line_d construct_line_d_object()const{ return Construct_line_d(*this); } Construct_ray_d construct_ray_d_object()const{ return Construct_ray_d(*this); } Construct_iso_box_d construct_iso_box_d_object()const{ return Construct_iso_box_d(*this); } Construct_aff_transformation_d construct_aff_transformation_d_object()const{ return Construct_aff_transformation_d(*this); } // Dummies for those required functors missing a concept. typedef Null_functor Position_on_line_d; Position_on_line_d position_on_line_d_object()const{return Null_functor();} typedef Null_functor Barycentric_coordinates_d; Barycentric_coordinates_d barycentric_coordinates_d_object()const{return Null_functor();} /* Not provided because they don't make sense here: Lift_to_paraboloid_d Project_along_d_axis_d */ }; } #endif