1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-05 18:16:23 +03:00

0026253: Wrong result obtained by General Fuse operator.

Replace BOPCol_MapOfShape by BOPCol_IndexedMapOfShape to provide
the same order of shells in the result

Test case for issue CR26253

Correction of test case for issue CR26253
This commit is contained in:
pkv 2015-05-28 15:21:57 +03:00 committed by bugmaster
parent fbf3becf65
commit a2ab27029b
3 changed files with 143 additions and 79 deletions

View File

@ -43,7 +43,8 @@ static
TopoDS_Shell& ); TopoDS_Shell& );
// //
static static
void RefineShell(TopoDS_Shell& theShell); void RefineShell(TopoDS_Shell& theShell,
BOPCol_ListOfShape& aLShX);
// //
static static
void MapEdgesAndFaces void MapEdgesAndFaces
@ -329,8 +330,9 @@ void BOPAlgo_ShellSplitter::SplitBlock(BOPTools_ConnexityBlock& aCB)
BOPTools_CoupleOfShape aCSOff; BOPTools_CoupleOfShape aCSOff;
BOPCol_MapOfOrientedShape AddedFacesMap; BOPCol_MapOfOrientedShape AddedFacesMap;
BOPCol_IndexedDataMapOfShapeListOfShape aEFMap, aMEFP; BOPCol_IndexedDataMapOfShapeListOfShape aEFMap, aMEFP;
Handle (IntTools_Context) aContext;
// //
Handle (IntTools_Context) aContext=new IntTools_Context; aContext=new IntTools_Context;
// //
const BOPCol_ListOfShape& myShapes=aCB.Shapes(); const BOPCol_ListOfShape& myShapes=aCB.Shapes();
// //
@ -345,6 +347,7 @@ void BOPAlgo_ShellSplitter::SplitBlock(BOPTools_ConnexityBlock& aCB)
TopAbs_EDGE, TopAbs_EDGE,
TopAbs_FACE, TopAbs_FACE,
aEFMap); aEFMap);
} }
// //
aItF.Initialize (myShapes); aItF.Initialize (myShapes);
@ -454,15 +457,18 @@ void BOPAlgo_ShellSplitter::SplitBlock(BOPTools_ConnexityBlock& aCB)
} // for (; aExp.More(); aExp.Next()) { } // for (; aExp.More(); aExp.Next()) {
} // for (; aItS.More(); aItS.Next()) { } // for (; aItS.More(); aItS.Next()) {
// //
if (BRep_Tool::IsClosed(aShell)) { BOPCol_ListOfShape aLShX;
aShell.Closed (Standard_True); BOPCol_ListIteratorOfListOfShape aItLShX;
myLoops.Append(aShell); //
} RefineShell(aShell, aLShX);
else { //
RefineShell(aShell); aItLShX.Initialize(aLShX);
if (BRep_Tool::IsClosed(aShell)) { for (; aItLShX.More(); aItLShX.Next()) {
aShell.Closed (Standard_True); TopoDS_Shell& aShX=*((TopoDS_Shell*)&aItLShX.Value());
myLoops.Append(aShell); //
if (BRep_Tool::IsClosed(aShX)) {
aShX.Closed(Standard_True);
myLoops.Append(aShX);
} }
} }
} // for (; aItF.More(); aItF.Next()) { } // for (; aItF.More(); aItF.Next()) {
@ -471,7 +477,8 @@ void BOPAlgo_ShellSplitter::SplitBlock(BOPTools_ConnexityBlock& aCB)
//function : RefineShell //function : RefineShell
//purpose : //purpose :
//======================================================================= //=======================================================================
void RefineShell(TopoDS_Shell& theShell) void RefineShell(TopoDS_Shell& theShell,
BOPCol_ListOfShape& aLShX)
{ {
TopoDS_Iterator aIt; TopoDS_Iterator aIt;
// //
@ -480,12 +487,12 @@ void RefineShell(TopoDS_Shell& theShell)
return; return;
} }
// //
Standard_Integer i, aNbMEF, aNbF; Standard_Integer i, aNbMEF, aNbF, aNbMFB;
BOPCol_IndexedDataMapOfShapeListOfShape aMEF; BOPCol_IndexedDataMapOfShapeListOfShape aMEF;
TopoDS_Builder aBB; TopoDS_Builder aBB;
TopExp_Explorer aExp; TopExp_Explorer aExp;
BOPCol_MapOfShape aMEStop, aMFB; BOPCol_IndexedMapOfShape aMFB;
BOPCol_MapIteratorOfMapOfShape aItM; BOPCol_MapOfShape aMEStop, aMFProcessed;
BOPCol_ListIteratorOfListOfShape aItLF, aItLFP; BOPCol_ListIteratorOfListOfShape aItLF, aItLFP;
BOPCol_ListOfShape aLFP, aLFP1; BOPCol_ListOfShape aLFP, aLFP1;
// //
@ -494,6 +501,7 @@ void RefineShell(TopoDS_Shell& theShell)
TopAbs_EDGE, TopAbs_EDGE,
TopAbs_FACE, TopAbs_FACE,
aMEF); aMEF);
aNbMEF=aMEF.Extent(); aNbMEF=aMEF.Extent();
for (i=1; i<=aNbMEF; ++i) { for (i=1; i<=aNbMEF; ++i) {
const TopoDS_Shape& aE=aMEF.FindKey(i); const TopoDS_Shape& aE=aMEF.FindKey(i);
@ -505,69 +513,86 @@ void RefineShell(TopoDS_Shell& theShell)
} }
// //
if (aMEStop.IsEmpty()) { if (aMEStop.IsEmpty()) {
aLShX.Append(theShell);
return; return;
} }
// //
// The first Face // The first Face
const TopoDS_Shape& aF1=aIt.Value(); for (; aIt.More(); aIt.Next()) {
aMFB.Add(aF1); const TopoDS_Shape& aF1=aIt.Value();
aLFP.Append(aF1); if (!aMFProcessed.Add(aF1)) {
// continue;
// Trying to reach the branch point
for (;;) {
aItLFP.Initialize(aLFP);
for (; aItLFP.More(); aItLFP.Next()) {
const TopoDS_Shape& aFP=aItLFP.Value();
//
aExp.Init(aFP, TopAbs_EDGE);
for (; aExp.More(); aExp.Next()) {
const TopoDS_Edge& aE=(*(TopoDS_Edge*)(&aExp.Current()));
if (aMEStop.Contains(aE)) {
continue;
}
//
if (BRep_Tool::Degenerated(aE)) {
continue;
}
//
const BOPCol_ListOfShape& aLF=aMEF.FindFromKey(aE);
//
aItLF.Initialize(aLF);
for (; aItLF.More(); aItLF.Next()) {
const TopoDS_Shape& aFP1=aItLF.Value();
if (aFP1.IsSame(aFP)) {
continue;
}
if (aMFB.Contains(aFP1)) {
continue;
}
aMFB.Add(aFP1);
aLFP1.Append(aFP1);
}// for (; aItLF.More(); aItLF.Next()) {
}// for (; aExp.More(); aExp.Next()) {
}// for (; aItLFP.More(); aItLFP.Next()) {
//
//
if (aLFP1.IsEmpty()) {
break;
} }
// //
aMFB.Clear();
aLFP.Clear(); aLFP.Clear();
aItLF.Initialize(aLFP1); //
for (; aItLF.More(); aItLF.Next()) { aMFB.Add(aF1);
const TopoDS_Shape& aFP1=aItLF.Value(); aLFP.Append(aF1);
aLFP.Append(aFP1); //
// Trying to reach the branch point
for (;;) {
aItLFP.Initialize(aLFP);
for (; aItLFP.More(); aItLFP.Next()) {
const TopoDS_Shape& aFP=aItLFP.Value();
//
aExp.Init(aFP, TopAbs_EDGE);
for (; aExp.More(); aExp.Next()) {
const TopoDS_Edge& aE=(*(TopoDS_Edge*)(&aExp.Current()));
if (aMEStop.Contains(aE)) {
continue;
}
//
if (BRep_Tool::Degenerated(aE)) {
continue;
}
//
const BOPCol_ListOfShape& aLF=aMEF.FindFromKey(aE);
//
aItLF.Initialize(aLF);
for (; aItLF.More(); aItLF.Next()) {
const TopoDS_Shape& aFP1=aItLF.Value();
if (aFP1.IsSame(aFP)) {
continue;
}
if (aMFB.Contains(aFP1)) {
continue;
}
//
aMFProcessed.Add(aFP1);
aMFB.Add(aFP1);
aLFP1.Append(aFP1);
}// for (; aItLF.More(); aItLF.Next()) {
}// for (; aExp.More(); aExp.Next()) {
} // for (; aItLFP.More(); aItLFP.Next()) {
//
//
if (aLFP1.IsEmpty()) {
break;
}
//
aLFP.Clear();
aItLF.Initialize(aLFP1);
for (; aItLF.More(); aItLF.Next()) {
const TopoDS_Shape& aFP1=aItLF.Value();
aLFP.Append(aFP1);
}
aLFP1.Clear();
}// for (;;) {
//
aNbMFB=aMFB.Extent();
if (aNbMFB) {
TopoDS_Shell aShX;
aBB.MakeShell(aShX);
//
for (i=1; i<=aNbMFB; ++i) {
const TopoDS_Shape& aFB=aMFB(i);
aBB.Add(aShX, aFB);
}
aLShX.Append(aShX);
} }
aLFP1.Clear(); }//for (; aIt.More(); aIt.Next()) {
}// for (;;) { }
//
// Remove all faces before the branch point
aItM.Initialize(aMFB);
for (; aItM.More(); aItM.Next()) {
const TopoDS_Shape& aFB=aItM.Value();
aBB.Remove(theShell, aFB);
}
}
//======================================================================= //=======================================================================
//function : MakeShells //function : MakeShells
//purpose : //purpose :

36
tests/bugs/modalg_6/bug26253 Executable file
View File

@ -0,0 +1,36 @@
puts "============"
puts "OCC26253"
puts "============"
puts ""
###############################
## Wrong result obtained by General Fuse operator.
###############################
box b1 -805 585 143 407 30 8
restore [locate_data_file bug26253_qs.brep] b2
bclearobjects
bcleartools
baddobjects b1 b2
bfillds
bbuild result
set square 64832
set nbshapes_expected "
Number of shapes in shape
VERTEX : 40
EDGE : 68
WIRE : 36
FACE : 36
SHELL : 11
SOLID : 6
COMPSOLID : 0
COMPOUND : 1
SHAPE : 198
"
checknbshapes result -ref ${nbshapes_expected} -t -m "result done by General Fuse algorithm"
set 3dviewer 1

View File

@ -1,19 +1,22 @@
puts "TODO CR25432 ALL: Error : The square of result shape is"
puts "================" puts "================"
puts "OCC26" puts "OCC26"
puts "================" puts "================"
puts "" puts ""
restore [locate_data_file OCC26.brep] a restore [locate_data_file OCC26.brep] a
explode a
checkshape a_1
checkshape a_2
bfuse result a_1 a_2 explode a
settolerance a_1 0.000301
settolerance a_2 0.000301
bclearobjects
bcleartools
baddobjects a_1
baddtools a_2
bfillds
bbop result 1
set square 41539.9 set square 41539.9
set 2dviewer 0 set 2dviewer 0