|
CGAL 6.0 - 3D Mesh Generation
|
The concept BisectionGeometricTraits_3 describes a geometric traits class that provides the basic types and operations to implement a model of MeshDomain_3 based solely on intersection detections. Points in the non-empty intersections are herein computed by bisection.
Such traits class is relevant when intersection detections can be performed efficiently. For instance, when bounding surfaces are implicitly described by a function (such as an isosurface of a 3D function from \( \mathbb{R}^3\) to \( \mathbb{R}\)), the do-intersect predicate with a segment is computed by evaluations of the function values at both end points of the segment.
Kernel Operations | |
The following functions give access to the predicate and construction objects: | |
| Compute_scalar_product_3 | compute_scalar_product_3_object () |
| Compute_squared_distance_3 | compute_squared_distance_3_object () |
| Compute_squared_radius_3 | compute_squared_radius_3_object () |
| Construct_center_3 | construct_center_3_object () |
| Construct_midpoint_3 | construct_midpoint_3_object () |
| Construct_point_on_3 | construct_point_on_3_object () |
| Construct_scaled_vector_3 | construct_scaled_vector_3_object () |
| Construct_segment_3 | construct_segment_3_object () |
| Construct_translated_point_3 | construct_translated_point_3_object () |
| Construct_vector_3 | construct_vector_3_object () |
| Has_on_bounded_side_3 | has_on_bounded_side_3_object () |
Model of Kernel::ComputeScalarProduct_3.
That function object must provide the operator:
FT operator()(Vector_3 v, Vector_3 w) which returns the scalar (inner) product of the two vectors v and w. Model of Kernel::ComputeSquaredDistance_3.
That function object must provide the operator:
FT operator()(Point_3, Point_3) which returns the squared distance between two points. Model of Kernel::ComputeSquaredRadius_3.
That function object must provide the operator:
FT operator()(Sphere_3 s) which returns the squared radius of s. Model of Kernel::ConstructCenter_3.
That function object must provide the operator:
Point_3 operator()(Sphere_3 s) which returns the center of the sphere s. Model of Kernel::ConstructMidpoint_3.
That function object must provide the operator:
Point_3 operator()(Point_3 p, Point_3 q) which computes the midpoint of the segment pq. Model of Kernel::ConstructPoint_3.
That function object must provide the following operators:
Point_3 operator()(Line_3 l,int i) which returns an arbitrary point on l. It holds point(i) == point(j), iff i==j. Furthermore, is directed from point(i) to point(j), for all i < j.Point_3 operator()(Ray_3 r,int i) which returns a point on r. point(0) is the source, point(i), with \( i>0\), is different from the source. Point_3 operator()(Segment_3 s,int i) which returns either source or target of s: point(0) returns the source of s, point(1) returns the target of s. Parameter i is taken modulo 2, which gives easy access to the other end point. Model of Kernel::ConstructScaledVector_3.
That function object must provide the operator:
Vector_3 operator()(Vector_3 v, FT scale) which returns the vector v scaled by a factor scale. Model of Kernel::ConstructSegment_3.
That function object must provide the operator:
Segment_3 operator()(Point_3 p, Point_3 q) which returns a segment with source p and target q, directed from the source to the target. Model of Kernel::ConstructTranslatedPoint_3.
That function object must provide the operator:
Point_3 operator()(Point_3 p, Vector_3 v) which returns the point obtained by translating p by the vector v. Model of Kernel::ConstructVertex_3.
That function object must provide the operator:
Vector_3 operator()(Point_3 a, Point_3 b) which returns the vector b-a. Numerical type.
Must be a model of FieldNumberType and FieldWithSqrt, and constructible from a double.
Model of Kernel::HasOnBoundedSide_3.
That function object must provide the operator:
bool operator()(Sphere_3 s, Point_3 p) which returns true iff p lies on the bounded side of s. The point type.
Must have a constructor Point_3(FT, FT, FT).