gpt4 book ai didi

c++ - 如何使用 cgal 循环器?

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:31:18 25 4
gpt4 key购买 nike

我正在尝试对点集进行 delaunay 三角剖分,找到离输入点最近的点,并获取它的事件顶点,但不知何故,以下代码不起作用。

#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

为什么我有最后一行?

最佳答案

CGAL的二维三角剖分有一个无限顶点连接到凸包的所有顶点(详见user manual)。

您可以使用 is_infinite 函数来测试单纯形是否无限。

关于c++ - 如何使用 cgal 循环器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22809284/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com