0020680: EDF 1252 SMESH: Bad cell created by Radial prism in center of torus

+  /*!
+   * \brief Return transformations to get coordinates of nodes of each internal layer
+   *        by nodes of the bottom. Layer is a set of nodes at a certain step
+   *        from bottom to top.
+   */
+  bool GetLayersTransformation(std::vector<gp_Trsf> & trsf) const;
This commit is contained in:
eap 2010-02-17 14:56:40 +00:00
parent 8cadb884f9
commit 0719fe6424

View File

@ -46,6 +46,7 @@
#include <BRepAdaptor_Surface.hxx> #include <BRepAdaptor_Surface.hxx>
#include <TopTools_IndexedMapOfOrientedShape.hxx> #include <TopTools_IndexedMapOfOrientedShape.hxx>
#include <gp_XYZ.hxx> #include <gp_XYZ.hxx>
#include <gp_Trsf.hxx>
class SMESHDS_SubMesh; class SMESHDS_SubMesh;
@ -58,7 +59,7 @@ typedef std::vector<const SMDS_MeshNode* > TNodeColumn;
// map of bottom nodes to the column of nodes above them // map of bottom nodes to the column of nodes above them
// (the column includes the bottom nodes) // (the column includes the bottom nodes)
typedef std::map< TNode, TNodeColumn > TNode2ColumnMap; typedef std::map< TNode, TNodeColumn > TNode2ColumnMap;
typedef std::map< double, TNodeColumn > TParam2ColumnMap; typedef std::map< double, TNodeColumn > TParam2ColumnMap;
typedef std::map< double, TNodeColumn >::const_iterator TParam2ColumnIt; typedef std::map< double, TNodeColumn >::const_iterator TParam2ColumnIt;
@ -73,11 +74,11 @@ typedef TopTools_IndexedMapOfOrientedShape TBlockShapes;
struct TNode struct TNode
{ {
const SMDS_MeshNode* myNode; const SMDS_MeshNode* myNode;
gp_XYZ myParams; mutable gp_XYZ myParams;
gp_XYZ GetCoords() const { return gp_XYZ( myNode->X(), myNode->Y(), myNode->Z() ); } gp_XYZ GetCoords() const { return gp_XYZ( myNode->X(), myNode->Y(), myNode->Z() ); }
gp_XYZ GetParams() const { return myParams; } gp_XYZ GetParams() const { return myParams; }
gp_XYZ& ChangeParams() { return myParams; } gp_XYZ& ChangeParams() const { return myParams; }
bool HasParams() const { return myParams.X() >= 0.0; } bool HasParams() const { return myParams.X() >= 0.0; }
SMDS_TypeOfPosition GetPositionType() const SMDS_TypeOfPosition GetPositionType() const
{ return myNode ? myNode->GetPosition()->GetTypeOfPosition() : SMDS_TOP_UNSPEC; } { return myNode ? myNode->GetPosition()->GetTypeOfPosition() : SMDS_TOP_UNSPEC; }
@ -144,13 +145,20 @@ public:
* \retval const TParam2ColumnMap& - map * \retval const TParam2ColumnMap& - map
*/ */
const TParam2ColumnMap& GetParam2ColumnMap(const int baseEdgeID, const TParam2ColumnMap& GetParam2ColumnMap(const int baseEdgeID,
bool & isReverse) bool & isReverse) const
{ {
std::pair< TParam2ColumnMap*, bool > & col_frw = std::pair< TParam2ColumnMap*, bool > col_frw =
myShapeIndex2ColumnMap[ baseEdgeID ]; myShapeIndex2ColumnMap.find( baseEdgeID )->second;
isReverse = !col_frw.second; isReverse = !col_frw.second;
return * col_frw.first; return * col_frw.first;
} }
/*!
* \brief Return transformations to get coordinates of nodes of each internal layer
* by nodes of the bottom. Layer is a set of nodes at a certain step
* from bottom to top.
*/
bool GetLayersTransformation(std::vector<gp_Trsf> & trsf) const;
/*! /*!
* \brief Return pointer to mesh * \brief Return pointer to mesh
@ -284,6 +292,8 @@ private:
int InsertSubShapes( TBlockShapes& shapeMap ) const; int InsertSubShapes( TBlockShapes& shapeMap ) const;
// redefine Adaptor methods // redefine Adaptor methods
gp_Pnt Value(const Standard_Real U,const Standard_Real V) const; gp_Pnt Value(const Standard_Real U,const Standard_Real V) const;
// debug
void dumpNodes(int nbNodes) const;
}; };
// -------------------------------------------------------------------- // --------------------------------------------------------------------
@ -299,6 +309,8 @@ private:
gp_Pnt Value(const Standard_Real U) const; gp_Pnt Value(const Standard_Real U) const;
Standard_Real FirstParameter() const { return 0; } Standard_Real FirstParameter() const { return 0; }
Standard_Real LastParameter() const { return 1; } Standard_Real LastParameter() const { return 1; }
// debug
void dumpNodes(int nbNodes) const;
}; };
// -------------------------------------------------------------------- // --------------------------------------------------------------------
@ -316,6 +328,8 @@ private:
gp_Pnt Value(const Standard_Real U) const; gp_Pnt Value(const Standard_Real U) const;
Standard_Real FirstParameter() const { return 0; } Standard_Real FirstParameter() const { return 0; }
Standard_Real LastParameter() const { return 1; } Standard_Real LastParameter() const { return 1; }
// debug
void dumpNodes(int nbNodes) const;
}; };
// -------------------------------------------------------------------- // --------------------------------------------------------------------
@ -337,20 +351,19 @@ private:
Standard_Real FirstParameter() const { return 0; } Standard_Real FirstParameter() const { return 0; }
Standard_Real LastParameter() const { return 1; } Standard_Real LastParameter() const { return 1; }
}; };
// --------------------------------------------------------------------
bool myNotQuadOnTop; bool myNotQuadOnTop;
SMESH_MesherHelper* myHelper; SMESH_MesherHelper* myHelper;
TBlockShapes myShapeIDMap; TBlockShapes myShapeIDMap;
SMESH_ComputeErrorPtr myError;
// container of 4 side faces // container of 4 side faces
TSideFace* mySide; TSideFace* mySide;
// node columns for each base edge // node columns for each base edge
std::vector< TParam2ColumnMap > myParam2ColumnMaps; std::vector< TParam2ColumnMap > myParam2ColumnMaps;
// to find a column for a node by edge SMESHDS Index // to find a column for a node by edge SMESHDS Index
std::map< int, std::pair< TParam2ColumnMap*, bool > > myShapeIndex2ColumnMap; std::map< int, std::pair< TParam2ColumnMap*, bool > > myShapeIndex2ColumnMap;
SMESH_ComputeErrorPtr myError;
/*! /*!
* \brief store error and comment and then return ( error == COMPERR_OK ) * \brief store error and comment and then return ( error == COMPERR_OK )
*/ */
@ -358,7 +371,6 @@ private:
myError = SMESH_ComputeError::New(error,comment); myError = SMESH_ComputeError::New(error,comment);
return myError->IsOK(); return myError->IsOK();
} }
//std::vector< SMESH_subMesh* > mySubMeshesVec; // submesh by in-block id
}; };
// ============================================= // =============================================
@ -432,7 +444,7 @@ private:
StdMeshers_PrismAsBlock myBlock; StdMeshers_PrismAsBlock myBlock;
SMESH_MesherHelper* myHelper; SMESH_MesherHelper* myHelper;
std::vector<gp_XYZ> myShapeXYZ; // point on each sub-shape std::vector<gp_XYZ> myShapeXYZ; // point on each sub-shape of the block
// map of bottom nodes to the column of nodes above them // map of bottom nodes to the column of nodes above them
// (the column includes the bottom node) // (the column includes the bottom node)