59 int _completed_surface;
62 std::set<Ref<Vertex> > _vertices;
63 std::set<Ref<Edge> > _edges;
64 std::set<Ref<Triangle> > _triangles;
67 std::map<Ref<Vertex>,
int> _vertex_to_index;
68 std::map<Ref<Edge>,
int> _edge_to_index;
69 std::map<Ref<Triangle>,
int> _triangle_to_index;
72 std::vector<Ref<Vertex> > _index_to_vertex;
73 std::vector<Ref<Edge> > _index_to_edge;
74 std::vector<Ref<Triangle> > _index_to_triangle;
77 int** _triangle_vertex;
83 std::vector<double> _values;
92 void clear_int_arrays();
94 void complete_ref_arrays();
95 void complete_int_arrays();
97 void recompute_index_maps();
110 int orientation)
const;
114 std::map<Ref<Vertex>,std::set<Ref<Edge> > > _tmp_edges;
121 int verbose()
const {
return _verbose; }
122 void verbose(
int v) { _verbose = v; }
137 virtual void complete_surface();
140 virtual void remove_short_edges(
double cutoff_length = 1.0e-6,
142 virtual void remove_slender_triangles(
143 int remove_slender,
double height_cutoff,
144 int remove_small,
double area_cutoff,
146 virtual void fix_orientation();
147 virtual void clear();
150 int nvertex()
const {
return _vertices.size(); };
151 Ref<Vertex> vertex(
int i)
const {
return _index_to_vertex[i]; };
153 std::map<Ref<Vertex>,
int>::iterator i = _vertex_to_index.find(o);
154 if (i != _vertex_to_index.end())
return i->second;
157 int nedge()
const {
return _edges.size(); };
158 Ref<Edge> edge(
int i)
const {
return _index_to_edge[i]; };
160 std::map<Ref<Edge>,
int>::iterator i = _edge_to_index.find(o);
161 if (i != _edge_to_index.end())
return i->second;
164 int ntriangle()
const {
return _triangles.size(); };
165 Ref<Triangle> triangle(
int i)
const {
return _index_to_triangle[i]; }
167 std::map<Ref<Triangle>,
int>::iterator i = _triangle_to_index.find(o);
168 if (i != _triangle_to_index.end())
return i->second;
173 int triangle_vertex(
int i,
int j)
const {
return _triangle_vertex[i][j]; };
174 int triangle_edge(
int i,
int j)
const {
return _triangle_edge[i][j]; };
175 int edge_vertex(
int i,
int j)
const {
return _edge_vertex[i][j]; };
182 virtual double flat_area();
183 virtual double flat_volume();
184 virtual double area();
185 virtual double volume();
189 virtual void print_vertices_and_triangles(std::ostream&o=
ExEnv::out0())
const;
190 virtual void print_geomview_format(std::ostream&o=
ExEnv::out0())
const;
195 void topology_info(
int nvertex,
int nedge,
int ntri, std::ostream&o=
ExEnv::out0());