Moved Vtr::MaskInterface into Far::PrimvarRefiner:

- updated PrimvarRefiner to make use of now-local Mask class
    - renamed vtr/maskInterfaces.h to vtr/componentInterfaces.h
    - updated usage of renamed header file and CMakeLists.txt
This commit is contained in:
barfowl 2015-05-27 20:44:06 -07:00
parent 89544eec9c
commit 6ce3292576
5 changed files with 66 additions and 66 deletions

View File

@ -36,7 +36,7 @@
#include "../vtr/refinement.h" #include "../vtr/refinement.h"
#include "../vtr/fvarRefinement.h" #include "../vtr/fvarRefinement.h"
#include "../vtr/stackBuffer.h" #include "../vtr/stackBuffer.h"
#include "../vtr/maskInterfaces.h" #include "../vtr/componentInterfaces.h"
#include "../far/types.h" #include "../far/types.h"
#include "../far/error.h" #include "../far/error.h"
#include "../far/topologyLevel.h" #include "../far/topologyLevel.h"
@ -222,6 +222,50 @@ private:
private: private:
TopologyRefiner const & _refiner; TopologyRefiner const & _refiner;
private:
//
// Local class to fulfil interface for <typename MASK> in the Scheme mask queries:
//
class Mask {
public:
typedef float Weight; // Also part of the expected interface
public:
Mask(Weight* v, Weight* e, Weight* f) : _vertWeights(v), _edgeWeights(e), _faceWeights(f) { }
~Mask() { }
public: // Generic interface expected of <typename MASK>:
int GetNumVertexWeights() const { return _vertCount; }
int GetNumEdgeWeights() const { return _edgeCount; }
int GetNumFaceWeights() const { return _faceCount; }
void SetNumVertexWeights(int count) { _vertCount = count; }
void SetNumEdgeWeights( int count) { _edgeCount = count; }
void SetNumFaceWeights( int count) { _faceCount = count; }
Weight const& VertexWeight(int index) const { return _vertWeights[index]; }
Weight const& EdgeWeight( int index) const { return _edgeWeights[index]; }
Weight const& FaceWeight( int index) const { return _faceWeights[index]; }
Weight& VertexWeight(int index) { return _vertWeights[index]; }
Weight& EdgeWeight( int index) { return _edgeWeights[index]; }
Weight& FaceWeight( int index) { return _faceWeights[index]; }
bool AreFaceWeightsForFaceCenters() const { return _faceWeightsForFaceCenters; }
void SetFaceWeightsForFaceCenters(bool on) { _faceWeightsForFaceCenters = on; }
private:
Weight* _vertWeights;
Weight* _edgeWeights;
Weight* _faceWeights;
int _vertCount;
int _edgeCount;
int _faceCount;
bool _faceWeightsForFaceCenters;
};
}; };
@ -290,7 +334,7 @@ PrimvarRefiner::interpolateChildVertsFromFaces(
float fVaryingWeight = 1.0f / (float) fVerts.size(); float fVaryingWeight = 1.0f / (float) fVerts.size();
Vtr::internal::MaskInterface fMask(fVertWeights, 0, 0); Mask fMask(fVertWeights, 0, 0);
Vtr::internal::FaceInterface fHood(fVerts.size()); Vtr::internal::FaceInterface fHood(fVerts.size());
scheme.ComputeFaceVertexMask(fHood, fMask); scheme.ComputeFaceVertexMask(fHood, fMask);
@ -332,7 +376,7 @@ PrimvarRefiner::interpolateChildVertsFromEdges(
ConstIndexArray eVerts = parent.getEdgeVertices(edge), ConstIndexArray eVerts = parent.getEdgeVertices(edge),
eFaces = parent.getEdgeFaces(edge); eFaces = parent.getEdgeFaces(edge);
Vtr::internal::MaskInterface eMask(eVertWeights, 0, eFaceWeights); Mask eMask(eVertWeights, 0, eFaceWeights);
eHood.SetIndex(edge); eHood.SetIndex(edge);
@ -407,7 +451,7 @@ PrimvarRefiner::interpolateChildVertsFromVerts(
* vEdgeWeights = weightBuffer, * vEdgeWeights = weightBuffer,
* vFaceWeights = vEdgeWeights + vEdges.size(); * vFaceWeights = vEdgeWeights + vEdges.size();
Vtr::internal::MaskInterface vMask(&vVertWeight, vEdgeWeights, vFaceWeights); Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights);
vHood.SetIndex(vert, cVert); vHood.SetIndex(vert, cVert);
@ -662,7 +706,7 @@ PrimvarRefiner::faceVaryingInterpolateChildVertsFromFaces(
// Declare and compute mask weights for this vertex relative to its parent face: // Declare and compute mask weights for this vertex relative to its parent face:
ConstIndexArray fValues = parentFVar.getFaceValues(face); ConstIndexArray fValues = parentFVar.getFaceValues(face);
Vtr::internal::MaskInterface fMask(fValueWeights, 0, 0); Mask fMask(fValueWeights, 0, 0);
Vtr::internal::FaceInterface fHood(fValues.size()); Vtr::internal::FaceInterface fHood(fValues.size());
scheme.ComputeFaceVertexMask(fHood, fMask); scheme.ComputeFaceVertexMask(fHood, fMask);
@ -697,7 +741,7 @@ PrimvarRefiner::faceVaryingInterpolateChildVertsFromEdges(
float eVertWeights[2]; float eVertWeights[2];
Vtr::internal::StackBuffer<float,8> eFaceWeights(parentLevel.getMaxEdgeFaces()); Vtr::internal::StackBuffer<float,8> eFaceWeights(parentLevel.getMaxEdgeFaces());
Vtr::internal::MaskInterface eMask(eVertWeights, 0, eFaceWeights); Mask eMask(eVertWeights, 0, eFaceWeights);
bool isLinearFVar = parentFVar._isLinear; bool isLinearFVar = parentFVar._isLinear;
if (isLinearFVar) { if (isLinearFVar) {
@ -870,7 +914,7 @@ PrimvarRefiner::faceVaryingInterpolateChildVertsFromVerts(
float * vEdgeWeights = weightBuffer; float * vEdgeWeights = weightBuffer;
float * vFaceWeights = vEdgeWeights + vEdges.size(); float * vFaceWeights = vEdgeWeights + vEdges.size();
Vtr::internal::MaskInterface vMask(&vVertWeight, vEdgeWeights, vFaceWeights); Mask vMask(&vVertWeight, vEdgeWeights, vFaceWeights);
vHood.SetIndex(vert, cVert); vHood.SetIndex(vert, cVert);
@ -1056,9 +1100,9 @@ PrimvarRefiner::limit(T const & src, U & dstPos, U1 * dstTan1Ptr, U2 * dstTan2Pt
* eTan2Weights = eTan1Weights + maxWeightsPerMask, * eTan2Weights = eTan1Weights + maxWeightsPerMask,
* fTan2Weights = fTan1Weights + maxWeightsPerMask; * fTan2Weights = fTan1Weights + maxWeightsPerMask;
Vtr::internal::MaskInterface posMask( vPosWeights, ePosWeights, fPosWeights); Mask posMask( vPosWeights, ePosWeights, fPosWeights);
Vtr::internal::MaskInterface tan1Mask(vTan1Weights, eTan1Weights, fTan1Weights); Mask tan1Mask(vTan1Weights, eTan1Weights, fTan1Weights);
Vtr::internal::MaskInterface tan2Mask(vTan2Weights, eTan2Weights, fTan2Weights); Mask tan2Mask(vTan2Weights, eTan2Weights, fTan2Weights);
// This is a bit obscure -- assigning both parent and child as last level -- but // This is a bit obscure -- assigning both parent and child as last level -- but
// this mask type was intended for another purpose. Consider one for the limit: // this mask type was intended for another purpose. Consider one for the limit:
@ -1236,7 +1280,7 @@ PrimvarRefiner::faceVaryingLimit(T const & src, U * dst, int channel) const {
* eWeights = vWeights + 1, * eWeights = vWeights + 1,
* fWeights = eWeights + vEdges.size(); * fWeights = eWeights + vEdges.size();
Vtr::internal::MaskInterface vMask(vWeights, eWeights, fWeights); Mask vMask(vWeights, eWeights, fWeights);
vHood.SetIndex(vert, vert); vHood.SetIndex(vert, vert);

View File

@ -45,7 +45,7 @@
#include "../vtr/fvarLevel.h" #include "../vtr/fvarLevel.h"
#include "../vtr/fvarRefinement.h" #include "../vtr/fvarRefinement.h"
#include "../vtr/stackBuffer.h" #include "../vtr/stackBuffer.h"
#include "../vtr/maskInterfaces.h" #include "../vtr/componentInterfaces.h"
namespace OpenSubdiv { namespace OpenSubdiv {
namespace OPENSUBDIV_VERSION { namespace OPENSUBDIV_VERSION {

View File

@ -38,10 +38,10 @@ set(SOURCE_FILES
set(PUBLIC_HEADER_FILES set(PUBLIC_HEADER_FILES
array.h array.h
componentInterfaces.h
fvarLevel.h fvarLevel.h
fvarRefinement.h fvarRefinement.h
level.h level.h
maskInterfaces.h
quadRefinement.h quadRefinement.h
refinement.h refinement.h
sparseSelector.h sparseSelector.h

View File

@ -21,8 +21,8 @@
// KIND, either express or implied. See the Apache License for the specific // KIND, either express or implied. See the Apache License for the specific
// language governing permissions and limitations under the Apache License. // language governing permissions and limitations under the Apache License.
// //
#ifndef OPENSUBDIV3_VTR_INTERFACES_H #ifndef OPENSUBDIV3_VTR_COMPONENT_INTERFACES_H
#define OPENSUBDIV3_VTR_INTERFACES_H #define OPENSUBDIV3_VTR_COMPONENT_INTERFACES_H
#include "../version.h" #include "../version.h"
@ -41,60 +41,17 @@ namespace Vtr {
namespace internal { namespace internal {
// //
// Simple classes supporting the interfaces required of generic types in the Scheme mask // Simple classes supporting the interfaces required of generic topological
// queries, e.g. <typename FACE, MASK, etc.> // types in the Scheme mask queries, e.g. <typename FACE, VERTEX, etc.>
// //
// These were added solely to support the temporary Refinement::computeMasks(), which // These are not used with Vtr but arguably belong with it as the details to
// is not expected to persist in its current form. So these are for illustration purposes // write these efficiently depends very much on intimate details of Vtr's
// now and may eventually be moved elsewhere (likely into Far). // implmentation, e.g. the use of tag bits, subdivision Rules, etc.
// //
//
// For <typename MASK>, where the mask weights are stored:
//
class MaskInterface {
public:
typedef float Weight; // Also part of the expected interface
public:
MaskInterface(Weight* v, Weight* e, Weight* f) : _vertWeights(v), _edgeWeights(e), _faceWeights(f) { }
~MaskInterface() { }
public: // Generic interface expected of <typename MASK>:
int GetNumVertexWeights() const { return _vertCount; }
int GetNumEdgeWeights() const { return _edgeCount; }
int GetNumFaceWeights() const { return _faceCount; }
void SetNumVertexWeights(int count) { _vertCount = count; }
void SetNumEdgeWeights( int count) { _edgeCount = count; }
void SetNumFaceWeights( int count) { _faceCount = count; }
Weight const& VertexWeight(int index) const { return _vertWeights[index]; }
Weight const& EdgeWeight( int index) const { return _edgeWeights[index]; }
Weight const& FaceWeight( int index) const { return _faceWeights[index]; }
Weight& VertexWeight(int index) { return _vertWeights[index]; }
Weight& EdgeWeight( int index) { return _edgeWeights[index]; }
Weight& FaceWeight( int index) { return _faceWeights[index]; }
bool AreFaceWeightsForFaceCenters() const { return _faceWeightsForFaceCenters; }
void SetFaceWeightsForFaceCenters(bool on) { _faceWeightsForFaceCenters = on; }
private:
Weight* _vertWeights;
Weight* _edgeWeights;
Weight* _faceWeights;
int _vertCount;
int _edgeCount;
int _faceCount;
bool _faceWeightsForFaceCenters;
};
// //
// For <typename FACE>, which provides information int the neighborhood of a face: // For <typename FACE>, which provides information in the neighborhood of a face:
// //
class FaceInterface { class FaceInterface {
public: public:
@ -198,4 +155,4 @@ private:
using namespace OPENSUBDIV_VERSION; using namespace OPENSUBDIV_VERSION;
} // end namespace OpenSubdiv } // end namespace OpenSubdiv
#endif /* OPENSUBDIV3_VTR_INTERFACES_H */ #endif /* OPENSUBDIV3_VTR_COMPONENT_INTERFACES_H */

View File

@ -29,7 +29,6 @@
#include "../vtr/refinement.h" #include "../vtr/refinement.h"
#include "../vtr/fvarLevel.h" #include "../vtr/fvarLevel.h"
#include "../vtr/fvarRefinement.h" #include "../vtr/fvarRefinement.h"
#include "../vtr/maskInterfaces.h"
#include "../vtr/stackBuffer.h" #include "../vtr/stackBuffer.h"
#include <cassert> #include <cassert>