#include <list>
#include <cassert>
#include <CGAL/Exact_predicates_exact_constructions_kernel.h>
#include <CGAL/Arr_segment_traits_2.h>
#include <CGAL/Surface_sweep_2_algorithms.h>
int main() {
};
std::list<Point_2> pts;
std::cout << "Found " << pts.size() << " intersection points: " << std::endl;
std::copy(pts.begin(), pts.end(), std::ostream_iterator<Point_2>(std::cout, "\n"));
std::list<Segment_2> sub_segs;
std::cout << "Found " << sub_segs.size() << " interior-disjoint sub-segments." << std::endl;
return 0;
}
OutputIterator compute_subcurves(InputIterator curves_begin, InputIterator curves_end, OutputIterator subcurves, bool multiple_overlaps=false)
Given a range of curves, compute all -monotone subcurves that are pairwise disjoint in their interior...
bool do_intersect(InputIterator curves_begin, InputIterator curves_end, bool consider_common_endpoints=true)
Given a range of curves, check whether there is at least one pair of curves that intersect.
OutputIterator compute_intersection_points(InputIterator curves_begin, InputIterator curves_end, OutputIterator points, bool report_endpoints=false)
Given a range of curves, compute all intersection points between two (or more) input curves.