OpenVDB
9.0.1
|
#include <nanovdb/util/Stencils.h>
Inherits BaseStencil< CurvatureStencil< GridT >, 19, GridT >.
Public Types | |
using | GridType = GridT |
using | TreeType = typename GridT::TreeType |
using | ValueType = typename GridT::ValueType |
using | AccessorType = ReadAccessor< ValueType > |
Public Member Functions | |
CurvatureStencil (const GridType &grid) | |
CurvatureStencil (const GridType &grid, double dx) | |
ValueType | meanCurvature () const |
Return the mean curvature at the previously buffered location. More... | |
ValueType | gaussianCurvature () const |
Return the Gaussian curvature at the previously buffered location. More... | |
void | curvatures (ValueType &mean, ValueType &gauss) const |
Return both the mean and the Gaussian curvature at the previously buffered location. More... | |
ValueType | meanCurvatureNormGrad () const |
ValueType | gaussianCurvatureNormGrad () const |
void | curvaturesNormGrad (ValueType &mean, ValueType &gauss) const |
Return both the mean and the Gaussian curvature at the previously buffered location. More... | |
void | principalCurvatures (ValueType &min, ValueType &max) const |
Computes the minimum and maximum principal curvature at the previously buffered location. More... | |
ValueType | laplacian () const |
Vec3< ValueType > | gradient () const |
template<int i, int j, int k> | |
unsigned int | pos () const |
Return linear offset for the specified stencil point relative to its center. More... | |
void | moveTo (const Coord &ijk) |
Initialize the stencil buffer with the values of voxel (i, j, k) and its neighbors. More... | |
void | moveTo (const Coord &ijk, const ValueType ¢erValue) |
Initialize the stencil buffer with the values of voxel (i, j, k) and its neighbors. The method also takes a value of the center element of the stencil, assuming it is already known. More... | |
void | moveTo (const IterType &iter) |
Initialize the stencil buffer with the values of voxel (x, y, z) and its neighbors. More... | |
void | moveTo (const Vec3< RealType > &xyz) |
Initialize the stencil buffer with the values of voxel (x, y, z) and its neighbors. More... | |
const ValueType & | getValue (unsigned int pos=0) const |
Return the value from the stencil buffer with linear offset pos. More... | |
const ValueType & | getValue () const |
Return the value at the specified location relative to the center of the stencil. More... | |
void | setValue (const ValueType &value) |
Set the value at the specified location relative to the center of the stencil. More... | |
ValueType | mean () const |
Return the mean value of the current stencil. More... | |
ValueType | min () const |
Return the smallest value in the stencil buffer. More... | |
ValueType | max () const |
Return the largest value in the stencil buffer. More... | |
const Coord & | getCenterCoord () const |
Return the coordinates of the center point of the stencil. More... | |
const ValueType & | getCenterValue () const |
Return the value at the center of the stencil. More... | |
bool | intersects (const ValueType &isoValue=ValueType(0)) const |
Return true if the center of the stencil intersects the iso-contour specified by the isoValue. More... | |
Mask | intersectionMask (ValueType isoValue=ValueType(0)) const |
Return true a bit-mask where the 6 lower bits indicates if the center of the stencil intersects the iso-contour specified by the isoValue. More... | |
const GridType & | grid () const |
Return a const reference to the grid from which this stencil was constructed. More... | |
const AccessorType & | accessor () const |
Return a const reference to the ValueAccessor associated with this Stencil. More... | |
Static Public Member Functions | |
static int | size () |
Return the size of the stencil buffer. More... | |
Static Public Attributes | |
static constexpr int | SIZE = 19 |
Protected Attributes | |
const GridType * | mGrid |
AccessorType | mAcc |
ValueType | mValues [SIZE] |
Coord | mCenter |
Friends | |
template<typename , int , typename > | |
class | BaseStencil |
|
inherited |
using GridType = GridT |
using TreeType = typename GridT::TreeType |
using ValueType = typename GridT::ValueType |
|
inline |
|
inline |
|
inlineinherited |
Return a const reference to the ValueAccessor associated with this Stencil.
Return both the mean and the Gaussian curvature at the previously buffered location.
Return both the mean and the Gaussian curvature at the previously buffered location.
|
inline |
Return the Gaussian curvature at the previously buffered location.
|
inline |
Return the mean Gaussian multiplied by the norm of the central-difference gradient.
|
inlineinherited |
Return the coordinates of the center point of the stencil.
|
inlineinherited |
Return the value at the center of the stencil.
|
inlineinherited |
Return the value from the stencil buffer with linear offset pos.
|
inlineinherited |
Return the value at the specified location relative to the center of the stencil.
Return the gradient computed at the previously buffered location by second-order central differencing.
|
inlineinherited |
Return a const reference to the grid from which this stencil was constructed.
Return true a bit-mask where the 6 lower bits indicates if the center of the stencil intersects the iso-contour specified by the isoValue.
The ordering of bit mask is ( -x, +x, -y, +y, -z, +z ), so to check if there is an intersection in -y use (mask & (1u<<2)) where mask is ther return value from this function. To check if there are any intersections use mask!=0u, and for no intersections use mask==0u. To count the number of intersections use __builtin_popcount(mask).
Return true if the center of the stencil intersects the iso-contour specified by the isoValue.
|
inline |
Return the Laplacian computed at the previously buffered location by second-order central differencing.
|
inlineinherited |
Return the largest value in the stencil buffer.
|
inlineinherited |
Return the mean value of the current stencil.
|
inline |
Return the mean curvature at the previously buffered location.
|
inline |
Return the mean curvature multiplied by the norm of the central-difference gradient. This method is very useful for mean-curvature flow of level sets!
|
inlineinherited |
Return the smallest value in the stencil buffer.
|
inlineinherited |
Initialize the stencil buffer with the values of voxel (i, j, k) and its neighbors.
ijk | Index coordinates of stencil center |
Initialize the stencil buffer with the values of voxel (i, j, k) and its neighbors. The method also takes a value of the center element of the stencil, assuming it is already known.
ijk | Index coordinates of stencil center |
centerValue | Value of the center element of the stencil |
|
inlineinherited |
Initialize the stencil buffer with the values of voxel (x, y, z) and its neighbors.
|
inlineinherited |
Initialize the stencil buffer with the values of voxel (x, y, z) and its neighbors.
xyz | Floating point voxel coordinates of stencil center |
This method will check to see if it is necessary to update the stencil based on the cached index coordinates of the center point.
|
inline |
Return linear offset for the specified stencil point relative to its center.
Computes the minimum and maximum principal curvature at the previously buffered location.
|
inlineinherited |
Set the value at the specified location relative to the center of the stencil.
|
inlinestaticinherited |
Return the size of the stencil buffer.
|
friend |
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |
|
static |