OpenVDB
9.0.1
|
#include <openvdb/math/Stencils.h>
Inherits BaseStencil< CurvatureStencil< GridT, IsSafe >, GridT, IsSafe >.
Public Types | |
typedef GridT | GridType |
typedef GridT::TreeType | TreeType |
typedef GridT::ValueType | ValueType |
typedef tree::ValueAccessor< const TreeType, IsSafe > | AccessorType |
typedef std::vector< ValueType > | BufferType |
typedef BufferType::iterator | IterType |
Public Member Functions | |
CurvatureStencil (const GridType &grid) | |
CurvatureStencil (const GridType &grid, Real 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... | |
std::pair< ValueType, ValueType > | principalCurvatures () const |
Return the pair (minimum, maximum) principal curvature at the previously buffered location. More... | |
ValueType | laplacian () const |
math::Vec3< ValueType > | gradient () const |
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... | |
int | size () |
Return the size of the stencil buffer. More... | |
ValueType | median () const |
Return the median value of the current 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=zeroVal< ValueType >()) const |
Return true if the center of the stencil intersects the iso-contour specified by the isoValue. More... | |
std::bitset< 6 > | intersectionMask (const ValueType &isoValue=zeroVal< ValueType >()) const |
Return true a bit-mask where the 6 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 Attributes | |
static const int | SIZE = 19 |
Protected Attributes | |
const GridType * | mGrid |
AccessorType | mAcc |
BufferType | mValues |
Coord | mCenter |
Friends | |
template<typename , typename , bool > | |
class | BaseStencil |
|
inherited |
|
inherited |
typedef GridT GridType |
|
inherited |
typedef GridT::TreeType TreeType |
typedef GridT::ValueType 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.
|
inline |
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.
|
inlineinherited |
Return true a bit-mask where the 6 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.test(2) where mask is ther return value from this function. To check if there are any intersections use mask.any(), and for no intersections use mask.none(). To count the number of intersections use mask.count().
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 median value of the current stencil.
|
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 stnecil 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.
Return the pair (minimum, maximum) principal curvature at the previously buffered location.
|
inlineinherited |
Set the value at the specified location relative to the center of the stencil.
|
inlineinherited |
Return the size of the stencil buffer.
|
friend |
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |
|
static |