data structures - Secure usage of Cell_handle in a CGAL Delaunay triangulation after point insertion -


i'm planning write algorithm use cgal delaunay triangulation data structure. need insert point triangulation, save reference cells, , make other insertion.

i'm wondering how can store reference cells not invalidated after insertion of new points in triangulation?

it's seems me cell_handle pointer internal structure, it's dangerous store due reallocation of internal container. in other hand can see no way in triangulation_3 interface store index cell_handle.

typedef cgal::exact_predicates_inexact_constructions_kernel k; typedef cgal::triangulation_vertex_base_3<k>             vb; typedef cgal::triangulation_hierarchy_vertex_base_3<vb>  vbh; typedef cgal::triangulation_data_structure_3<vbh>        tds; typedef cgal::delaunay_triangulation_3<k,tds>            dt; typedef cgal::triangulation_hierarchy_3<dt>              dh; typedef dh::vertex_iterator vertex_iterator; typedef dh::vertex_handle   vertex_handle; typedef dh::point           point;  int main(){     dh t;    for(int = 0; < 100; ++i)       t.insert(point(rand()%1000,rand()%1000,rand()%1000));     assert( t.is_valid() );    assert( t.number_of_vertices() == 100 );    assert( t.dimension() == 3 );     typedef dh::cell_iterator celliterator;     std::vector<dh::cell_handle> hnd;    celliterator itend = t.finite_cells_end();    for(celliterator = t.finite_cells_begin(); it!=itend; ++it){       const int dist = std::distance(t.cells_begin(),it);       hnd.push_back(it);    }     const int newp(1000);    for(int = 0; < newp; ++i)       t.insert(point(rand()%1000,rand()%1000,rand()%1000));     int finitec(0),infinitec(0);    for(int = 0; < hnd.size(); ++i){       const int dist = std::distance(t.cells_begin(),hnd[i]);       if(t.is_infinite(hnd[i]))      ++infinitec;   else      ++finitec;    }    assert( t.is_valid() );    return 0; } 

this code systematically crash but, , strange me, if change newp 10000, code magically works.

can explain me how handle problem?

since cell can disappear during insertion of new point, handle have saved not guarantee point on expect.

you have crash because use triangulation hierarchy internally creates , remove cells in internal container. if use cgal::delaunay_triangulation_3, not have crash.

for problem, should store quadruplet of vertex_handles , use is_cell function (documented here).


Comments

Popular posts from this blog

c++ - Function signature as a function template parameter -

algorithm - What are some ways to combine a number of (potentially incompatible) sorted sub-sets of a total set into a (partial) ordering of the total set? -

How to call a javascript function after the page loads with a chrome extension? -