forked from Pike1z/SETSM
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathedge_list.cpp
121 lines (109 loc) · 3.09 KB
/
edge_list.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#include <cstddef>
#include "basic_topology_types.hpp"
EdgeList::EdgeList(std::size_t num_points)
{
// 3F < 2E, E <= F + V <= (2/3)E + V <-> E <= 3V
// We store edge and twin, so need memory of 6*num_points
// Allocate all memory upfront and use stack structure
// (this->unused_edges + this->idx) to track currently
// unused memory
this->size = 6 * num_points;
this->idx = this->size;
this->edges = new Edge[this->size];
this->unused_edges = new Edge*[this->size];
for (std::size_t t = 0; t < this->size; t++)
{
this->unused_edges[t] = this->edges + t;
}
this->is_part_of_split = false;
this->is_local_copy = false;
}
EdgeList::EdgeList(Edge *edges, Edge **unused_edges, size_t num_points)
{
// Constructor used to make sub-EdgeList
// from a larger EdgeList
this->size = 6 * num_points;
this->idx = this->size;
this->edges = edges;
this->unused_edges = unused_edges;
this->is_part_of_split = true;
this->is_local_copy = false;
}
EdgeList::EdgeList(Edge *edges, size_t size)
{
// Constructor used to make local copy of EdgeList
// with its own empty unused_edges and idx
this->size = size;
this->idx = 0;
this->edges = edges;
this->local_copy_unused_edges = new std::vector<Edge *>();
this->is_part_of_split = false;
this->is_local_copy = true;
}
EdgeList::~EdgeList()
{
// If this is part of a split EdgeList, do not free any edge memory
if (this->is_part_of_split)
return;
// If this is part of a local copy, do not free main edge memory
if (this->is_local_copy)
{
delete this->local_copy_unused_edges;
return;
}
delete [] this->unused_edges;
delete [] this->edges;
}
Edge *EdgeList::GetNewEdge()
{
if (!this->is_local_copy) {
this->idx--;
return this->unused_edges[this->idx];
} else {
Edge *edge = this->local_copy_unused_edges->back();
this->local_copy_unused_edges->pop_back();
return edge;
}
}
void EdgeList::RemoveEdge(Edge &edge)
{
if (!this->is_local_copy) {
this->unused_edges[this->idx] = &edge;
this->idx++;
} else {
this->local_copy_unused_edges->push_back(&edge);
}
}
void EdgeList::SplitEdgeList(EdgeList *&left_list, EdgeList *&right_list, size_t median)
{
// Splits this into two sub EdgeLists with enough memory to store
// edges for a triangulation of median and (this->size / 6) - median
// points, respectively
left_list = new EdgeList(this->edges, this->unused_edges, median);
right_list = new EdgeList(this->edges + 6 * median, this->unused_edges + 6 * median, (this->size / 6) - median);
}
void EdgeList::MergeEdgeLists(EdgeList &left_list, EdgeList &right_list)
{
// Combine lists of unused edges, updating
// this->idx appropriately
this->idx = left_list.idx;
for (size_t t = 0; t < right_list.idx; t++)
{
this->unused_edges[this->idx + t] = right_list.unused_edges[t];
}
this->idx += right_list.idx;
}
void EdgeList::MergeUnused(EdgeList &local_list)
{
// Combine lists of unused edges, updating
// this->idx appropriately
for (Edge* edge : *local_list.local_copy_unused_edges)
{
this->unused_edges[this->idx++] = edge;
}
}
EdgeList *EdgeList::MakeLocalCopy()
{
EdgeList *local = new EdgeList(this->edges, this->size);
return local;
}