|
FEAT 3
Finite Element Analysis Toolbox
|
Interface for voxel masker for the VoxelMap class. More...
#include <voxel_map.hpp>
Public Types | |
| typedef CoordType_ | CoordType |
| the coordinate type More... | |
| typedef Tiny::Vector< CoordType_, dim_ > | PointType |
| the point type More... | |
Public Member Functions | |
| virtual | ~VoxelMasker () |
| virtual destructor More... | |
| virtual void | mask_line (std::vector< int > &mask, const CoordType x_min, const CoordType x_max, const PointType &point)=0 |
| Computes the mask for an entire X-coordinate row. More... | |
Static Public Member Functions | |
| static CoordType | x_coord (const CoordType x_min, const CoordType x_max, const std::size_t i, const std::size_t n) |
| Computes the X-coordinate for a given point. More... | |
Interface for voxel masker for the VoxelMap class.
A voxel masker is basically an object that performs an inside-outside-test for some sort of geometrical object for a given point in X/Y/Z coordinates. To reduce the overhead introduced by virtual function calls, this class provides an abstract method mask_line that will perform the I/O-test for an entire row/line of points with common Y/Z coordinates at once rather than for a single point.
Definition at line 70 of file voxel_map.hpp.
| typedef CoordType_ FEAT::Geometry::VoxelMasker< CoordType_, dim_ >::CoordType |
the coordinate type
Definition at line 74 of file voxel_map.hpp.
| typedef Tiny::Vector<CoordType_, dim_> FEAT::Geometry::VoxelMasker< CoordType_, dim_ >::PointType |
the point type
Definition at line 76 of file voxel_map.hpp.
|
inlinevirtual |
virtual destructor
Definition at line 79 of file voxel_map.hpp.
|
pure virtual |
Computes the mask for an entire X-coordinate row.
This function is called by the VoxelMap class to perform the inside/outside-test for a line of points with common Y/Z coordinates, where the X coordinates of the points have to be computed from the X-coordinate range and the number points by calling the x_coord helper function.
| [in,out] | mask | The mask vector for the current X-row. Is allocated to correct size, but its contents are undefined upon entry. Assuming that the length of this vector is n, then the i-th entry of the mask vector is to be set to 1 if the point with the X-coordinate equal to x_coord(x_min, x_max, i, mask.size()) is inside the mask, otherwise it is to be set to 0. |
| [in] | x_min,x_max | The minimal and maximal X-coordinate of the X-line for which the mask is to be computed. |
| [in] | point | The point that contains the Y- and (in 3D) Z-coordinates of the X-line that for which the mask is to be computed. The first coordinate, i.e. point[0], is undefined, so only point[1] and (in 3D) point[2] are set to the Y-/Z-coords. |
Implemented in FEAT::Geometry::VoxelCGALMasker< CoordType_ >, FEAT::Geometry::VoxelLambdaMasker< Lambda_, CoordType_, dim_ >, and FEAT::Geometry::VoxelFormulaMasker< dim_ >.
Referenced by FEAT::Geometry::VoxelMap::_compute_voxel_map_lines().
|
inlinestatic |
Computes the X-coordinate for a given point.
This helper function can be used by derived classes to compute the X-coordinate for a single point on the mask line.
| [in] | x_min,x_max | The minimal and maximal X-coordinate of the X-line for which the mask is to be computed. |
| [in] | i | The index of the current point in the X-line that is being tested |
| [in] | n | The number of points in the line; corresponds to mask.size() |
Definition at line 101 of file voxel_map.hpp.
Referenced by FEAT::Geometry::VoxelLambdaMasker< Lambda_, CoordType_, dim_ >::mask_line().