mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0027032: [Regression to 6.9.1] Result of bcut has the same volume as the object
- Avoid reducing tolerance of the original edges in BOPAlgo_PaveFiller::CorrectToleranceOfSE - If a boundary edge is considered coincident with a section curve then increase its tolerance more carefully, using real distance instead of extended reached tolerance. - New test case bugs/modalg_6/bug27032 - Test cases boolean/gdml_private/E4-F3 have been amended to check area of the result. - Puts TODO in test cases boolean gdml_private ZI5,ZI7,ZJ7.
This commit is contained in:
parent
7d83504007
commit
05cf4d98b0
@ -188,7 +188,10 @@ protected:
|
|||||||
|
|
||||||
Standard_EXPORT void PutBoundPaveOnCurve (const TopoDS_Face& theF1, const TopoDS_Face& theF2, const Standard_Real theTolR3D, BOPDS_Curve& theNC, BOPCol_ListOfInteger& theLBV);
|
Standard_EXPORT void PutBoundPaveOnCurve (const TopoDS_Face& theF1, const TopoDS_Face& theF2, const Standard_Real theTolR3D, BOPDS_Curve& theNC, BOPCol_ListOfInteger& theLBV);
|
||||||
|
|
||||||
Standard_EXPORT Standard_Boolean IsExistingPaveBlock (const Handle(BOPDS_PaveBlock)& thePB, const BOPDS_Curve& theNC, const Standard_Real theTolR3D, const BOPDS_IndexedMapOfPaveBlock& theMPB, Handle(BOPDS_PaveBlock)& thePBOut);
|
Standard_EXPORT Standard_Boolean IsExistingPaveBlock
|
||||||
|
(const Handle(BOPDS_PaveBlock)& thePB, const BOPDS_Curve& theNC,
|
||||||
|
const Standard_Real theTolR3D, const BOPDS_IndexedMapOfPaveBlock& theMPB,
|
||||||
|
Handle(BOPDS_PaveBlock)& thePBOut, Standard_Real& theTolNew);
|
||||||
|
|
||||||
Standard_EXPORT Standard_Boolean IsExistingPaveBlock (const Handle(BOPDS_PaveBlock)& thePB, const BOPDS_Curve& theNC, const Standard_Real theTolR3D, const BOPCol_ListOfInteger& theLSE);
|
Standard_EXPORT Standard_Boolean IsExistingPaveBlock (const Handle(BOPDS_PaveBlock)& thePB, const BOPDS_Curve& theNC, const Standard_Real theTolR3D, const BOPCol_ListOfInteger& theLSE);
|
||||||
|
|
||||||
|
@ -521,7 +521,8 @@ void BOPAlgo_PaveFiller::MakeBlocks()
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
bExist=IsExistingPaveBlock(aPB, aNC, aTolR3D, aMPBOnIn, aPBOut);
|
Standard_Real aTolNew;
|
||||||
|
bExist=IsExistingPaveBlock(aPB, aNC, aTolR3D, aMPBOnIn, aPBOut, aTolNew);
|
||||||
if (bExist) {
|
if (bExist) {
|
||||||
if (aMPBAdd.Add(aPBOut)) {
|
if (aMPBAdd.Add(aPBOut)) {
|
||||||
Standard_Boolean bInBothFaces = Standard_True;
|
Standard_Boolean bInBothFaces = Standard_True;
|
||||||
@ -532,8 +533,10 @@ void BOPAlgo_PaveFiller::MakeBlocks()
|
|||||||
nE = aPBOut->Edge();
|
nE = aPBOut->Edge();
|
||||||
const TopoDS_Edge& aE = *(TopoDS_Edge*)&myDS->Shape(nE);
|
const TopoDS_Edge& aE = *(TopoDS_Edge*)&myDS->Shape(nE);
|
||||||
aTolE = BRep_Tool::Tolerance(aE);
|
aTolE = BRep_Tool::Tolerance(aE);
|
||||||
if (aTolR3D > aTolE) {
|
if (aTolNew < aFF.TolReal())
|
||||||
UpdateEdgeTolerance(nE, aTolR3D);
|
aTolNew = aFF.TolReal(); // use real tolerance of intersection
|
||||||
|
if (aTolNew > aTolE) {
|
||||||
|
UpdateEdgeTolerance(nE, aTolNew);
|
||||||
}
|
}
|
||||||
bInBothFaces = Standard_False;
|
bInBothFaces = Standard_False;
|
||||||
}
|
}
|
||||||
@ -1097,7 +1100,7 @@ Standard_Boolean BOPAlgo_PaveFiller::IsExistingPaveBlock
|
|||||||
return !bRet;
|
return !bRet;
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
Standard_Real aT1, aT2, aTm, aTx, aTol;
|
Standard_Real aT1, aT2, aTm, aTx, aTol, aDist;
|
||||||
Standard_Integer nE, iFlag;
|
Standard_Integer nE, iFlag;
|
||||||
gp_Pnt aPm;
|
gp_Pnt aPm;
|
||||||
Bnd_Box aBoxPm;
|
Bnd_Box aBoxPm;
|
||||||
@ -1120,7 +1123,7 @@ Standard_Boolean BOPAlgo_PaveFiller::IsExistingPaveBlock
|
|||||||
const TopoDS_Edge& aE=(*(TopoDS_Edge *)(&aSIE.Shape()));
|
const TopoDS_Edge& aE=(*(TopoDS_Edge *)(&aSIE.Shape()));
|
||||||
aTol = BRep_Tool::Tolerance(aE);
|
aTol = BRep_Tool::Tolerance(aE);
|
||||||
aTol = aTol > theTolR3D ? aTol : theTolR3D;
|
aTol = aTol > theTolR3D ? aTol : theTolR3D;
|
||||||
iFlag=myContext->ComputePE(aPm, aTol, aE, aTx);
|
iFlag=myContext->ComputePE(aPm, aTol, aE, aTx, aDist);
|
||||||
if (!iFlag) {
|
if (!iFlag) {
|
||||||
return bRet;
|
return bRet;
|
||||||
}
|
}
|
||||||
@ -1138,7 +1141,8 @@ Standard_Boolean BOPAlgo_PaveFiller::IsExistingPaveBlock
|
|||||||
const BOPDS_Curve& theNC,
|
const BOPDS_Curve& theNC,
|
||||||
const Standard_Real theTolR3D,
|
const Standard_Real theTolR3D,
|
||||||
const BOPDS_IndexedMapOfPaveBlock& theMPBOnIn,
|
const BOPDS_IndexedMapOfPaveBlock& theMPBOnIn,
|
||||||
Handle(BOPDS_PaveBlock)& aPBOut)
|
Handle(BOPDS_PaveBlock)& aPBOut,
|
||||||
|
Standard_Real& theTolNew)
|
||||||
{
|
{
|
||||||
Standard_Boolean bRet;
|
Standard_Boolean bRet;
|
||||||
Standard_Real aT1, aT2, aTm, aTx;
|
Standard_Real aT1, aT2, aTm, aTx;
|
||||||
@ -1165,6 +1169,7 @@ Standard_Boolean BOPAlgo_PaveFiller::IsExistingPaveBlock
|
|||||||
aBoxP2.Add(aP2);
|
aBoxP2.Add(aP2);
|
||||||
aBoxP2.Enlarge(theTolR3D);
|
aBoxP2.Enlarge(theTolR3D);
|
||||||
//
|
//
|
||||||
|
theTolNew = 0.;
|
||||||
aNbPB = theMPBOnIn.Extent();
|
aNbPB = theMPBOnIn.Extent();
|
||||||
for (i = 1; i <= aNbPB; ++i) {
|
for (i = 1; i <= aNbPB; ++i) {
|
||||||
const Handle(BOPDS_PaveBlock)& aPB = theMPBOnIn(i);
|
const Handle(BOPDS_PaveBlock)& aPB = theMPBOnIn(i);
|
||||||
@ -1181,19 +1186,24 @@ Standard_Boolean BOPAlgo_PaveFiller::IsExistingPaveBlock
|
|||||||
iFlag2 = (nV12 == nV21 || nV12 == nV22) ? 2 :
|
iFlag2 = (nV12 == nV21 || nV12 == nV22) ? 2 :
|
||||||
(!aBoxSp.IsOut(aBoxP2) ? 1 : 0);
|
(!aBoxSp.IsOut(aBoxP2) ? 1 : 0);
|
||||||
if (iFlag1 && iFlag2) {
|
if (iFlag1 && iFlag2) {
|
||||||
|
Standard_Real aDist;
|
||||||
if (aBoxSp.IsOut(aBoxPm) || myContext->ComputePE(aPm,
|
if (aBoxSp.IsOut(aBoxPm) || myContext->ComputePE(aPm,
|
||||||
theTolR3D,
|
theTolR3D,
|
||||||
aSp,
|
aSp,
|
||||||
aTx)) {
|
aTx, theTolNew)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
if (iFlag1 == 1) {
|
if (iFlag1 == 1) {
|
||||||
iFlag1 = !myContext->ComputePE(aP1, theTolR3D, aSp, aTx);
|
iFlag1 = !myContext->ComputePE(aP1, theTolR3D, aSp, aTx, aDist);
|
||||||
|
if (theTolNew < aDist)
|
||||||
|
theTolNew = aDist;
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
if (iFlag2 == 1) {
|
if (iFlag2 == 1) {
|
||||||
iFlag2 = !myContext->ComputePE(aP2, theTolR3D, aSp, aTx);
|
iFlag2 = !myContext->ComputePE(aP2, theTolR3D, aSp, aTx, aDist);
|
||||||
|
if (theTolNew < aDist)
|
||||||
|
theTolNew = aDist;
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
if (iFlag1 && iFlag2) {
|
if (iFlag1 && iFlag2) {
|
||||||
@ -2525,7 +2535,7 @@ void BOPAlgo_PaveFiller::CorrectToleranceOfSE()
|
|||||||
for (; aItLPB.More(); aItLPB.Next()) {
|
for (; aItLPB.More(); aItLPB.Next()) {
|
||||||
const Handle(BOPDS_PaveBlock)& aPB = aItLPB.Value();
|
const Handle(BOPDS_PaveBlock)& aPB = aItLPB.Value();
|
||||||
Standard_Integer nE;
|
Standard_Integer nE;
|
||||||
if (!aPB->HasEdge(nE)) {
|
if (!aPB->HasEdge(nE) || aPB->OriginalEdge() >= 0) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
const TopoDS_Edge& aE = TopoDS::Edge(myDS->Shape(nE));
|
const TopoDS_Edge& aE = TopoDS::Edge(myDS->Shape(nE));
|
||||||
|
@ -481,12 +481,13 @@ Standard_Integer IntTools_Context::ComputePE
|
|||||||
(const gp_Pnt& aP1,
|
(const gp_Pnt& aP1,
|
||||||
const Standard_Real aTolP1,
|
const Standard_Real aTolP1,
|
||||||
const TopoDS_Edge& aE2,
|
const TopoDS_Edge& aE2,
|
||||||
Standard_Real& aT)
|
Standard_Real& aT,
|
||||||
|
Standard_Real& aDist)
|
||||||
{
|
{
|
||||||
if (!BRep_Tool::IsGeometric(aE2)) {
|
if (!BRep_Tool::IsGeometric(aE2)) {
|
||||||
return -2;
|
return -2;
|
||||||
}
|
}
|
||||||
Standard_Real aDist, aTolE2, aTolSum;
|
Standard_Real aTolE2, aTolSum;
|
||||||
Standard_Integer aNbProj;
|
Standard_Integer aNbProj;
|
||||||
//
|
//
|
||||||
GeomAPI_ProjectPointOnCurve& aProjector=ProjPC(aE2);
|
GeomAPI_ProjectPointOnCurve& aProjector=ProjPC(aE2);
|
||||||
|
@ -108,7 +108,9 @@ Standard_EXPORT virtual ~IntTools_Context();
|
|||||||
//! 1. the edge is degenerated (-1)
|
//! 1. the edge is degenerated (-1)
|
||||||
//! 2. the edge does not contain 3d curve and pcurves (-2)
|
//! 2. the edge does not contain 3d curve and pcurves (-2)
|
||||||
//! 3. projection algorithm failed (-3)
|
//! 3. projection algorithm failed (-3)
|
||||||
Standard_EXPORT Standard_Integer ComputePE (const gp_Pnt& theP, const Standard_Real theTolP, const TopoDS_Edge& theE, Standard_Real& theT);
|
Standard_EXPORT Standard_Integer ComputePE (const gp_Pnt& theP, const Standard_Real theTolP,
|
||||||
|
const TopoDS_Edge& theE, Standard_Real& theT,
|
||||||
|
Standard_Real& theDist);
|
||||||
|
|
||||||
|
|
||||||
//! Computes parameter of the vertex aV on
|
//! Computes parameter of the vertex aV on
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
source [locate_data_file 20000_casemate-inf.prt.2.gdml.tcl]
|
source [locate_data_file 20000_casemate-inf.prt.2.gdml.tcl]
|
||||||
|
checkprops result -s 2.94595e+006
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
source [locate_data_file 20000_casemate-sup.prt.2.gdml.tcl]
|
source [locate_data_file 20000_casemate-sup.prt.2.gdml.tcl]
|
||||||
|
checkprops result -s 3.02422e+006
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
source [locate_data_file 20000_casemate.asm.2.gdml.tcl]
|
source [locate_data_file 20000_casemate.asm.2.gdml.tcl]
|
||||||
|
checkprops result -s 5.97016e+006
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
source [locate_data_file 20000_casemate_inf.asm.2.gdml.tcl]
|
source [locate_data_file 20000_casemate_inf.asm.2.gdml.tcl]
|
||||||
|
checkprops result -s 2.94595e+006
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
source [locate_data_file 20000_casemate_ne.asm.2.gdml.tcl]
|
source [locate_data_file 20000_casemate_ne.asm.2.gdml.tcl]
|
||||||
|
checkprops result -s 5.97016e+006
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
source [locate_data_file 20000_casemate_no.asm.2.gdml.tcl]
|
source [locate_data_file 20000_casemate_no.asm.2.gdml.tcl]
|
||||||
|
checkprops result -s 5.97016e+006
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
source [locate_data_file 20000_casemate_se.asm.2.gdml.tcl]
|
source [locate_data_file 20000_casemate_se.asm.2.gdml.tcl]
|
||||||
|
checkprops result -s 5.97016e+006
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
source [locate_data_file 20000_casemate_so.asm.2.gdml.tcl]
|
source [locate_data_file 20000_casemate_so.asm.2.gdml.tcl]
|
||||||
|
checkprops result -s 5.97016e+006
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
source [locate_data_file 20000_casemate_sup.asm.2.gdml.tcl]
|
source [locate_data_file 20000_casemate_sup.asm.2.gdml.tcl]
|
||||||
|
checkprops result -s 3.02422e+006
|
||||||
|
@ -1,2 +1,4 @@
|
|||||||
|
puts "TODO ?OCC27052 All: Faulty shapes in variables faulty_1 to"
|
||||||
|
|
||||||
source [locate_data_file equipement_chambre.asm.1.gdml.tcl]
|
source [locate_data_file equipement_chambre.asm.1.gdml.tcl]
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
puts "TODO ?OCC27052 All: Faulty shapes in variables faulty_1 to"
|
||||||
puts "TODO OCC26018 ALL: bopcheck failed"
|
puts "TODO OCC26018 ALL: bopcheck failed"
|
||||||
source [locate_data_file mos2014-asm-scf-final.asm.1.gdml.tcl]
|
source [locate_data_file mos2014-asm-scf-final.asm.1.gdml.tcl]
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
puts "TODO ?OCC27052 All: Faulty shapes in variables faulty_1 to"
|
||||||
puts "TODO OCC26018 ALL: bopcheck failed"
|
puts "TODO OCC26018 ALL: bopcheck failed"
|
||||||
source [locate_data_file mos2014-scf-final.prt.1.gdml.tcl]
|
source [locate_data_file mos2014-scf-final.prt.1.gdml.tcl]
|
||||||
|
|
||||||
|
14
tests/bugs/modalg_6/bug27032
Normal file
14
tests/bugs/modalg_6/bug27032
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
puts "========"
|
||||||
|
puts "OCC27032"
|
||||||
|
puts "========"
|
||||||
|
puts ""
|
||||||
|
##########################################################################################
|
||||||
|
# Result of bcut has the same volume as the object
|
||||||
|
##########################################################################################
|
||||||
|
|
||||||
|
restore [locate_data_file OCC27032_sh.brep] a
|
||||||
|
|
||||||
|
explode a
|
||||||
|
bcut result a_1 a_2
|
||||||
|
|
||||||
|
checkprops result -s 1.80949e+006
|
Loading…
x
Reference in New Issue
Block a user