diff --git a/src/BOPAlgo/BOPAlgo_Builder.cxx b/src/BOPAlgo/BOPAlgo_Builder.cxx index a015c50aca..4dd493d073 100644 --- a/src/BOPAlgo/BOPAlgo_Builder.cxx +++ b/src/BOPAlgo/BOPAlgo_Builder.cxx @@ -362,7 +362,6 @@ void BOPAlgo_Builder::PerformInternal(const BOPAlgo_PaveFiller& theFiller) //======================================================================= void BOPAlgo_Builder::PostTreat() { - //BRepLib::SameParameter(myShape, 1.e-7, Standard_True); - BOPTools_AlgoTools::CorrectTolerances(myShape, 0.05); - BOPTools_AlgoTools::CorrectShapeTolerances(myShape); + BOPTools_AlgoTools::CorrectTolerances(myShape, 0.05, myRunParallel); + BOPTools_AlgoTools::CorrectShapeTolerances(myShape, myRunParallel); } diff --git a/src/BOPTools/BOPTools_AlgoTools.cdl b/src/BOPTools/BOPTools_AlgoTools.cdl index 541cd52f9a..d4db6710b6 100644 --- a/src/BOPTools/BOPTools_AlgoTools.cdl +++ b/src/BOPTools/BOPTools_AlgoTools.cdl @@ -46,60 +46,60 @@ uses is ComputeVV(myclass; - aV1:Vertex from TopoDS; - aP2:Pnt from gp; - aTolP2:Real from Standard) - returns Integer from Standard; + aV1:Vertex from TopoDS; + aP2:Pnt from gp; + aTolP2:Real from Standard) + returns Integer from Standard; ComputeVV(myclass; - aV1:Vertex from TopoDS; - aV2:Vertex from TopoDS) - returns Integer from Standard; + aV1:Vertex from TopoDS; + aV2:Vertex from TopoDS) + returns Integer from Standard; MakeVertex (myclass; - aLV: out ListOfShape from BOPCol; - aV : out Vertex from TopoDS); + aLV: out ListOfShape from BOPCol; + aV : out Vertex from TopoDS); MakeEdge(myclass; - theCurve:Curve from IntTools; - theV1: Vertex from TopoDS; - theT1: Real from Standard; - theV2: Vertex from TopoDS; - theT2: Real from Standard; - theTolR3D: Real from Standard; - theE :out Edge from TopoDS); + theCurve:Curve from IntTools; + theV1: Vertex from TopoDS; + theT1: Real from Standard; + theV2: Vertex from TopoDS; + theT2: Real from Standard; + theTolR3D: Real from Standard; + theE :out Edge from TopoDS); MakePCurve(myclass; - theE : Edge from TopoDS; - theF1: Face from TopoDS; - theF2: Face from TopoDS; - theCurve:Curve from IntTools; - thePC1:Boolean from Standard; - thePC2:Boolean from Standard); + theE : Edge from TopoDS; + theF1: Face from TopoDS; + theF2: Face from TopoDS; + theCurve:Curve from IntTools; + thePC1:Boolean from Standard; + thePC2:Boolean from Standard); MakeContainer(myclass; - theType:ShapeEnum from TopAbs; - theShape:out Shape from TopoDS); + theType:ShapeEnum from TopAbs; + theShape:out Shape from TopoDS); IsHole(myclass; - aW: Shape from TopoDS; - aF: Shape from TopoDS) - returns Boolean from Standard; + aW: Shape from TopoDS; + aF: Shape from TopoDS) + returns Boolean from Standard; IsSplitToReverse(myclass; - theSplit : Shape from TopoDS; - theShape : Shape from TopoDS; - theContext:out Context from BOPInt) + theSplit : Shape from TopoDS; + theShape : Shape from TopoDS; + theContext:out Context from BOPInt) ---Purpose: Returns True if the shape theSplit has opposite -- direction than theShape -- theContext - cashed geometrical tools returns Boolean from Standard; IsSplitToReverse(myclass; - theSplit : Face from TopoDS; - theShape : Face from TopoDS; - theContext:out Context from BOPInt) + theSplit : Face from TopoDS; + theShape : Face from TopoDS; + theContext:out Context from BOPInt) ---Purpose: Returns True if normal direction of the face -- theShape is not the same as for the face -- theSplit @@ -107,33 +107,33 @@ is returns Boolean from Standard; IsSplitToReverse (myclass; - aE1: Edge from TopoDS; - aE2: Edge from TopoDS; - aContext:out Context from BOPInt) - returns Boolean from Standard; + aE1: Edge from TopoDS; + aE2: Edge from TopoDS; + aContext:out Context from BOPInt) + returns Boolean from Standard; AreFacesSameDomain(myclass; - theF1: Face from TopoDS; - theF2: Face from TopoDS; - theContext:out Context from BOPInt) - returns Boolean from Standard; + theF1: Face from TopoDS; + theF2: Face from TopoDS; + theContext:out Context from BOPInt) + returns Boolean from Standard; CheckSameGeom (myclass; - theF1: Face from TopoDS; - theF2: Face from TopoDS; - theContext:out Context from BOPInt) - returns Boolean from Standard; + theF1: Face from TopoDS; + theF2: Face from TopoDS; + theContext:out Context from BOPInt) + returns Boolean from Standard; Sense (myclass; - theF1: Face from TopoDS; - theF2: Face from TopoDS) - returns Integer from Standard; + theF1: Face from TopoDS; + theF2: Face from TopoDS) + returns Integer from Standard; GetEdgeOff (myclass; - theEdge :Edge from TopoDS; - theFace :Face from TopoDS; - theEdgeOff :out Edge from TopoDS) + theEdge :Edge from TopoDS; + theFace :Face from TopoDS; + theEdgeOff :out Edge from TopoDS) ---Purpose: Returns True if the face theFace contains -- the edge theEdge but with opposite orientation. -- If the method returns True theEdgeOff is the @@ -141,12 +141,12 @@ is returns Boolean from Standard; GetFaceOff(myclass; - theEdge :Edge from TopoDS; - theFace :Face from TopoDS; - theLCEF :out ListOfCoupleOfShape from BOPTools; - theFaceOff :out Face from TopoDS; - theContext :out Context from BOPInt) - returns Boolean from Standard; + theEdge :Edge from TopoDS; + theFace :Face from TopoDS; + theLCEF :out ListOfCoupleOfShape from BOPTools; + theFaceOff :out Face from TopoDS; + theContext :out Context from BOPInt) + returns Boolean from Standard; ---Purpose: For the face theFace and its edge theEdge -- finds the face suitable to produce shell. @@ -154,11 +154,11 @@ is -- from theLCEF must share edge theEdge IsInternalFace(myclass; - theFace :Face from TopoDS; - theEdge :Edge from TopoDS; - theFace1 :Face from TopoDS; - theFace2 :Face from TopoDS; - theContext:out Context from BOPInt) + theFace :Face from TopoDS; + theEdge :Edge from TopoDS; + theFace1 :Face from TopoDS; + theFace2 :Face from TopoDS; + theContext:out Context from BOPInt) ---Purpose: Returns True if the face theFace is inside of the -- couple of faces theFace1, theFace2. -- The faces theFace, theFace1, theFace2 must @@ -166,10 +166,10 @@ is returns Integer from Standard; IsInternalFace(myclass; - theFace :Face from TopoDS; - theEdge :Edge from TopoDS; - theLF :out ListOfShape from BOPCol; - theContext:out Context from BOPInt) + theFace :Face from TopoDS; + theEdge :Edge from TopoDS; + theLF :out ListOfShape from BOPCol; + theContext:out Context from BOPInt) ---Purpose: Returns True if the face theFace is inside of the -- appropriate couple of faces (from the set theLF) . -- The faces of the set theLF and theFace must @@ -177,11 +177,11 @@ is returns Integer from Standard; IsInternalFace(myclass; - theFace :Face from TopoDS; - theSolid :Solid from TopoDS; - theMEF :out IndexedDataMapOfShapeListOfShape from BOPCol; - theTol :Real from Standard; - theContext:out Context from BOPInt) + theFace :Face from TopoDS; + theSolid :Solid from TopoDS; + theMEF :out IndexedDataMapOfShapeListOfShape from BOPCol; + theTol :Real from Standard; + theContext:out Context from BOPInt) ---Purpose: Returns True if the face theFace is inside the -- solid theSolid. -- theMEF - Map Edge/Faces for theSolid @@ -191,9 +191,9 @@ is GetEdgeOnFace (myclass; - theEdge :Edge from TopoDS; - theFace :Face from TopoDS; - theEdgeOnF :out Edge from TopoDS) + theEdge :Edge from TopoDS; + theFace :Face from TopoDS; + theEdgeOnF :out Edge from TopoDS) ---Purpose: For the face theFace gets the edge theEdgeOnF -- that is the same as theEdge -- Returns True if such edge exists @@ -201,10 +201,10 @@ is returns Boolean from Standard; ComputeState(myclass; - thePoint :Pnt from gp; - theSolid :Solid from TopoDS; - theTol :Real from Standard; - theContext:out Context from BOPInt) + thePoint :Pnt from gp; + theSolid :Solid from TopoDS; + theTol :Real from Standard; + theContext:out Context from BOPInt) ---Purpose: Computes the 3-D state of the point thePoint -- toward solid theSolid. -- theTol - value of precision of computation @@ -213,10 +213,10 @@ is returns State from TopAbs; ComputeState(myclass; - theVertex:Vertex from TopoDS; - theSolid :Solid from TopoDS; - theTol :Real from Standard; - theContext:out Context from BOPInt) + theVertex:Vertex from TopoDS; + theSolid :Solid from TopoDS; + theTol :Real from Standard; + theContext:out Context from BOPInt) ---Purpose: Computes the 3-D state of the vertex theVertex -- toward solid theSolid. -- theTol - value of precision of computation @@ -225,10 +225,10 @@ is returns State from TopAbs; ComputeState(myclass; - theEdge :Edge from TopoDS; - theSolid :Solid from TopoDS; - theTol :Real from Standard; - theContext:out Context from BOPInt) + theEdge :Edge from TopoDS; + theSolid :Solid from TopoDS; + theTol :Real from Standard; + theContext:out Context from BOPInt) ---Purpose: Computes the 3-D state of the edge theEdge -- toward solid theSolid. -- theTol - value of precision of computation @@ -237,11 +237,11 @@ is returns State from TopAbs; ComputeState(myclass; - theFace :Face from TopoDS; - theSolid :Solid from TopoDS; - theTol :Real from Standard; - theBounds:out IndexedMapOfShape from BOPCol; - theContext:out Context from BOPInt) + theFace :Face from TopoDS; + theSolid :Solid from TopoDS; + theTol :Real from Standard; + theBounds:out IndexedMapOfShape from BOPCol; + theContext:out Context from BOPInt) ---Purpose: Computes the 3-D state of the face theFace -- toward solid theSolid. -- theTol - value of precision of computation @@ -251,10 +251,10 @@ is returns State from TopAbs; ComputeStateByOnePoint(myclass; - theShape :Shape from TopoDS; - theSolid :Solid from TopoDS; - theTol :Real from Standard; - theContext:out Context from BOPInt) + theShape :Shape from TopoDS; + theSolid :Solid from TopoDS; + theTol :Real from Standard; + theContext:out Context from BOPInt) ---Purpose: Computes the 3-D state of the shape theShape -- toward solid theSolid. -- theTol - value of precision of computation @@ -263,30 +263,32 @@ is returns State from TopAbs; MakeConnexityBlock(myclass; - theLS :out ListOfShape from BOPCol; - theMapAvoid:out IndexedMapOfShape from BOPCol; - theLSCB :out ListOfShape from BOPCol; - theAllocator:BaseAllocator from BOPCol); + theLS :out ListOfShape from BOPCol; + theMapAvoid:out IndexedMapOfShape from BOPCol; + theLSCB :out ListOfShape from BOPCol; + theAllocator:BaseAllocator from BOPCol); ---Purpose: For the list of faces theLS build block -- theLSCB in terms of connexity by edges -- theMapAvoid - set of edges to avoid for -- the treatment MakeConnexityBlocks(myclass; - theS :Shape from TopoDS; - theType1 :ShapeEnum from TopAbs; - theType2 :ShapeEnum from TopAbs; - theLCB :out ListOfShape from BOPCol); + theS :Shape from TopoDS; + theType1 :ShapeEnum from TopAbs; + theType2 :ShapeEnum from TopAbs; + theLCB :out ListOfShape from BOPCol); ---Purpose: For the compound theS build the blocks -- theLCB (as list of compounds) -- in terms of connexity by the shapes of theType OrientFacesOnShell (myclass; - theS :out Shape from TopoDS); + theS :out Shape from TopoDS); CorrectTolerances (myclass; - theS: Shape from TopoDS; - theTolMax: Real from Standard =0.0001); + theS: Shape from TopoDS; + theTolMax: Real from Standard =0.0001; + theRunParallel: Boolean from Standard=Standard_False); + ---Purpose: --- Provides valid values of tolerances for the shape --- is max value of the tolerance that can be @@ -295,15 +297,17 @@ is --- perform. --- CorrectCurveOnSurface (myclass; - theS: Shape from TopoDS; - theTolMax: Real from Standard =0.0001); + theS: Shape from TopoDS; + theTolMax: Real from Standard =0.0001; + theRunParallel: Boolean from Standard=Standard_False); ---Purpose: --- Provides valid values of tolerances for the shape --- in terms of BRepCheck_InvalidCurveOnSurface. --- CorrectPointOnCurve (myclass; - theS: Shape from TopoDS; - theTolMax: Real from Standard =0.0001); + theS: Shape from TopoDS; + theTolMax: Real from Standard =0.0001; + theRunParallel: Boolean from Standard=Standard_False); ---Purpose: --- Provides valid values of tolerances for the shape --- in terms of BRepCheck_InvalidPointOnCurve. @@ -312,9 +316,9 @@ is --copy from BOPTools_AlgoTools.cdl MakeNewVertex (myclass; - aP1 : Pnt from gp; - aTol: Real from Standard; - aNewVertex:out Vertex from TopoDS); + aP1 : Pnt from gp; + aTol: Real from Standard; + aNewVertex:out Vertex from TopoDS); ---Purpose: --- Make a vertex using 3D-point and 3D-tolerance value --- @@ -325,74 +329,74 @@ is --- Make a vertex using couple of vertices --- MakeNewVertex (myclass; - aE1: Edge from TopoDS; - aP1: Real from Standard; - aE2: Edge from TopoDS; - aP2: Real from Standard; - aNewVertex:out Vertex from TopoDS); + aE1: Edge from TopoDS; + aP1: Real from Standard; + aE2: Edge from TopoDS; + aP2: Real from Standard; + aNewVertex:out Vertex from TopoDS); ---Purpose: --- Make a vertex in place of intersection between two edges --- with parameters --- MakeNewVertex (myclass; - aE1: Edge from TopoDS; - aP1: Real from Standard; - aF2: Face from TopoDS; - aNewVertex:out Vertex from TopoDS); + aE1: Edge from TopoDS; + aP1: Real from Standard; + aF2: Face from TopoDS; + aNewVertex:out Vertex from TopoDS); ---Purpose: --- Make a vertex in place of intersection between the edge --- with parameter and the face --- PointOnEdge (myclass; - aEdge: Edge from TopoDS; - aPrm: Real from Standard; - aP:out Pnt from gp); + aEdge: Edge from TopoDS; + aPrm: Real from Standard; + aP:out Pnt from gp); ---Purpose: --- Compute a 3D-point on the edge at parameter --- MakeSplitEdge (myclass; - aE1: Edge from TopoDS; - aV1: Vertex from TopoDS; - aP1: Real from Standard; - aV2: Vertex from TopoDS; - aP2: Real from Standard; - aNewEdge:out Edge from TopoDS); + aE1: Edge from TopoDS; + aV1: Vertex from TopoDS; + aP1: Real from Standard; + aV2: Vertex from TopoDS; + aP2: Real from Standard; + aNewEdge:out Edge from TopoDS); ---Purpose: --- Make the edge from base edge and two vertices --- at parameters --- MakeSectEdge (myclass; - aIC: Curve from IntTools; - aV1: Vertex from TopoDS; - aP1: Real from Standard; - aV2: Vertex from TopoDS; - aP2: Real from Standard; - aNewEdge:out Edge from TopoDS); + aIC: Curve from IntTools; + aV1: Vertex from TopoDS; + aP1: Real from Standard; + aV2: Vertex from TopoDS; + aP2: Real from Standard; + aNewEdge:out Edge from TopoDS); ---Purpose: --- Make the edge from 3D-Curve and two vertices --- at parameters --- UpdateVertex (myclass; - aIC: Curve from IntTools; - aT : Real from Standard; - aV : Vertex from TopoDS); + aIC: Curve from IntTools; + aT : Real from Standard; + aV : Vertex from TopoDS); ---Purpose: --- Update the tolerance value for vertex --- taking into account the fact that lays on --- the curve --- UpdateVertex (myclass; - aE : Edge from TopoDS; - aT : Real from Standard; - aV : Vertex from TopoDS); + aE : Edge from TopoDS; + aT : Real from Standard; + aV : Vertex from TopoDS); ---Purpose: --- Update the tolerance value for vertex --- taking into account the fact that lays on --- the edge --- UpdateVertex (myclass; - aVF : Vertex from TopoDS; - aVN : Vertex from TopoDS); + aVF : Vertex from TopoDS; + aVN : Vertex from TopoDS); ---Purpose: --- Update the tolerance value for vertex --- taking into account the fact that should @@ -400,62 +404,63 @@ is --- CorrectRange (myclass; - aE1: Edge from TopoDS; - aE2: Edge from TopoDS; - aSR: Range from IntTools; - aNewSR:out Range from IntTools); + aE1: Edge from TopoDS; + aE2: Edge from TopoDS; + aSR: Range from IntTools; + aNewSR:out Range from IntTools); ---Purpose: --- Correct shrunk range taking into account 3D-curve --- resolution and corresp. tolerances' values of , --- CorrectRange (myclass; - aE: Edge from TopoDS; - aF: Face from TopoDS; - aSR: Range from IntTools; - aNewSR:out Range from IntTools); + aE: Edge from TopoDS; + aF: Face from TopoDS; + aSR: Range from IntTools; + aNewSR:out Range from IntTools); ---Purpose: --- Correct shrunk range taking into account 3D-curve --- resolution and corresp. tolerances' values of , --- IsBlockInOnFace(myclass; - aShR : Range from IntTools; - aF : Face from TopoDS; - aE : Edge from TopoDS; - aContext:out Context from BOPInt) - returns Boolean from Standard; + aShR : Range from IntTools; + aF : Face from TopoDS; + aE : Edge from TopoDS; + aContext:out Context from BOPInt) + returns Boolean from Standard; ---Purpose: --- Returns TRUE if PaveBlock lays on the face , i.e --- the is IN or ON in 2D of IsMicroEdge(myclass; - theEdge : Edge from TopoDS; - theContext : Context from BOPInt) - returns Boolean from Standard; + theEdge : Edge from TopoDS; + theContext : Context from BOPInt) + returns Boolean from Standard; ---Purpose: --- Checks if it is possible to compute shrunk range for the edge . --- CorrectShapeTolerances (myclass; - theS: Shape from TopoDS); + theS: Shape from TopoDS; + theRunParallel: Boolean from Standard=Standard_False); ---Purpose: --- Corrects tolerance values of the sub-shapes of the shape if needed. --- Dimension(myclass; - theS:Shape from TopoDS) - returns Integer from Standard; + theS:Shape from TopoDS) + returns Integer from Standard; ---Purpose: --- Retutns dimension of the shape . IsOpenShell(myclass; - theShell:Shell from TopoDS) - returns Boolean from Standard; - ---Purpose: Returns true if the shell is open + theShell:Shell from TopoDS) + returns Boolean from Standard; + ---Purpose: Returns true if the shell is open IsInvertedSolid(myclass; - theSolid:Solid from TopoDS) - returns Boolean from Standard; - ---Purpose: Returns true if the solid is inverted - + theSolid:Solid from TopoDS) + returns Boolean from Standard; + ---Purpose: Returns true if the solid is inverted + end AlgoTools; diff --git a/src/BOPTools/BOPTools_AlgoTools_1.cxx b/src/BOPTools/BOPTools_AlgoTools_1.cxx index 97d2efb51d..a49449402e 100644 --- a/src/BOPTools/BOPTools_AlgoTools_1.cxx +++ b/src/BOPTools/BOPTools_AlgoTools_1.cxx @@ -13,18 +13,48 @@ // commercial license or contractual agreement. #include - -#include -#include -#include - +// +#include +#include +// +#include +#include +#include +// +#include +#include +#include +#include +#include +// +#include +#include +#include +#include +// +#include +#include +#include +#include +#include +// +#include +// +#include +#include +// +#include +#include +// +#include +// #include #include #include #include - -#include - +#include +#include +// #include #include #include @@ -34,50 +64,21 @@ #include #include #include - -#include -#include -#include -#include - -#include -#include -#include - -#include - -#include -#include -#include -#include - -#include -#include - -#include - -#include -#include -#include +#include // #include -#include -#include -#include +// #include -#include -#include -#include -#include +// +#include +#include +#include #include #include #include -#include -#include -#include -#include -#include -#include +// +#include +#include static void CheckEdge (const TopoDS_Edge& E, @@ -99,71 +100,413 @@ static static void CorrectWires(const TopoDS_Face& aF); -static - Standard_Real IntersectCurves2d(const gp_Pnt& aPV, - const TopoDS_Face& aF, - const TopoDS_Edge& aE1, - const TopoDS_Edge& aE2); + static void UpdateEdges(const TopoDS_Face& aF); -static - void UpdateVertices(const TopoDS_Edge& aE); +static + Standard_Real IntersectCurves2d(const gp_Pnt& aPV, + const TopoDS_Face& aF, + const Handle(Geom_Surface)& aS, + const TopoDS_Edge& aE1, + const TopoDS_Edge& aE2); + + +//======================================================================= +//class : BOPTools_CPC +//purpose : +//======================================================================= +class BOPTools_CPC { + public: + BOPTools_CPC() + : myMaxTol(1.e-7) { + } + // + ~BOPTools_CPC() { + } + // + void SetEdge(const TopoDS_Edge& aE) { + myEdge=aE; + } + // + const TopoDS_Edge& Edge()const { + return myEdge; + } + // + void SetMaxTol(const Standard_Real aMaxTol) { + myMaxTol=aMaxTol; + } + // + Standard_Real MaxTol()const { + return myMaxTol; + } + // + void Perform() { + CheckEdge(myEdge, myMaxTol); + } + + protected: + Standard_Real myMaxTol; + TopoDS_Edge myEdge; +}; +// +//======================================================================= +typedef BOPCol_NCVector BOPTools_VectorOfCPC; +// +typedef BOPCol_TBBFunctor + BOPTools_CPCFunctor; +// +typedef BOPCol_TBBCnt + BOPTools_CPCCnt; +// +//======================================================================= +//class : BOPTools_CWT +//purpose : +//======================================================================= +class BOPTools_CWT { + public: + BOPTools_CWT() { + } + // + ~BOPTools_CWT() { + } + // + void SetFace(const TopoDS_Face& aF) { + myFace=aF; + } + // + void Perform() { + CorrectWires(myFace); + } + // + protected: + TopoDS_Face myFace; +}; +//======================================================================= +typedef BOPCol_NCVector BOPTools_VectorOfCWT; +// +typedef BOPCol_TBBFunctor + BOPTools_CWTFunctor; +// +typedef BOPCol_TBBCnt + BOPTools_CWTCnt; +// +//======================================================================= +//class : BOPTools_CDT +//purpose : +//======================================================================= +class BOPTools_CDT { + public: + BOPTools_CDT() + : myMaxTol(1.e-7) { + } + // + ~BOPTools_CDT() { + } + // + void SetEdge(const TopoDS_Edge& aE) { + myEdge=aE; + } + // + void SetFace(const TopoDS_Face& aF) { + myFace=aF; + } + // + void SetMaxTol(const Standard_Real aMaxTol) { + myMaxTol=aMaxTol; + } + // + void Perform() { + CorrectEdgeTolerance (myEdge, myFace, myMaxTol); + } + // + protected: + Standard_Real myMaxTol; + TopoDS_Edge myEdge; + TopoDS_Face myFace; +}; +//======================================================================= +typedef BOPCol_NCVector BOPTools_VectorOfCDT; +// +typedef BOPCol_TBBFunctor + BOPTools_CDTFunctor; +// +typedef BOPCol_TBBCnt + BOPTools_CDTCnt; +// +//======================================================================= +//class : BOPTools_CVT +//purpose : +//======================================================================= +class BOPTools_CVT { + public: + BOPTools_CVT() { + } + // + ~BOPTools_CVT() { + } + // + void SetEdge(const TopoDS_Edge& aE) { + myEdge=aE; + } + // + void Perform() { + CorrectVertexTolerance(myEdge); + } + // + protected: + TopoDS_Edge myEdge; +}; +// +//======================================================================= +typedef BOPCol_NCVector BOPTools_VectorOfCVT; +// +typedef BOPCol_TBBFunctor + BOPTools_CVTFunctor; +// +typedef BOPCol_TBBCnt + BOPTools_CVTCnt; +// +//======================================================================= +//class : BOPTools_CET +//purpose : +//======================================================================= +class BOPTools_CET { + public: + BOPTools_CET() { + } + // + ~BOPTools_CET() { + } + // + void SetFace(const TopoDS_Face& aF) { + myFace=aF; + } + // + void Perform() { + UpdateEdges(myFace); + } + // + protected: + TopoDS_Face myFace; +}; +//======================================================================= +typedef BOPCol_NCVector BOPTools_VectorOfCET; +// +typedef BOPCol_TBBFunctor + BOPTools_CETFunctor; +// +typedef BOPCol_TBBCnt + BOPTools_CETCnt; +// //======================================================================= // Function : CorrectTolerances // purpose : //======================================================================= - void BOPTools_AlgoTools::CorrectTolerances(const TopoDS_Shape& aShape, - const Standard_Real aMaxTol) +void BOPTools_AlgoTools::CorrectTolerances + (const TopoDS_Shape& aShape, + const Standard_Real aMaxTol, + const Standard_Boolean bRunParallel) { - BOPTools_AlgoTools::CorrectPointOnCurve(aShape, aMaxTol); - BOPTools_AlgoTools::CorrectCurveOnSurface(aShape, aMaxTol); + BOPTools_AlgoTools::CorrectPointOnCurve(aShape, aMaxTol, bRunParallel); + BOPTools_AlgoTools::CorrectCurveOnSurface(aShape, aMaxTol, bRunParallel); } - +// //======================================================================= // Function : CorrectPointOnCurve // purpose : //======================================================================= - void BOPTools_AlgoTools::CorrectPointOnCurve(const TopoDS_Shape& S, - const Standard_Real aMaxTol) +void BOPTools_AlgoTools::CorrectPointOnCurve + (const TopoDS_Shape& aS, + const Standard_Real aMaxTol, + const Standard_Boolean bRunParallel) { - Standard_Integer i, aNb; - TopTools_IndexedMapOfShape Edges; - TopExp::MapShapes (S, TopAbs_EDGE, Edges); - aNb=Edges.Extent(); - for (i=1; i<=aNb; i++) { - const TopoDS_Edge& E= TopoDS::Edge(Edges(i)); - CheckEdge(E, aMaxTol); - } + TopExp_Explorer aExp; + BOPTools_VectorOfCPC aVCPC; + // + aExp.Init(aS, TopAbs_EDGE); + for(; aExp.More(); aExp.Next()) { + const TopoDS_Edge& aE=*((TopoDS_Edge*)&aExp.Current()); + BOPTools_CPC& aCPC=aVCPC.Append1(); + aCPC.SetEdge(aE); + aCPC.SetMaxTol(aMaxTol); + } + // + //====================================================== + BOPTools_CPCCnt::Perform(bRunParallel, aVCPC); + //====================================================== } - //======================================================================= // Function : CorrectCurveOnSurface // purpose : //======================================================================= - void BOPTools_AlgoTools::CorrectCurveOnSurface(const TopoDS_Shape& S, - const Standard_Real aMaxTol) +void BOPTools_AlgoTools::CorrectCurveOnSurface + (const TopoDS_Shape& aS, + const Standard_Real aMaxTol, + const Standard_Boolean bRunParallel) { - Standard_Integer i, aNbFaces, j, aNbEdges; - TopTools_IndexedMapOfShape Faces; - TopExp::MapShapes (S, TopAbs_FACE, Faces); - - aNbFaces=Faces.Extent(); - for (i=1; i<=aNbFaces; i++) { - const TopoDS_Face& F= TopoDS::Face(Faces(i)); + TopExp_Explorer aExpF, aExpE; + BOPTools_VectorOfCWT aVCWT; + BOPTools_VectorOfCDT aVCDT; + // + aExpF.Init(aS, TopAbs_FACE); + for (; aExpF.More(); aExpF.Next()) { + const TopoDS_Face& aF=*((TopoDS_Face*)&aExpF.Current()); // - CorrectWires(F); + BOPTools_CWT& aCWT=aVCWT.Append1(); + aCWT.SetFace(aF); // - TopTools_IndexedMapOfShape Edges; - TopExp::MapShapes (F, TopAbs_EDGE, Edges); - aNbEdges=Edges.Extent(); - for (j=1; j<=aNbEdges; j++) { - const TopoDS_Edge& E= TopoDS::Edge(Edges(j)); - CorrectEdgeTolerance (E, F, aMaxTol); + aExpE.Init(aF, TopAbs_EDGE); + for (; aExpE.More(); aExpE.Next()) { + const TopoDS_Edge& aE=*((TopoDS_Edge*)&aExpE.Current()); + // + BOPTools_CDT& aCDT=aVCDT.Append1(); + aCDT.SetEdge(aE); + aCDT.SetFace(aF); + aCDT.SetMaxTol(aMaxTol); } } + // + //====================================================== + BOPTools_CWTCnt::Perform(bRunParallel, aVCWT); + //====================================================== + BOPTools_CDTCnt::Perform(bRunParallel, aVCDT); + //====================================================== +} +//======================================================================= +// Function : CorrectShapeTolerances +// purpose : +//======================================================================= +void BOPTools_AlgoTools::CorrectShapeTolerances + (const TopoDS_Shape& aShape, + const Standard_Boolean bRunParallel) +{ + TopExp_Explorer aExp; + BOPTools_VectorOfCVT aVCVT; + BOPTools_VectorOfCET aVCET; + // + aExp.Init(aShape, TopAbs_EDGE); + for (; aExp.More(); aExp.Next()) { + const TopoDS_Edge& aE = *(TopoDS_Edge*)&aExp.Current(); + BOPTools_CVT& aCVT=aVCVT.Append1(); + aCVT.SetEdge(aE); + } + // + //====================================================== + BOPTools_CVTCnt::Perform(bRunParallel, aVCVT); + //====================================================== + // + aExp.Init(aShape, TopAbs_FACE); + for (; aExp.More(); aExp.Next()) { + const TopoDS_Face& aF = *(TopoDS_Face*)&aExp.Current(); + BOPTools_CET& aCET=aVCET.Append1(); + aCET.SetFace(aF); + } + // + //====================================================== + BOPTools_CETCnt::Perform(bRunParallel, aVCET); + //====================================================== +} +// +//======================================================================= +// Function : CheckEdge +// purpose : Correct tolerances for Vertices on Edge +//======================================================================= +void CheckEdge (const TopoDS_Edge& Ed, + const Standard_Real aMaxTol) +{ + Standard_Real aTolE, aTol, aD2, aNewTolerance, dd; + gp_Pnt aPC; + TopLoc_Location L; + TopoDS_Edge aE; + TopoDS_Vertex aV; + TopoDS_Iterator aItS; + // + TopAbs_Orientation aOrV; + BRep_ListIteratorOfListOfPointRepresentation aItPR; + BRep_ListIteratorOfListOfCurveRepresentation aItCR; + // + aE=Ed; + aE.Orientation(TopAbs_FORWARD); + aTolE=BRep_Tool::Tolerance(aE); + // + Handle(BRep_TEdge)& TE = *((Handle(BRep_TEdge)*)&aE.TShape()); + // + aItS.Initialize(aE); + for (; aItS.More(); aItS.Next()) { + aV= TopoDS::Vertex(aItS.Value()); + // + Handle(BRep_TVertex)& TV=*((Handle(BRep_TVertex)*)&aV.TShape()); + const gp_Pnt& aPV = TV->Pnt(); + // + aTol=BRep_Tool::Tolerance(aV); + aTol=Max(aTol, aTolE); + dd=0.1*aTol; + aTol*=aTol; + // + const TopLoc_Location& Eloc = aE.Location(); + // + aItCR.Initialize(TE->Curves()); + while (aItCR.More()) { + const Handle(BRep_CurveRepresentation)& aCR = aItCR.Value(); + const TopLoc_Location& loc = aCR->Location(); + L = (Eloc * loc).Predivided(aV.Location()); + // + if (aCR->IsCurve3D()) { + const Handle(Geom_Curve)& aC = aCR->Curve3D(); + if (!aC.IsNull()) { + aItPR.Initialize(TV->Points()); + while (aItPR.More()) { + const Handle(BRep_PointRepresentation)& aPR=aItPR.Value(); + if (aPR->IsPointOnCurve(aC, L)) { + aPC = aC->Value(aPR->Parameter()); + aPC.Transform(L.Transformation()); + aD2=aPV.SquareDistance(aPC); + if (aD2 > aTol) { + aNewTolerance=sqrt(aD2)+dd; + if (aNewToleranceUpdateTolerance(aNewTolerance); + } + } + aItPR.Next(); + } + // + aOrV=aV.Orientation(); + if (aOrV==TopAbs_FORWARD || aOrV==TopAbs_REVERSED) { + const Handle(BRep_GCurve)& aGC=*((Handle(BRep_GCurve)*)&aCR); + + if (aOrV==TopAbs_FORWARD) { + aPC=aC->Value(aGC->First()); + } + else { + aPC=aC->Value(aGC->Last()); + } + aPC.Transform(L.Transformation()); + // + aD2=aPV.SquareDistance(aPC); + if (aD2 > aTol) { + aNewTolerance=sqrt(aD2)+dd; + if (aNewToleranceUpdateTolerance(aNewTolerance); + } + } + } + } + aItCR.Next(); + }// while (itcr.More()) { + } // for (; aVExp.More(); aVExp.Next()) { } //======================================================================= // Function : CorrectWires @@ -171,23 +514,30 @@ static //======================================================================= void CorrectWires(const TopoDS_Face& aFx) { + Standard_Boolean bIsPeriodic; Standard_Integer i, aNbV; Standard_Real aTol, aTol2, aD2, aD2max, aT1, aT2, aT; gp_Pnt aP, aPV; gp_Pnt2d aP2D; TopoDS_Face aF; - BRep_Builder aBB; + TopoDS_Vertex aV11, aV12, aV21, aV22;; TopTools_IndexedDataMapOfShapeListOfShape aMVE; TopTools_ListIteratorOfListOfShape aIt, aIt1; // aF=aFx; aF.Orientation(TopAbs_FORWARD); const Handle(Geom_Surface)& aS=BRep_Tool::Surface(aFx); + GeomAdaptor_Surface aGAS (aS); // - TopExp::MapShapesAndAncestors(aF, TopAbs_VERTEX, TopAbs_EDGE, aMVE); + bIsPeriodic=(aGAS.IsUPeriodic() || aGAS.IsVPeriodic()); + // + TopExp::MapShapesAndAncestors(aF, + TopAbs_VERTEX, + TopAbs_EDGE, + aMVE); aNbV=aMVE.Extent(); for (i=1; i<=aNbV; ++i) { - const TopoDS_Vertex& aV=TopoDS::Vertex(aMVE.FindKey(i)); + const TopoDS_Vertex& aV=*((TopoDS_Vertex*)&aMVE.FindKey(i)); aPV=BRep_Tool::Pnt(aV); aTol=BRep_Tool::Tolerance(aV); aTol2=aTol*aTol; @@ -197,8 +547,10 @@ void CorrectWires(const TopoDS_Face& aFx) aIt.Initialize(aLE); for (; aIt.More(); aIt.Next()) { const TopoDS_Edge& aE=*(TopoDS_Edge*)(&aIt.Value()); + const Handle(Geom2d_Curve)& aC2D= + BRep_Tool::CurveOnSurface(aE, aF, aT1, aT2); aT=BRep_Tool::Parameter(aV, aE); - const Handle(Geom2d_Curve)& aC2D=BRep_Tool::CurveOnSurface(aE, aF, aT1, aT2); + // aC2D->D0(aT, aP2D); aS->D0(aP2D.X(), aP2D.Y(), aP); aD2=aPV.SquareDistance(aP); @@ -206,34 +558,41 @@ void CorrectWires(const TopoDS_Face& aFx) aD2max=aD2; } //check self interference - if (aNbV == 2) { + if (aNbV==2) { continue; } + // + if (bIsPeriodic) { + continue; + } + // + TopExp::Vertices(aE, aV11, aV12); + // aIt1 = aIt; aIt1.Next(); for (; aIt1.More(); aIt1.Next()) { const TopoDS_Edge& aE1=*(TopoDS_Edge*)(&aIt1.Value()); + // //do not perform check for edges that have two common vertices - { - TopoDS_Vertex aV11, aV12, aV21, aV22; - TopExp::Vertices(aE, aV11, aV12); - TopExp::Vertices(aE1, aV21, aV22); - if ((aV11.IsSame(aV21) && aV12.IsSame(aV22)) || - (aV12.IsSame(aV21) && aV11.IsSame(aV22))) { - continue; - } + TopExp::Vertices(aE1, aV21, aV22); + if ((aV11.IsSame(aV21) && aV12.IsSame(aV22)) || + (aV12.IsSame(aV21) && aV11.IsSame(aV22))) { + continue; } - aD2 = IntersectCurves2d(aPV, aF, aE, aE1); + // + aD2=IntersectCurves2d(aPV, aF, aS, aE, aE1); if (aD2>aD2max) { aD2max=aD2; } - } - } + }// for (; aIt1.More(); aIt1.Next()) { + }// for (; aIt.More(); aIt.Next()) { if (aD2max>aTol2) { + BRep_Builder aBB; + // aTol=sqrt(aD2max); aBB.UpdateVertex(aV, aTol); } - } + }// for (i=1; i<=aNbV; ++i) { } //======================================================================= // Function : IntersectCurves2d @@ -241,15 +600,10 @@ void CorrectWires(const TopoDS_Face& aFx) //======================================================================= Standard_Real IntersectCurves2d(const gp_Pnt& aPV, const TopoDS_Face& aF, + const Handle(Geom_Surface)& aS, const TopoDS_Edge& aE1, const TopoDS_Edge& aE2) { - const Handle(Geom_Surface)& aS=BRep_Tool::Surface(aF); - GeomAdaptor_Surface aGAS (aS); - if (aGAS.IsUPeriodic() || aGAS.IsVPeriodic()) { - return 0; - } - // Standard_Real aDist, aD, aT11, aT12, aT21, aT22, aTol2d; Standard_Integer j, aNbPnt; Geom2dInt_GInter aInter; @@ -259,12 +613,16 @@ Standard_Real IntersectCurves2d(const gp_Pnt& aPV, aDist = 0.; aTol2d = Precision::Confusion(); // - const Handle(Geom2d_Curve)& aC2D1=BRep_Tool::CurveOnSurface(aE1, aF, aT11, aT12); - const Handle(Geom2d_Curve)& aC2D2=BRep_Tool::CurveOnSurface(aE2, aF, aT21, aT22); + const Handle(Geom2d_Curve)& aC2D1= + BRep_Tool::CurveOnSurface(aE1, aF, aT11, aT12); + const Handle(Geom2d_Curve)& aC2D2= + BRep_Tool::CurveOnSurface(aE2, aF, aT21, aT22); // Geom2dAdaptor_Curve aGAC1(aC2D1), aGAC2(aC2D2); - IntRes2d_Domain aDom1(aC2D1->Value(aT11), aT11, aTol2d, aC2D1->Value(aT12), aT12, aTol2d), - aDom2(aC2D2->Value(aT21), aT21, aTol2d, aC2D2->Value(aT22), aT22, aTol2d); + IntRes2d_Domain aDom1(aC2D1->Value(aT11), aT11, aTol2d, + aC2D1->Value(aT12), aT12, aTol2d); + IntRes2d_Domain aDom2(aC2D2->Value(aT21), aT21, aTol2d, + aC2D2->Value(aT22), aT22, aTol2d); // aInter.Perform(aGAC1, aDom1, aGAC2, aDom2, aTol2d, aTol2d); if (aInter.IsDone()) { @@ -286,7 +644,6 @@ Standard_Real IntersectCurves2d(const gp_Pnt& aPV, } return aDist; } - //======================================================================= // Function : CorrectEdgeTolerance // purpose : Correct tolerances for Edge @@ -352,7 +709,8 @@ void CorrectEdgeTolerance (const TopoDS_Edge& myShape, } if (!myCref.IsNull()) { - const Handle(BRep_GCurve)& GCref = *((Handle(BRep_GCurve)*)&myCref); + const Handle(BRep_GCurve)& GCref = + *((Handle(BRep_GCurve)*)&myCref); Standard_Real First,Last; GCref->Range(First,Last); if (Last<=First) { @@ -363,16 +721,20 @@ void CorrectEdgeTolerance (const TopoDS_Edge& myShape, else { if (myCref->IsCurve3D()) { Handle(Geom_Curve) C3dx = Handle(Geom_Curve)::DownCast - (myCref->Curve3D()->Transformed (myCref->Location().Transformation())); + (myCref->Curve3D()->Transformed + (myCref->Location().Transformation())); GeomAdaptor_Curve GAC3d(C3dx, First, Last); myHCurve = new GeomAdaptor_HCurve(GAC3d); } else { // curve on surface Handle(Geom_Surface) Sref = myCref->Surface(); - Sref = Handle(Geom_Surface)::DownCast(Sref->Transformed(myCref->Location().Transformation())); + Sref = Handle(Geom_Surface):: + DownCast(Sref->Transformed(myCref->Location().Transformation())); const Handle(Geom2d_Curve)& PCref = myCref->PCurve(); - Handle(GeomAdaptor_HSurface) GAHSref = new GeomAdaptor_HSurface(Sref); - Handle(Geom2dAdaptor_HCurve) GHPCref = new Geom2dAdaptor_HCurve(PCref, First, Last); + Handle(GeomAdaptor_HSurface) GAHSref = + new GeomAdaptor_HSurface(Sref); + Handle(Geom2dAdaptor_HCurve) GHPCref = + new Geom2dAdaptor_HCurve(PCref, First, Last); Adaptor3d_CurveOnSurface ACSref(GHPCref,GAHSref); myHCurve = new Adaptor3d_HCurveOnSurface(ACSref); } @@ -414,25 +776,19 @@ void CorrectEdgeTolerance (const TopoDS_Edge& myShape, if (SameRange && (f != First || l != Last)) { return ;//BRepCheck_InvalidSameRangeFlag; } - + Handle(Geom_Surface) Sb = cr->Surface(); - Sb = Handle(Geom_Surface)::DownCast (Su->Transformed(L.Transformation())); + Sb = Handle(Geom_Surface):: + DownCast (Su->Transformed(L.Transformation())); Handle(Geom2d_Curve) PC = cr->PCurve(); - Handle(GeomAdaptor_HSurface) GAHS = new GeomAdaptor_HSurface(Sb); - Handle(Geom2dAdaptor_HCurve) GHPC = new Geom2dAdaptor_HCurve(PC,f,l); + Handle(GeomAdaptor_HSurface) GAHS = + new GeomAdaptor_HSurface(Sb); + Handle(Geom2dAdaptor_HCurve) GHPC = + new Geom2dAdaptor_HCurve(PC,f,l); Adaptor3d_CurveOnSurface ACS(GHPC,GAHS); - ok = Validate(myHCurve->Curve(), ACS, Tol, SameParameter, aNewTol); + ok = Validate(myHCurve->Curve(), ACS, + Tol, SameParameter, aNewTol); if (ok) { - if (cr->IsCurveOnClosedSurface()) { - //return ;// BRepCheck::Add(lst,BRepCheck_InvalidCurveOnClosedSurface); - } - else { - //return;//BRepCheck::Add(lst,BRepCheck_InvalidCurveOnSurface); - } - if (SameParameter) { - //return;//BRepCheck::Add(lst,BRepCheck_InvalidSameParameterFlag); - } - // if (aNewTolUpdateTolerance(aNewTol+Delta); // @@ -447,10 +803,6 @@ void CorrectEdgeTolerance (const TopoDS_Edge& myShape, ACS.Load(GHPC); // meme remarque... ok = Validate(myHCurve->Curve(),ACS,Tol,SameParameter, aNewTol); if (ok) { - //return;//BRepCheck::Add(lst,BRepCheck_InvalidCurveOnClosedSurface); - if (SameParameter) { - //return;//BRepCheck::Add(lst,BRepCheck_InvalidSameParameterFlag); - } if (aNewTolUpdateTolerance(aNewTol+Delta); CorrectVertexTolerance(myShape); @@ -465,102 +817,77 @@ void CorrectEdgeTolerance (const TopoDS_Edge& myShape, Handle(Geom_Plane) P; Handle(Standard_Type) styp = Su->DynamicType(); if (styp == STANDARD_TYPE(Geom_RectangularTrimmedSurface)) { - P = Handle(Geom_Plane)::DownCast(Handle(Geom_RectangularTrimmedSurface):: - DownCast(Su)->BasisSurface()); + P = Handle(Geom_Plane):: + DownCast(Handle(Geom_RectangularTrimmedSurface):: + DownCast(Su)->BasisSurface()); } else { P = Handle(Geom_Plane)::DownCast(Su); } if (P.IsNull()) { // not a plane - return;//BRepCheck::Add(lst,BRepCheck_NoCurveOnSurface); + return; } else {// on fait la projection a la volee, comme BRep_Tool - P = Handle(Geom_Plane)::DownCast(P->Transformed(L.Transformation())); + P = Handle(Geom_Plane):: + DownCast(P->Transformed(L.Transformation())); //on projette Cref sur ce plan Handle(GeomAdaptor_HSurface) GAHS = new GeomAdaptor_HSurface(P); // Dub - Normalement myHCurve est une GeomAdaptor_HCurve - GeomAdaptor_Curve& Gac = Handle(GeomAdaptor_HCurve)::DownCast(myHCurve)->ChangeCurve(); + GeomAdaptor_Curve& Gac = + Handle(GeomAdaptor_HCurve)::DownCast(myHCurve)->ChangeCurve(); Handle(Geom_Curve) C3dx = Gac.Curve(); - Handle(Geom_Curve) ProjOnPlane = GeomProjLib::ProjectOnPlane - (new Geom_TrimmedCurve(C3dx,First,Last), P, P->Position().Direction(), Standard_True); + Handle(Geom_Curve) ProjOnPlane = + GeomProjLib::ProjectOnPlane(new Geom_TrimmedCurve(C3dx,First,Last), + P, + P->Position().Direction(), + Standard_True); - Handle(GeomAdaptor_HCurve) aHCurve = new GeomAdaptor_HCurve(ProjOnPlane); + Handle(GeomAdaptor_HCurve) aHCurve = + new GeomAdaptor_HCurve(ProjOnPlane); ProjLib_ProjectedCurve proj(GAHS,aHCurve); Handle(Geom2d_Curve) PC = Geom2dAdaptor::MakeCurve(proj); Handle(Geom2dAdaptor_HCurve) GHPC = - new Geom2dAdaptor_HCurve(PC, myHCurve->FirstParameter(), myHCurve->LastParameter()); + new Geom2dAdaptor_HCurve(PC, + myHCurve->FirstParameter(), + myHCurve->LastParameter()); Adaptor3d_CurveOnSurface ACS(GHPC,GAHS); Standard_Boolean okx = Validate(myHCurve->Curve(),ACS, - Tol,Standard_True, aNewTol); // voir dub... + Tol,Standard_True, aNewTol); if (okx) { - //return;//BRepCheck::Add(lst,BRepCheck_InvalidCurveOnSurface); if (aNewTolUpdateTolerance(aNewTol+Delta); CorrectVertexTolerance(myShape); } } } - }//end of if (!pcurvefound) { } // end of 2. Tolerances in InContext - } - -//======================================================================= -// Function : CorrectShapeTolerances -// purpose : -//======================================================================= - void BOPTools_AlgoTools::CorrectShapeTolerances(const TopoDS_Shape& aShape) -{ - TopExp_Explorer aExp; - Standard_Integer aDim; - // - aDim=Dimension(aShape); - if (aDim == 1) { - aExp.Init(aShape, TopAbs_EDGE); - for (; aExp.More(); aExp.Next()) { - const TopoDS_Edge& aE = *(TopoDS_Edge*)&aExp.Current(); - UpdateVertices(aE); - } - } else { - aExp.Init(aShape, TopAbs_FACE); - for (; aExp.More(); aExp.Next()) { - const TopoDS_Face& aF = *(TopoDS_Face*)&aExp.Current(); - UpdateEdges(aF); - } - } -} - //======================================================================= //function : CorrectVertexTolerance //purpose : //======================================================================= void CorrectVertexTolerance(const TopoDS_Edge& aE) { - Standard_Integer k, aNbV; Standard_Real aTolE, aTolV; - TopTools_IndexedMapOfShape aVMap; - + TopoDS_Iterator aIt; + // aTolE=BRep_Tool::Tolerance(aE); - - TopExp::MapShapes(aE, TopAbs_VERTEX, aVMap); - aNbV=aVMap.Extent(); - for (k=1; k<=aNbV; ++k) { - const TopoDS_Vertex& aV=TopoDS::Vertex(aVMap(k)); + aIt.Initialize(aE); + for(; aIt.More(); aIt.Next()) { + const TopoDS_Vertex& aV=*((TopoDS_Vertex*)&aIt.Value()); aTolV=BRep_Tool::Tolerance(aV); if (aTolVUpdateTolerance(aTolE); } } } - -#define NCONTROL 23 //======================================================================= //function : Validate //purpose : @@ -577,7 +904,8 @@ Standard_Boolean Validate(const Adaptor3d_Curve& CRef, Last = CRef.LastParameter(); MaxDistance = 0.; Tol2 = Tol*Tol; - + // + Standard_Integer NCONTROL=23; Standard_Integer i, aNC1=NCONTROL-1; Standard_Boolean aFlag=Standard_False; @@ -672,139 +1000,36 @@ Standard_Boolean Validate(const Adaptor3d_Curve& CRef, aD=sqrt (MaxDistance); aNewTolerance=aD; - return aFlag; - -} - -//======================================================================= -// Function : CheckEdge -// purpose : Correct tolerances for Vertices on Edge -//======================================================================= -void CheckEdge (const TopoDS_Edge& Ed, const Standard_Real aMaxTol) -{ - TopoDS_Edge E=Ed; - E.Orientation(TopAbs_FORWARD); - - gp_Pnt Controlp; - - TopExp_Explorer aVExp; - aVExp.Init(E, TopAbs_VERTEX); - for (; aVExp.More(); aVExp.Next()) { - TopoDS_Vertex aVertex= TopoDS::Vertex(aVExp.Current()); - - Handle(BRep_TVertex)& TV = *((Handle(BRep_TVertex)*) &aVertex.TShape()); - const gp_Pnt& prep = TV->Pnt(); - - Standard_Real Tol, aD2, aNewTolerance, dd; - - Tol =BRep_Tool::Tolerance(aVertex); - Tol = Max(Tol, BRep_Tool::Tolerance(E)); - dd=0.1*Tol; - Tol*=Tol; - - const TopLoc_Location& Eloc = E.Location(); - BRep_ListIteratorOfListOfPointRepresentation itpr; - - Handle(BRep_TEdge)& TE = *((Handle(BRep_TEdge)*)&E.TShape()); - BRep_ListIteratorOfListOfCurveRepresentation itcr(TE->Curves()); - while (itcr.More()) { - const Handle(BRep_CurveRepresentation)& cr = itcr.Value(); - const TopLoc_Location& loc = cr->Location(); - TopLoc_Location L = (Eloc * loc).Predivided(aVertex.Location()); - - if (cr->IsCurve3D()) { - const Handle(Geom_Curve)& C = cr->Curve3D(); - if (!C.IsNull()) { - itpr.Initialize(TV->Points()); - while (itpr.More()) { - const Handle(BRep_PointRepresentation)& pr = itpr.Value(); - if (pr->IsPointOnCurve(C,L)) { - Controlp = C->Value(pr->Parameter()); - Controlp.Transform(L.Transformation()); - aD2=prep.SquareDistance(Controlp); - if (aD2 > Tol) { - aNewTolerance=sqrt(aD2)+dd; - if (aNewToleranceUpdateTolerance(aNewTolerance); - } - } - itpr.Next(); - } - - TopAbs_Orientation orv = aVertex.Orientation(); - if (orv == TopAbs_FORWARD || orv == TopAbs_REVERSED) { - const Handle(BRep_GCurve)& GC = *((Handle(BRep_GCurve)*)&cr); - - if (orv==TopAbs_FORWARD) - Controlp = C->Value(GC->First()); - else - Controlp = C->Value(GC->Last()); - - Controlp.Transform(L.Transformation()); - aD2=prep.SquareDistance(Controlp); - - if (aD2 > Tol) { - aNewTolerance=sqrt(aD2)+dd; - if (aNewToleranceUpdateTolerance(aNewTolerance); - } - } - } - } - itcr.Next(); - } - } -} - -//======================================================================= -// Function : UpdateVertices -// purpose : -//======================================================================= - void UpdateVertices(const TopoDS_Edge& aE) -{ - Standard_Real aTolE, aTolV; - TopoDS_Iterator aItE; - BRep_Builder aBB; - // - aTolE = BRep_Tool::Tolerance(aE); - aItE.Initialize(aE); - for (; aItE.More(); aItE.Next()) { - const TopoDS_Vertex& aV = *(TopoDS_Vertex*)&aItE.Value(); - aTolV = BRep_Tool::Tolerance(aV); - if (aTolV < aTolE) { - aBB.UpdateVertex(aV, aTolE); - } - } } //======================================================================= // Function : UpdateEdges // purpose : //======================================================================= - void UpdateEdges(const TopoDS_Face& aF) +void UpdateEdges(const TopoDS_Face& aF) { Standard_Real aTolF, aTolE, aTolV; TopoDS_Iterator aItF, aItW, aItE; BRep_Builder aBB; // - aTolE = aTolF = BRep_Tool::Tolerance(aF); + aTolE=aTolF= BRep_Tool::Tolerance(aF); aItF.Initialize(aF); for (; aItF.More(); aItF.Next()) { const TopoDS_Shape& aS = aItF.Value(); if (aS.ShapeType()==TopAbs_WIRE) { aItW.Initialize(aS); for (; aItW.More(); aItW.Next()) { - const TopoDS_Edge& aE = *(TopoDS_Edge*)&aItW.Value(); + const TopoDS_Edge& aE=*((TopoDS_Edge*)&aItW.Value()); aTolE = BRep_Tool::Tolerance(aE); if (aTolE < aTolF) { aBB.UpdateEdge(aE, aTolF); aTolE = aTolF; } - UpdateVertices(aE); + //UpdateVertices(aE); } } else { - const TopoDS_Vertex& aV = *(TopoDS_Vertex*)&aItF.Value(); + const TopoDS_Vertex& aV=*(TopoDS_Vertex*)&aItF.Value(); aTolV = BRep_Tool::Tolerance(aV); if (aTolV < aTolE) { aBB.UpdateVertex(aV, aTolF);