The vertices of a mesh.
More...
#include <geogram/mesh/mesh.h>
The vertices of a mesh.
Definition at line 322 of file mesh.h.
◆ assign_points() [1/2]
void GEO::MeshVertices::assign_points |
( |
const double * |
points, |
|
|
index_t |
dim, |
|
|
index_t |
nb_pts |
|
) |
| |
Assigns all the points.
- Parameters
-
[in] | points | a const pointer to the (dim * nb_pts ) coordinates of al the points |
[in] | dim | the dimension of the points, i.e. number of coordinates per point |
[in] | nb_pts | number of points |
◆ assign_points() [2/2]
void GEO::MeshVertices::assign_points |
( |
vector< double > & |
points, |
|
|
index_t |
dim, |
|
|
bool |
steal_arg |
|
) |
| |
Assigns all the points.
- Parameters
-
[in] | points | a vector that contains all the coordinates of the points |
[in] | dim | the dimension of the points, i.e. number of coordinates per point |
[in] | steal_arg | if true, memory is stolen from points , using std::vector::swap (no memory copy). |
◆ clear()
void GEO::MeshVertices::clear |
( |
bool |
keep_attributes = true , |
|
|
bool |
keep_memory = false |
|
) |
| |
|
overridevirtual |
Removes all the elements and attributes.
- Parameters
-
[in] | keep_attributes | if true, then all the existing attribute names / bindings are kept (but they are cleared). If false, they are destroyed. |
[in] | keep_memory | if true, then memory is kept and can be reused by subsequent mesh element creations. |
Implements GEO::MeshElements.
◆ clear_store()
void GEO::MeshVertices::clear_store |
( |
bool |
keep_attributes, |
|
|
bool |
keep_memory = false |
|
) |
| |
|
overrideprotectedvirtual |
Removes all the elements and attributes.
- Parameters
-
[in] | keep_attributes | if true, then all the existing attribute names / bindings are kept (but they are cleared). If false, they are destroyed. |
[in] | keep_memory | if true, then memory is kept and can be reused by subsequent mesh element creations. |
Reimplemented from GEO::MeshSubElementsStore.
◆ copy()
void GEO::MeshVertices::copy |
( |
const MeshVertices & |
rhs, |
|
|
bool |
copy_attributes = true |
|
) |
| |
|
inlineprotected |
◆ create_vertex() [1/2]
index_t GEO::MeshVertices::create_vertex |
( |
| ) |
|
|
inline |
Creates a new vertex.
- Returns
- the index of the created vertex
Definition at line 344 of file mesh.h.
◆ create_vertex() [2/2]
index_t GEO::MeshVertices::create_vertex |
( |
const double * |
coords | ) |
|
|
inline |
Creates a new vertex.
- Parameters
-
- Returns
- the index of the created vertex
Definition at line 353 of file mesh.h.
◆ create_vertices()
Creates a contiguous chunk of vertices.
- Parameters
-
[in] | nb | number of sub-elements to create |
- Returns
- the index of the first created vertex
Definition at line 375 of file mesh.h.
◆ delete_elements()
void GEO::MeshVertices::delete_elements |
( |
vector< index_t > & |
to_delete, |
|
|
bool |
remove_isolated_vertices = true |
|
) |
| |
|
overridevirtual |
Deletes a set of elements.
- Parameters
-
[in] | to_delete | a vector of size nb(). If to_delete[e] is different from 0, then element e will be destroyed, else it will be kept. On exit, to_delete is modified (it is used for internal bookkeeping). |
[in] | remove_isolated_vertices | if true, then the vertices that are no longer incident to any element are deleted. |
Implements GEO::MeshElements.
◆ dimension()
index_t GEO::MeshVertices::dimension |
( |
| ) |
const |
|
inline |
Gets the dimension of the vertices.
- Returns
- the number of coordinates in each vertex
Definition at line 427 of file mesh.h.
◆ double_precision()
bool GEO::MeshVertices::double_precision |
( |
| ) |
const |
|
inline |
Tests whether vertices are stored in double-precision mode.
Double precision mode is the default. Single-precision mode is used for instance by Vorpaview, to make it more memory efficient.
Definition at line 419 of file mesh.h.
◆ permute_elements()
void GEO::MeshVertices::permute_elements |
( |
vector< index_t > & |
permutation | ) |
|
|
overridevirtual |
Applies a permutation to the elements and their attributes.
On exit, permutation is modified (used for internal bookkeeping). Applying a permutation permutation
is equivalent to:
for(i=0; i<permutation.size(); i++) {
data2[i] = data[permutation[i]]
}
data = data2 ;
Implements GEO::MeshElements.
◆ point() [1/2]
Gets a point.
- Parameters
-
[in] | v | the vertex, in 0..nb()-1 |
- Returns
- a modifiable reference to the point that corresponds to the vertex
- Precondition
- !single_precision()
Definition at line 482 of file mesh.h.
◆ point() [2/2]
const vec3 & GEO::MeshVertices::point |
( |
index_t |
v | ) |
const |
|
inline |
Gets a point.
- Parameters
-
[in] | v | the vertex, in 0..nb()-1 |
- Returns
- a const reference to the point that corresponds to the vertex
- Precondition
- !single_precision()
Definition at line 496 of file mesh.h.
◆ point_ptr() [1/2]
double * GEO::MeshVertices::point_ptr |
( |
index_t |
v | ) |
|
|
inline |
Gets a point.
- Parameters
-
[in] | v | the vertex, in 0..nb()-1 |
- Returns
- a pointer to the coordinates of the point that correspond to the vertex
- Precondition
- !single_precision()
Definition at line 468 of file mesh.h.
◆ point_ptr() [2/2]
const double * GEO::MeshVertices::point_ptr |
( |
index_t |
v | ) |
const |
|
inline |
Gets a point.
- Parameters
-
[in] | v | the index of the vertex |
- Returns
- a const pointer to the coordinates of the point that correspond to the vertex
- Precondition
- !single_precision()
Definition at line 455 of file mesh.h.
◆ pop()
void GEO::MeshVertices::pop |
( |
| ) |
|
|
overridevirtual |
◆ resize_store()
void GEO::MeshVertices::resize_store |
( |
index_t |
new_size | ) |
|
|
overrideprotectedvirtual |
◆ set_dimension()
void GEO::MeshVertices::set_dimension |
( |
index_t |
dim | ) |
|
|
inline |
Sets the dimension of the vertices.
Existing coordinates are kept, newly created coordinates are initialized to zero.
- Parameters
-
Definition at line 440 of file mesh.h.
◆ set_double_precision()
void GEO::MeshVertices::set_double_precision |
( |
| ) |
|
Sets double precision mode.
Double precision mode is the default. Single-precision mode is used for instance by Vorpaview, to make it more memory efficient. Existing point coordinates are copied and converted to double precision.
◆ set_single_precision()
void GEO::MeshVertices::set_single_precision |
( |
| ) |
|
Sets single precision mode.
Single-precision mode is used for instance by Vorpaview, to make it more memory efficient. Existing point coordinates are copied and converted to single precision.
◆ single_precision()
bool GEO::MeshVertices::single_precision |
( |
| ) |
const |
|
inline |
Tests whether vertices are stored in single-precision mode.
Single-precision mode is used for instance by Vorpaview, to make it more memory efficient.
Definition at line 408 of file mesh.h.
◆ single_precision_point_ptr() [1/2]
float * GEO::MeshVertices::single_precision_point_ptr |
( |
index_t |
v | ) |
|
|
inline |
Gets a (single-precision) point.
- Parameters
-
[in] | v | the index of the vertex |
- Returns
- a pointer to the coordinates of the point that corresponds to the vertex
- Precondition
- single_precision()
Definition at line 523 of file mesh.h.
◆ single_precision_point_ptr() [2/2]
const float * GEO::MeshVertices::single_precision_point_ptr |
( |
index_t |
v | ) |
const |
|
inline |
Gets a (single-precision) point.
- Parameters
-
[in] | v | the index of the vertex |
- Returns
- a const pointer to the coordinates of the point that corresponds to the vertex
- Precondition
- single_precision()
Definition at line 510 of file mesh.h.
◆ GeogramIOHandler
friend class GeogramIOHandler |
|
friend |
◆ Mesh
◆ cell_corners_
◆ edges_
◆ facet_corners_
◆ point_
◆ point_fp32_
Attribute<float> GEO::MeshVertices::point_fp32_ |
|
protected |
The documentation for this class was generated from the following file: