HDK
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
HDK_Sample::UT_SolidAngle< T, S > Class Template Reference

#include <UT_SolidAngle.h>

Classes

struct  BoxData
 

Public Member Functions

 UT_SolidAngle ()
 This is outlined so that we don't need to include UT_BVHImpl.h. More...
 
 ~UT_SolidAngle ()
 This is outlined so that we don't need to include UT_BVHImpl.h. More...
 
 UT_SolidAngle (const int ntriangles, const int *const triangle_points, const int npoints, const UT_Vector3T< S > *const positions, const int order=2)
 
void init (const int ntriangles, const int *const triangle_points, const int npoints, const UT_Vector3T< S > *const positions, const int order=2)
 
void clear ()
 Frees myTree and myData, and clears the rest. More...
 
bool isClear () const
 Returns true if this is clear. More...
 
computeSolidAngle (const UT_Vector3T< T > &query_point, const T accuracy_scale=T(2.0)) const
 

Detailed Description

template<typename T, typename S>
class HDK_Sample::UT_SolidAngle< T, S >

Class for quickly approximating signed solid angle of a large mesh from many query points. This is useful for computing the generalized winding number at many points.

NOTE: This is currently only instantiated for <float,float>.

Definition at line 203 of file UT_SolidAngle.h.

Constructor & Destructor Documentation

template<typename T , typename S >
UT_SolidAngle< T, S >::UT_SolidAngle ( )

This is outlined so that we don't need to include UT_BVHImpl.h.

Definition at line 104 of file UT_SolidAngle.C.

template<typename T , typename S >
UT_SolidAngle< T, S >::~UT_SolidAngle ( )

This is outlined so that we don't need to include UT_BVHImpl.h.

Definition at line 116 of file UT_SolidAngle.C.

template<typename T, typename S>
HDK_Sample::UT_SolidAngle< T, S >::UT_SolidAngle ( const int  ntriangles,
const int *const  triangle_points,
const int  npoints,
const UT_Vector3T< S > *const  positions,
const int  order = 2 
)
inline

NOTE: This does not take ownership over triangle_points or positions, but does keep pointers to them, so the caller must keep them in scope for the lifetime of this structure.

Definition at line 214 of file UT_SolidAngle.h.

Member Function Documentation

template<typename T , typename S >
void UT_SolidAngle< T, S >::clear ( void  )

Frees myTree and myData, and clears the rest.

Definition at line 712 of file UT_SolidAngle.C.

template<typename T, typename S >
T UT_SolidAngle< T, S >::computeSolidAngle ( const UT_Vector3T< T > &  query_point,
const T  accuracy_scale = T(2.0) 
) const

Returns an approximation of the signed solid angle of the mesh from the specified query_point accuracy_scale is the value of (maxP/q) beyond which the approximation of the box will be used.

Definition at line 725 of file UT_SolidAngle.C.

template<typename T , typename S>
void UT_SolidAngle< T, S >::init ( const int  ntriangles,
const int *const  triangle_points,
const int  npoints,
const UT_Vector3T< S > *const  positions,
const int  order = 2 
)

Initialize the tree and data. NOTE: It is safe to call init on a UT_SolidAngle that has had init called on it before, to re-initialize it.

Definition at line 124 of file UT_SolidAngle.C.

template<typename T, typename S>
bool HDK_Sample::UT_SolidAngle< T, S >::isClear ( ) const
inline

Returns true if this is clear.

Definition at line 237 of file UT_SolidAngle.h.


The documentation for this class was generated from the following files: