#ifndef CGAL_KD_KERNEL_D_INTERFACE_H #define CGAL_KD_KERNEL_D_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 Get_type::type RT; typedef typename Get_type::type FT; typedef typename Get_type::type Boolean; typedef typename Get_type::type Sign; typedef typename Get_type::type Comparison_result; typedef typename Get_type::type Orientation; typedef typename Get_type::type Oriented_side; typedef typename Get_type::type Bounded_side; typedef typename Get_type::type Angle; typedef typename Get_type::type Flat_orientation_d; typedef typename Get_type::type Point_d; typedef typename Get_type::type Vector_d; typedef typename Get_type::type Segment_d; typedef typename Get_type::type Sphere_d; typedef typename Get_type::type Hyperplane_d; typedef Vector_d Direction_d; typedef typename Get_type::type Line_d; typedef typename Get_type::type Ray_d; typedef typename Get_type::type Iso_box_d; typedef typename Get_type::type Aff_transformation_d; typedef typename Get_functor::type Compute_coordinate_d; typedef typename Get_functor::type Compare_lexicographically_d; typedef typename Get_functor::type Equal_d; typedef typename Get_functor::type Less_lexicographically_d; typedef typename Get_functor::type Less_or_equal_lexicographically_d; // FIXME: and vectors? typedef typename Get_functor::type Orientation_d; typedef typename Get_functor::type Less_coordinate_d; typedef typename Get_functor::type Point_dimension_d; typedef typename Get_functor::type Side_of_oriented_sphere_d; typedef typename Get_functor::type Contained_in_affine_hull_d; typedef typename Get_functor::type Construct_flat_orientation_d; typedef typename Get_functor::type In_flat_orientation_d; typedef typename Get_functor::type In_flat_side_of_oriented_sphere_d; typedef typename Get_functor::type Point_to_vector_d; typedef typename Get_functor::type Vector_to_point_d; typedef typename Get_functor >::type Construct_point_d; typedef typename Get_functor >::type Construct_vector_d; typedef typename Get_functor >::type Construct_segment_d; typedef typename Get_functor >::type Construct_sphere_d; typedef typename Get_functor >::type Construct_hyperplane_d; typedef Construct_vector_d Construct_direction_d; typedef typename Get_functor >::type Construct_line_d; typedef typename Get_functor >::type Construct_ray_d; typedef typename Get_functor >::type Construct_iso_box_d; typedef typename Get_functor >::type Construct_aff_transformation_d; typedef typename Get_functor::type Midpoint_d; struct Component_accessor_d : private Store_kernel { CGAL_FUNCTOR_INIT_STORE(Component_accessor_d) int dimension(Point_d const&p){ return this->kernel().point_dimension_d_object()(p); } FT cartesian(Point_d const&p, int i){ return this->kernel().compute_coordinate_d_object()(p); } RT homogeneous(Point_d 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 Get_functor >::type CPI; typedef typename Get_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()(typename First_if_different::Type 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()(typename First_if_different::Type const&v, int)const{ return operator()(v, End_tag()); } }; typedef typename Construct_cartesian_const_iterator_d::result_type Cartesian_const_iterator_d; typedef typename Get_functor::type Squared_distance_d; //typedef typename Get_functor::type Affine_rank_d; //typedef typename Get_functor::type Affinely_independent_d; //typedef typename Get_functor::type Contained_in_linear_hull_d; //typedef typename Get_functor::type Contained_in_simplex_d; typedef typename Get_functor::type Has_on_positive_side_d; //typedef typename Get_functor::type Linear_rank_d; //typedef typename Get_functor::type Linearly_independent_d; typedef typename Get_functor::type Oriented_side_d; //typedef typename Get_functor::type Side_of_bounded_sphere_d; typedef typename Get_functor::type Center_of_sphere_d; typedef typename Get_functor::type Value_at_d; typedef typename Get_functor::type Point_of_sphere_d; typedef typename Get_functor::type Orthogonal_vector_d; //typedef typename Get_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 // CGAL_KD_KERNEL_D_INTERFACE_H