如何使用CGAL循环器?

6

我正在尝试对点集进行德劳内三角剖分,找到离输入点最近的点,并获取它的相关顶点,但是以下代码似乎无法正常工作。

#include <CGAL/Exact_predicates_inexact_constructions_kernel.h>
#include <CGAL/Delaunay_triangulation_2.h>
#include <fstream>
typedef CGAL::Exact_predicates_inexact_constructions_kernel K;
typedef CGAL::Delaunay_triangulation_2<K> Triangulation;
typedef Triangulation::Edge_iterator Edge_iterator;
typedef Triangulation::Point Point;
typedef Triangulation::Vertex_handle Vertex_handle;
typedef Triangulation::Vertex_circulator Vertex_circulator;
int main( )
{
  std::ifstream in("data.txt");
  assert(in);
  std::istream_iterator<Point> begin(in);
  std::istream_iterator<Point> end;
  Triangulation T;
  T.insert(begin, end);
  std::cout << T.number_of_vertices() <<std::endl;
  Vertex_handle handle = T.nearest_vertex(Point(1, 1));
  std::cout << handle->point() << std::endl;
  std::cout<<"incidents: \n" << std::endl;
  Vertex_circulator circulator = T.incident_vertices(handle), done(circulator);
  do
    {
      std::cout << circulator->point() << std::endl;
    } while(++circulator != done);
  return 0;
}

例如,如果 data.txt 文件是这样的:
2 3
1 1
1 0

输出结果为

3
1 1
incidents:

1 0
2 3
2.02461e-307 6.94896e-308

为什么我的文本末尾会有一个奇怪的空白行?

1个回答

7
CGAL的2D三角剖分有一个无限顶点,连接到凸包的所有顶点(详见用户手册)。
您可以使用is_infinite函数测试一个单纯形是否为无限。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接