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

0028163: 3D Offset algorithm produces incorrect result on attached shape in mode Complete Intersection

1. Correct building of the lists of intersection faces connected to the same vertex.
2. For the artificially invalid cases with only one invalid face avoid usage of the edges having same origins as invalid edges.
3. Test cases for the issue.
4. Test cases offset shape_type_i_c XM1, ZW*,ZX*,ZY* have been modified to provide more clear result.
5. TODO statements have been removed from the test case offset shape_type_i_c XE6 as it is OK.
6. Test case offset shape_type_i_c ZZ2 is improvement.
This commit is contained in:
emv 2016-11-18 10:06:50 +03:00 committed by apn
parent a8b5267725
commit b443d53628
34 changed files with 454 additions and 165 deletions

View File

@ -443,7 +443,35 @@ void BRepOffset_Inter3d::ConnexIntByInt
// map the shape for vertices // map the shape for vertices
if (bIsPlanar) { if (bIsPlanar) {
TopExp::MapShapes(SI, TopAbs_VERTEX, VEmap); TopExp::MapShapes(SI, TopAbs_VERTEX, VEmap);
TopExp::MapShapesAndAncestors(SI, TopAbs_VERTEX, TopAbs_FACE, aMVF); //
// make vertex-faces connexity map with unique ancestors
// TopExp::MapShapesAndAncestors(SI, TopAbs_VERTEX, TopAbs_FACE, aMVF);
TopExp_Explorer aExpF(SI, TopAbs_FACE);
for (; aExpF.More(); aExpF.Next()) {
const TopoDS_Shape& aF = aExpF.Current();
//
TopExp_Explorer aExpV(aF, TopAbs_VERTEX);
for (; aExpV.More(); aExpV.Next()) {
const TopoDS_Shape& aV = aExpV.Current();
//
TopTools_ListOfShape *pLF = aMVF.ChangeSeek(aV);
if (!pLF) {
pLF = &aMVF(aMVF.Add(aV, TopTools_ListOfShape()));
pLF->Append(aF);
continue;
}
//
TopTools_ListIteratorOfListOfShape aItLF(*pLF);
for (; aItLF.More(); aItLF.Next()) {
if (aItLF.Value().IsSame(aF)) {
break;
}
}
if (!aItLF.More()) {
pLF->Append(aF);
}
}
}
} }
// //
TopTools_DataMapOfShapeListOfShape aDMVLF1, aDMVLF2, aDMIntFF; TopTools_DataMapOfShapeListOfShape aDMVLF1, aDMVLF2, aDMIntFF;
@ -462,19 +490,15 @@ void BRepOffset_Inter3d::ConnexIntByInt
if (aLF.Extent() < 2) { if (aLF.Extent() < 2) {
continue; continue;
} }
// // build lists of faces connected to the same vertex by looking for
// find pairs in which the vertex is alone (not connected to shared edges) // the pairs in which the vertex is alone (not connected to shared edges)
TopTools_ListOfShape aLF1, aLF2; TopTools_ListOfShape aLF1, aLF2;
Standard_Boolean bVertexOnly = Standard_False;
TopTools_MapOfShape aMFence;
// //
it.Initialize(aLF); it.Initialize(aLF);
for (; it.More(); it.Next()) { for (; it.More(); it.Next()) {
const TopoDS_Face& aFV1 = *(TopoDS_Face*)&it.Value(); const TopoDS_Shape& aFV1 = it.Value();
if (!aMFence.Add(aFV1)) {
continue;
}
// //
// get edges of first face connected to current vertex
TopTools_MapOfShape aME; TopTools_MapOfShape aME;
TopExp_Explorer aExp(aFV1, TopAbs_EDGE); TopExp_Explorer aExp(aFV1, TopAbs_EDGE);
for (; aExp.More(); aExp.Next()) { for (; aExp.More(); aExp.Next()) {
@ -488,37 +512,31 @@ void BRepOffset_Inter3d::ConnexIntByInt
} }
} }
// //
it1.Initialize(aLF); // get to the next face in the list
it1 = it;
for (it1.Next(); it1.More(); it1.Next()) { for (it1.Next(); it1.More(); it1.Next()) {
const TopoDS_Face& aFV2 = *(TopoDS_Face*)&it1.Value(); const TopoDS_Shape& aFV2 = it1.Value();
if (aMFence.Contains(aFV2)) {
continue;
}
// //
bVertexOnly = Standard_True;
aExp.Init(aFV2, TopAbs_EDGE); aExp.Init(aFV2, TopAbs_EDGE);
for (; aExp.More(); aExp.Next()) { for (; aExp.More(); aExp.Next()) {
const TopoDS_Shape& aEV2 = aExp.Current(); const TopoDS_Shape& aEV2 = aExp.Current();
if (aME.Contains(aEV2)) { if (aME.Contains(aEV2)) {
bVertexOnly = Standard_False;
break; break;
} }
} }
// //
if (bVertexOnly) { if (!aExp.More()) {
// faces share only vertex - make pair for intersection
aLF1.Append(aFV1); aLF1.Append(aFV1);
aLF2.Append(aFV2); aLF2.Append(aFV2);
aMFence.Add(aFV2);
} }
} }
} }
// //
if (aLF1.IsEmpty()) { if (aLF1.Extent()) {
continue; aDMVLF1.Bind(aS, aLF1);
aDMVLF2.Bind(aS, aLF2);
} }
//
aDMVLF1.Bind(aS, aLF1);
aDMVLF2.Bind(aS, aLF2);
} }
} }
// //

View File

@ -783,19 +783,19 @@ void BuildSplitsOfFaces(const TopTools_ListOfShape& theLF,
TopTools_ListOfShape aLFImages1; TopTools_ListOfShape aLFImages1;
BuildSplitsOfFace(aF, aCE1, Standard_False, theFacesOrigins, aLFImages1); BuildSplitsOfFace(aF, aCE1, Standard_False, theFacesOrigins, aLFImages1);
// //
// additionally check if newly created faces are not the same // check if the rebuilding has added some new faces to the splits
Standard_Boolean bAllInv = Standard_True;
for (TopTools_ListIteratorOfListOfShape aItLFIm(aLFImages1); aItLFIm.More();) for (TopTools_ListIteratorOfListOfShape aItLFIm(aLFImages1); aItLFIm.More();)
{ {
Standard_Boolean bAllInv = Standard_True;
const TopoDS_Shape& aFIm = aItLFIm.Value(); const TopoDS_Shape& aFIm = aItLFIm.Value();
TopExp_Explorer aExpE(aFIm, TopAbs_EDGE); TopExp_Explorer aExpE(aFIm, TopAbs_EDGE);
for (; aExpE.More(); aExpE.Next()) { for (; aExpE.More(); aExpE.Next()) {
const TopoDS_Shape& aE = aExpE.Current(); const TopoDS_Shape& aE = aExpE.Current();
if (!aMapEInv.Contains(aE) && !aMENInv.Contains(aE)) { if (!aMapEInv.Contains(aE)) {
break; bAllInv = Standard_False;
} if (!aMENInv.Contains(aE)) {
else if (bAllInv) { break;
bAllInv = aMapEInv.Contains(aE); }
} }
} }
// //
@ -1314,12 +1314,14 @@ Standard_Boolean CheckIfArtificial(const TopoDS_Shape& theF,
TopExp_Explorer aExpV(aEInv, TopAbs_VERTEX); TopExp_Explorer aExpV(aEInv, TopAbs_VERTEX);
for (; aExpV.More(); aExpV.Next()) { for (; aExpV.More(); aExpV.Next()) {
const TopoDS_Shape& aVEInv = aExpV.Current(); const TopoDS_Shape& aVEInv = aExpV.Current();
if (!aMEUsed.Contains(aVEInv) && aMVE.Contains(aVEInv)) { const TopTools_ListOfShape* pLENInv = aMVE.Seek(aVEInv);
const TopTools_ListOfShape& aLENInv = aMVE.FindFromKey(aVEInv); if (pLENInv) {
TopTools_ListIteratorOfListOfShape aItLEInv(aLENInv); TopTools_ListIteratorOfListOfShape aItLEInv(*pLENInv);
for (; aItLEInv.More(); aItLEInv.Next()) { for (; aItLEInv.More(); aItLEInv.Next()) {
const TopoDS_Shape& aENInv = aItLEInv.Value(); const TopoDS_Shape& aENInv = aItLEInv.Value();
theMENInv.Add(aENInv); if (!aMEUsed.Contains(aENInv)) {
theMENInv.Add(aENInv);
}
} }
} }
} }
@ -1395,7 +1397,7 @@ void FindInvalidEdges(const TopoDS_Face& theF,
// be defined by the edges on the original face adjacent to the connection vertex // be defined by the edges on the original face adjacent to the connection vertex
// //
const TopoDS_Face& aFOr = *(TopoDS_Face*)&theFacesOrigins.Find(theF); const TopoDS_Face& aFOr = *(TopoDS_Face*)&theFacesOrigins.Find(theF);
// invald edges // invalid edges
TopTools_IndexedMapOfShape aMEInv; TopTools_IndexedMapOfShape aMEInv;
// valid edges // valid edges
TopTools_MapOfShape aMEVal; TopTools_MapOfShape aMEVal;
@ -1479,6 +1481,11 @@ void FindInvalidEdges(const TopoDS_Face& theF,
TopTools_MapOfShape aME, aMV; TopTools_MapOfShape aME, aMV;
Standard_Boolean bInvalid = Standard_False, bChecked = Standard_False; Standard_Boolean bInvalid = Standard_False, bChecked = Standard_False;
Standard_Integer aNbP = NbPoints(aEIm); Standard_Integer aNbP = NbPoints(aEIm);
Standard_Boolean bUseVertex = !aNbVOr ? Standard_False :
(aNbVOr == 1 &&
aDMEF.FindFromKey(aEIm).Extent() == 1 &&
!theOEOrigins.IsBound(aEIm));
//
aItLEO.Initialize(aLEOr); aItLEO.Initialize(aLEOr);
for (; aItLEO.More(); aItLEO.Next()) { for (; aItLEO.More(); aItLEO.Next()) {
const TopoDS_Shape& aSOr = aItLEO.Value(); const TopoDS_Shape& aSOr = aItLEO.Value();
@ -1487,18 +1494,9 @@ void FindInvalidEdges(const TopoDS_Face& theF,
TopoDS_Shape aEOrF; TopoDS_Shape aEOrF;
if (bVertex) { if (bVertex) {
// for some cases it is impossible to check the validity of the edge // for some cases it is impossible to check the validity of the edge
if (aNbVOr > 1) { if (!bUseVertex) {
continue; continue;
} }
//
if (aDMEF.FindFromKey(aEIm).Extent() > 1) {
continue;
}
//
if (theOEOrigins.IsBound(aEIm)) {
continue;
}
//
// find edges on the original face adjacent to this vertex // find edges on the original face adjacent to this vertex
if (aDMVEFOr.IsEmpty()) { if (aDMVEFOr.IsEmpty()) {
// fill the map // fill the map
@ -1579,8 +1577,9 @@ void FindInvalidEdges(const TopoDS_Face& theF,
} }
// //
// check if the edge has been inverted // check if the edge has been inverted
Standard_Boolean bInverted = CheckInverted(aEIm, aFOr, theOEImages, theOEOrigins, Standard_Boolean bInverted = !aNbE ? Standard_False :
theEdgesOrigins, aDMEF, aDMVE, aMEdges, theMEInverted); CheckInverted(aEIm, aFOr, theOEImages, theOEOrigins,
theEdgesOrigins, aDMEF, aDMVE, aMEdges, theMEInverted);
// //
if (!bInverted || !aNbVOr) { if (!bInverted || !aNbVOr) {
theValidEdges.Add(aEIm); theValidEdges.Add(aEIm);
@ -1908,10 +1907,6 @@ Standard_Boolean CheckInverted(const TopoDS_Edge& theEIm,
return Standard_False; return Standard_False;
} }
// //
if (theMEInverted.Contains(theEIm)) {
return Standard_True;
}
//
// it is necessary to compare the direction from first vertex // it is necessary to compare the direction from first vertex
// to the last vertex on the original edge with the // to the last vertex on the original edge with the
// same direction on the new edge. If the directions // same direction on the new edge. If the directions
@ -2013,7 +2008,7 @@ Standard_Boolean CheckInverted(const TopoDS_Edge& theEIm,
if (aEO.ShapeType() == TopAbs_EDGE && aMFence.Add(aEO)) { if (aEO.ShapeType() == TopAbs_EDGE && aMFence.Add(aEO)) {
TopoDS_Shape aEOin; TopoDS_Shape aEOin;
if (FindShape(aEO, theFOr, aEOin)) { if (FindShape(aEO, theFOr, aEOin)) {
aLOE.Append(aEO); AppendToList(aLOE, aEO);
} }
} }
} }
@ -2512,6 +2507,7 @@ void RemoveInsideFaces(TopTools_IndexedDataMapOfShapeListOfShape& theFImages,
// //
TopoDS_Compound aSolids; TopoDS_Compound aSolids;
BRep_Builder().MakeCompound(aSolids); BRep_Builder().MakeCompound(aSolids);
TopTools_MapOfShape aMFKeep;
// //
TopExp_Explorer aExpS(aSols, TopAbs_SOLID); TopExp_Explorer aExpS(aSols, TopAbs_SOLID);
for (; aExpS.More(); aExpS.Next()) { for (; aExpS.More(); aExpS.Next()) {
@ -2538,7 +2534,9 @@ void RemoveInsideFaces(TopTools_IndexedDataMapOfShapeListOfShape& theFImages,
const TopoDS_Shape& aFS = aExpF.Current(); const TopoDS_Shape& aFS = aExpF.Current();
// //
if (aMFToRem.Contains(aFS)) { if (aMFToRem.Contains(aFS)) {
aMFToRem.Remove(aFS); if (!aMFKeep.Add(aFS)) {
aMFKeep.Remove(aFS);
}
} }
else { else {
aMFToRem.Add(aFS); aMFToRem.Add(aFS);
@ -2551,6 +2549,11 @@ void RemoveInsideFaces(TopTools_IndexedDataMapOfShapeListOfShape& theFImages,
} }
} }
// //
TopTools_MapIteratorOfMapOfShape aItM(aMFKeep);
for (; aItM.More(); aItM.Next()) {
aMFToRem.Remove(aItM.Value());
}
//
// remove newly found internal faces // remove newly found internal faces
RemoveValidSplits(aMFToRem, theFImages, aMV, theMERemoved); RemoveValidSplits(aMFToRem, theFImages, aMV, theMERemoved);
RemoveInvalidSplits(aMFToRem, theArtInvFaces, theInvEdges, theInvFaces, aMV, theMERemoved); RemoveInvalidSplits(aMFToRem, theArtInvFaces, theInvEdges, theInvFaces, aMV, theMERemoved);
@ -3320,85 +3323,136 @@ void IntersectFaces(const TopTools_IndexedDataMapOfShapeListOfShape& theFToRebui
// when dealing with artificially invalid faces for intersection to be // when dealing with artificially invalid faces for intersection to be
// complete we need to use not only invalid edges, but also the // complete we need to use not only invalid edges, but also the
// edges connected to invalid ones // edges connected to invalid ones
TopTools_MapOfShape aMEAlone, aMFence, aMVEInv;
TopTools_IndexedDataMapOfShapeListOfShape aDMVEVal; // find blocks of artificially invalid faces
// TopTools_DataMapOfShapeShape aDMFImF;
TopoDS_Compound aCFArt;
BRep_Builder().MakeCompound(aCFArt);
TopTools_DataMapIteratorOfDataMapOfShapeShape aItM(theArtInvFaces); TopTools_DataMapIteratorOfDataMapOfShapeShape aItM(theArtInvFaces);
for (; aItM.More(); aItM.Next()) { for (; aItM.More(); aItM.Next()) {
const TopoDS_Shape& aF = aItM.Key(); const TopoDS_Shape& aF = aItM.Key();
const TopTools_ListOfShape& aLFInv = theInvFaces.FindFromKey(aF); const TopTools_ListOfShape& aLFInv = theInvFaces.FindFromKey(aF);
aItLF.Initialize(aLFInv); aItLF.Initialize(aLFInv);
for (; aItLF.More(); aItLF.Next()) { for (; aItLF.More(); aItLF.Next()) {
const TopoDS_Shape& aFInv = aItLF.Value(); BRep_Builder().Add(aCFArt, aItLF.Value());
for (TopExp_Explorer aExp(aFInv, TopAbs_EDGE); aExp.More(); aExp.Next()) aDMFImF.Bind(aItLF.Value(), aF);
{
const TopoDS_Shape& aE = aExp.Current();
if (theInvEdges.Contains(aE)) {
for (TopoDS_Iterator aItV(aE); aItV.More(); aItV.Next()) {
aMVEInv.Add(aItV.Value());
}
continue;
}
if (aMFence.Add(aE)) {
TopExp::MapShapesAndAncestors(aE, TopAbs_VERTEX, TopAbs_EDGE, aDMVEVal);
}
}
} }
} }
// //
// collect edges with free vertices // make connexity blocks
Standard_Integer aNbV = aDMVEVal.Extent(); TopTools_ListOfShape aLCBArt;
for (i = 1; i <= aNbV; ++i) { BOPTools_AlgoTools::MakeConnexityBlocks(aCFArt, TopAbs_VERTEX, TopAbs_FACE, aLCBArt);
const TopoDS_Shape& aV = aDMVEVal.FindKey(i); //
if (!aMVEInv.Contains(aV)) { // alone edges
continue; TopTools_MapOfShape aMEAlone;
//
TopTools_ListIteratorOfListOfShape aItLCBArt(aLCBArt);
for (; aItLCBArt.More(); aItLCBArt.Next()) {
const TopoDS_Shape& aCB = aItLCBArt.Value();
//
// check if aCB contains splits of only one offset face
TopTools_MapOfShape aMFArt;
TopExp_Explorer aExpF(aCB, TopAbs_FACE);
for (; aExpF.More(); aExpF.Next()) {
aMFArt.Add(aDMFImF.Find(aExpF.Current()));
} }
// //
const TopTools_ListOfShape& aLEV = aDMVEVal(i); Standard_Boolean bAlone = (aMFArt.Extent() == 1);
if (aLEV.Extent() > 1) {
continue;
}
// //
const TopoDS_Shape& aE = aLEV.First(); // vertices on invalid edges
aMEAlone.Add(aE); TopTools_MapOfShape aMVEInv;
TopTools_MapOfShape aMFence;
// edges that should not be marked as alone - edges having same origins as invalid ones
TopTools_MapOfShape aMEAvoid;
// map to find alone edges by looking for free vertices
TopTools_IndexedDataMapOfShapeListOfShape aDMVEVal;
// //
// if this alone edge adds nothing to the intersection list TopExp_Explorer aExpE(aCB, TopAbs_EDGE);
// it means that the origin of this edge has been split and we need to for (; aExpE.More(); aExpE.Next()) {
// add the neigboring images of the same origins const TopoDS_Shape& aE = aExpE.Current();
if (aDMSF.Find(aE).Extent() > 1) { if (theInvEdges.Contains(aE)) {
continue; for (TopoDS_Iterator aItV(aE); aItV.More(); aItV.Next()) {
} aMVEInv.Add(aItV.Value());
// }
// check also its vertices //
TopoDS_Iterator aItE(aE); if (bAlone) {
for (; aItE.More(); aItE.Next()) { const TopTools_ListOfShape *pLEOr = theOEOrigins.Seek(aE);
const TopoDS_Shape& aVE = aItE.Value(); if (pLEOr) {
if (aDMSF.Find(aVE).Extent() > 2) { TopTools_ListIteratorOfListOfShape aItLEOr(*pLEOr);
break; for (; aItLEOr.More(); aItLEOr.Next()) {
TopTools_ListIteratorOfListOfShape aItLEIm(theOEImages.Find(aItLEOr.Value()));
for (; aItLEIm.More(); aItLEIm.Next()) {
aMEAvoid.Add(aItLEIm.Value());
}
}
}
}
continue;
}
//
if (aMFence.Add(aE)) {
TopExp::MapShapesAndAncestors(aE, TopAbs_VERTEX, TopAbs_EDGE, aDMVEVal);
} }
} }
// //
if (aItE.More()) { // find edges with free vertices
continue; Standard_Integer aNbV = aDMVEVal.Extent();
} for (i = 1; i <= aNbV; ++i) {
// const TopoDS_Shape& aV = aDMVEVal.FindKey(i);
// the edge is useless - look for other images if (!aMVEInv.Contains(aV)) {
const TopTools_ListOfShape *pLEOr = theOEOrigins.Seek(aE); continue;
if (!pLEOr) { }
continue;
}
//
TopTools_ListIteratorOfListOfShape aItLEOr(*pLEOr);
for (; aItLEOr.More(); aItLEOr.Next()) {
const TopoDS_Shape& aEOr = aItLEOr.Value();
// //
const TopTools_ListOfShape& aLEIm = theOEImages.Find(aEOr); const TopTools_ListOfShape& aLEV = aDMVEVal(i);
TopTools_ListIteratorOfListOfShape aItLEIm(aLEIm); if (aLEV.Extent() > 1) {
for (; aItLEIm.More(); aItLEIm.Next()) { continue;
const TopoDS_Shape& aEIm = aItLEIm.Value(); }
//
const TopoDS_Shape& aE = aLEV.First();
if (aMEAvoid.Contains(aE)) {
continue;
}
//
aMEAlone.Add(aE);
//
// if this alone edge adds nothing to the intersection list
// it means that the origin of this edge has been split and we need to
// add the neighboring images of the same origins
if (aDMSF.Find(aE).Extent() > 1) {
continue;
}
//
// check also its vertices
TopoDS_Iterator aItE(aE);
for (; aItE.More(); aItE.Next()) {
const TopoDS_Shape& aVE = aItE.Value();
if (aDMSF.Find(aVE).Extent() > 2) {
break;
}
}
//
if (aItE.More()) {
continue;
}
//
// the edge is useless - look for other images
const TopTools_ListOfShape *pLEOr = theOEOrigins.Seek(aE);
if (!pLEOr) {
continue;
}
//
TopTools_ListIteratorOfListOfShape aItLEOr(*pLEOr);
for (; aItLEOr.More(); aItLEOr.Next()) {
const TopoDS_Shape& aEOr = aItLEOr.Value();
// //
if (aMFence.Contains(aEIm)) { const TopTools_ListOfShape& aLEIm = theOEImages.Find(aEOr);
aMEAlone.Add(aEIm); TopTools_ListIteratorOfListOfShape aItLEIm(aLEIm);
for (; aItLEIm.More(); aItLEIm.Next()) {
const TopoDS_Shape& aEIm = aItLEIm.Value();
//
if (aMFence.Contains(aEIm)) {
aMEAlone.Add(aEIm);
}
} }
} }
} }
@ -3958,17 +4012,24 @@ void ProcessCommonEdges(const TopTools_ListOfShape& theLEC,
aItLE.Initialize(theLEC); aItLE.Initialize(theLEC);
for (; aItLE.More(); aItLE.Next()) { for (; aItLE.More(); aItLE.Next()) {
const TopoDS_Shape& aEC = aItLE.Value(); const TopoDS_Shape& aEC = aItLE.Value();
if (theAllInvs.Contains(aEC) || theInvEdges.Contains(aEC)) { // check if all images of the origin of this edge
return; // are not connected to any invalidity
} const TopoDS_Shape& aEInt = theETrimEInf.Find(aEC);
// const TopTools_ListOfShape& aLVE = theMEInfETrim.Find(aEInt);
TopoDS_Iterator aItV(aEC); TopTools_ListIteratorOfListOfShape aItLVE(aLVE);
for (; aItV.More(); aItV.Next()) { for (; aItLVE.More(); aItLVE.Next()) {
if (theAllInvs.Contains(aItV.Value())) { const TopoDS_Shape& aECx = aItLVE.Value();
if (theAllInvs.Contains(aECx) || theInvEdges.Contains(aECx)) {
return; return;
} }
//
TopoDS_Iterator aItV(aECx);
for (; aItV.More(); aItV.Next()) {
if (theAllInvs.Contains(aItV.Value())) {
return;
}
}
} }
//
// use only one element // use only one element
if (aLEC.IsEmpty()) { if (aLEC.IsEmpty()) {
aLEC.Append(aEC); aLEC.Append(aEC);
@ -4514,6 +4575,7 @@ void UpdateValidEdges(const TopTools_IndexedDataMapOfShapeListOfShape& theFImage
// back connection from edges to faces // back connection from edges to faces
TopTools_DataMapOfShapeListOfShape aMELF; TopTools_DataMapOfShapeListOfShape aMELF;
// //
TopTools_MapOfShape aMETmp;
Standard_Integer i, aNb = theFLE.Extent(); Standard_Integer i, aNb = theFLE.Extent();
for (i = 1; i <= aNb; ++i) { for (i = 1; i <= aNb; ++i) {
const TopoDS_Face& aF = TopoDS::Face(theFLE.FindKey(i)); const TopoDS_Face& aF = TopoDS::Face(theFLE.FindKey(i));
@ -4522,6 +4584,11 @@ void UpdateValidEdges(const TopTools_IndexedDataMapOfShapeListOfShape& theFImage
TopTools_ListIteratorOfListOfShape aItLE(aLEInt); TopTools_ListIteratorOfListOfShape aItLE(aLEInt);
for (; aItLE.More(); aItLE.Next()) { for (; aItLE.More(); aItLE.Next()) {
const TopoDS_Shape& aE = aItLE.Value(); const TopoDS_Shape& aE = aItLE.Value();
if ((theMECheckExt.Contains(aE) || aMETmp.Contains(aE)) && !theEImages.IsBound(aE)) {
theMECheckExt.Remove(aE);
aMETmp.Add(aE);
continue;
}
TopTools_ListOfShape* pLF = aMELF.ChangeSeek(aE); TopTools_ListOfShape* pLF = aMELF.ChangeSeek(aE);
if (!pLF) { if (!pLF) {
pLF = aMELF.Bound(aE, TopTools_ListOfShape()); pLF = aMELF.Bound(aE, TopTools_ListOfShape());
@ -4728,6 +4795,8 @@ void TrimNewIntersectionEdges(const TopTools_ListOfShape& theLE,
for (; aIt.More(); aIt.Next()) { for (; aIt.More(); aIt.Next()) {
const TopoDS_Shape& aE = aIt.Value(); const TopoDS_Shape& aE = aIt.Value();
// //
Standard_Boolean bCheckExt = theMECheckExt.Remove(aE);
//
Standard_Boolean bOld = theEETrim.IsBound(aE); Standard_Boolean bOld = theEETrim.IsBound(aE);
if (bOld) { if (bOld) {
const TopTools_ListOfShape& aLET = theEETrim.Find(aE); const TopTools_ListOfShape& aLET = theEETrim.Find(aE);
@ -4820,7 +4889,6 @@ void TrimNewIntersectionEdges(const TopTools_ListOfShape& theLE,
} }
} }
// //
Standard_Boolean bCheckExt = theMECheckExt.Contains(aE);
if (aLEIm.IsEmpty()) { if (aLEIm.IsEmpty()) {
theEImages.UnBind(aE); theEImages.UnBind(aE);
} }
@ -4846,10 +4914,6 @@ void TrimNewIntersectionEdges(const TopTools_ListOfShape& theLE,
} }
} }
} }
//
if (bCheckExt) {
theMECheckExt.Remove(aE);
}
} }
} }

View File

@ -1,10 +1,10 @@
puts "TODO CR27414 ALL: Error : The area of result shape is"
puts "TODO CR27414 ALL: Error : The volume of result shape is"
restore [locate_data_file bug26917_dom-7724_trim5.brep] s restore [locate_data_file bug26917_dom-7724_trim5.brep] s
OFFSETSHAPE 15 {} $calcul $type OFFSETSHAPE 15 {} $calcul $type
checkprops result -v 0 -s 0 checkprops result -v 596571 -s 50145.4
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 9 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -1,10 +1,12 @@
restore [locate_data_file bug28046_rm-107_merged_input.brep] s restore [locate_data_file bug28046_rm-107_merged_input.brep] s
OFFSETSHAPE 8 {} $calcul $type offsetparameter 1e-7 c i r
offsetload s 8
offsetperform result
checkprops result -v 4.40128e+007 -s 1.81672e+006 checkprops result -v 4.40128e+007 -s 1.81672e+006
unifysamedom result_unif result unifysamedom result_unif result
checknbshapes result_unif -face 64 -shell 1 checknbshapes result_unif -edge 186 -face 64 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -0,0 +1,27 @@
restore [locate_data_file bug28163_merged_input.brep] s
offsetparameter 1e-7 c i
offsetload s 4
foreach f [explode s f] {
mksurface surf $f
set found [regexp {Axis :([-0-9.+eE]*), ([-0-9.+eE]*), ([-0-9.+eE]*)} [dump surf] full x y z]
if {$found && abs(abs($z) - 1) < 1.e-7} {
offsetonface $f 3
} else {
if { y < -0.7 } {
offsetonface $f 5
} else {
if { y > 0.7 } {
offsetonface $f 3
}
}
}
}
offsetperform result
checkprops result -v 4.27764e+007 -s 1.70699e+006
unifysamedom result_unif result
checknbshapes result_unif -face 413 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -0,0 +1,27 @@
restore [locate_data_file bug28163_merged_input_trim1.brep] s
offsetparameter 1e-7 c i
offsetload s 4
foreach f [explode s f] {
mksurface surf $f
set found [regexp {Axis :([-0-9.+eE]*), ([-0-9.+eE]*), ([-0-9.+eE]*)} [dump surf] full x y z]
if {$found && abs(abs($z) - 1) < 1.e-7} {
offsetonface $f 3
} else {
if { y < -0.7 } {
offsetonface $f 5
} else {
if { y > 0.7 } {
offsetonface $f 3
}
}
}
}
offsetperform result
checkprops result -v 1.62872e+007 -s 600815
unifysamedom result_unif result
checknbshapes result_unif -face 90 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -0,0 +1,27 @@
restore [locate_data_file bug28163_merged_input_trim3.brep] s
offsetparameter 1e-7 c i
offsetload s 4
foreach f [explode s f] {
mksurface surf $f
set found [regexp {Axis :([-0-9.+eE]*), ([-0-9.+eE]*), ([-0-9.+eE]*)} [dump surf] full x y z]
if {$found && abs(abs($z) - 1) < 1.e-7} {
offsetonface $f 3
} else {
if { y < -0.7 } {
offsetonface $f 5
} else {
if { y > 0.7 } {
offsetonface $f 3
}
}
}
}
offsetperform result
checkprops result -v 1.23529e+006 -s 103271
unifysamedom result_unif result
checknbshapes result_unif -face 35 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -0,0 +1,27 @@
restore [locate_data_file bug28163_merged_input_trim5.brep] s
offsetparameter 1e-7 c i
offsetload s 4
foreach f [explode s f] {
mksurface surf $f
set found [regexp {Axis :([-0-9.+eE]*), ([-0-9.+eE]*), ([-0-9.+eE]*)} [dump surf] full x y z]
if {$found && abs(abs($z) - 1) < 1.e-7} {
offsetonface $f 3
} else {
if { y < -0.7 } {
offsetonface $f 5
} else {
if { y > 0.7 } {
offsetonface $f 3
}
}
}
}
offsetperform result
checkprops result -v 195034 -s 24982.5
unifysamedom result_unif result
checknbshapes result_unif -face 12 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -0,0 +1,10 @@
restore [locate_data_file bug28163_merged_input.brep] s
OFFSETSHAPE 4 {} $calcul $type
checkprops result -v 4.44822e+007 -s 1.70739e+006
unifysamedom result_unif result
checknbshapes result_unif -face 423 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -0,0 +1,10 @@
restore [locate_data_file bug28163_merged_input_trim1.brep] s
OFFSETSHAPE 4 {} $calcul $type
checkprops result -v 1.68905e+007 -s 606317
unifysamedom result_unif result
checknbshapes result_unif -face 91 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -0,0 +1,10 @@
restore [locate_data_file bug28163_merged_input_trim3.brep] s
OFFSETSHAPE 4 {} $calcul $type
checkprops result -v 1.34032e+006 -s 107264
unifysamedom result_unif result
checknbshapes result_unif -face 36 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -0,0 +1,10 @@
restore [locate_data_file bug28163_merged_input_trim5.brep] s
OFFSETSHAPE 4 {} $calcul $type
checkprops result -v 220952 -s 26863.2
unifysamedom result_unif result
checknbshapes result_unif -face 12 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43.7 {} $calcul $type
checkprops result -v 2.70147e+009 checkprops result -v 2.70147e+009
checkprops result -s 1.63922e+007 checkprops result -s 1.63922e+007
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 38 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43.7 {} $calcul $type
checkprops result -v 4.55952e+006 checkprops result -v 4.55952e+006
checkprops result -s 178524 checkprops result -s 178524
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 14 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 14 {} $calcul $type
checkprops result -v 702756 checkprops result -v 702756
checkprops result -s 58381.3 checkprops result -s 58381.3
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 9 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43.7 {} $calcul $type
checkprops result -v 3.77467e+006 checkprops result -v 3.77467e+006
checkprops result -s 155537 checkprops result -s 155537
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 8 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 4 {} $calcul $type
checkprops result -v 3771.44 checkprops result -v 3771.44
checkprops result -s 1506.76 checkprops result -s 1506.76
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 12 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 5 {} $calcul $type
checkprops result -v 5453.96 checkprops result -v 5453.96
checkprops result -s 1912.14 checkprops result -s 1912.14
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 13 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -9,4 +9,7 @@ offsetperform result
checkprops result -v 5530.7 checkprops result -v 5530.7
checkprops result -s 1919.49 checkprops result -s 1919.49
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 13 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 15 {} $calcul $type
checkprops result -v 48955.7 checkprops result -v 48955.7
checkprops result -s 8048.95 checkprops result -s 8048.95
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 8 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 6 {} $calcul $type
checkprops result -v 7543.63 checkprops result -v 7543.63
checkprops result -s 2359.85 checkprops result -s 2359.85
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 13 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43 {} $calcul $type
checkprops result -v 7.05903e+008 checkprops result -v 7.05903e+008
checkprops result -s 5.59084e+006 checkprops result -s 5.59084e+006
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 21 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 35 {} $calcul $type
checkprops result -v 7.94674e+008 checkprops result -v 7.94674e+008
checkprops result -s 6.11963e+006 checkprops result -s 6.11963e+006
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 22 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43 {} $calcul $type
checkprops result -v 7.05903e+008 checkprops result -v 7.05903e+008
checkprops result -s 5.59084e+006 checkprops result -s 5.59084e+006
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 21 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43 {} $calcul $type
checkprops result -v 9.12393e+008 checkprops result -v 9.12393e+008
checkprops result -s 7.01321e+006 checkprops result -s 7.01321e+006
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 21 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43 {} $calcul $type
checkprops result -v 5.23391e+008 checkprops result -v 5.23391e+008
checkprops result -s 4.7898e+006 checkprops result -s 4.7898e+006
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 22 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43 {} $calcul $type
checkprops result -v 1.58077e+009 checkprops result -v 1.58077e+009
checkprops result -s 1.04396e+007 checkprops result -s 1.04396e+007
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 38 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43 {} $calcul $type
checkprops result -v 2.09462e+009 checkprops result -v 2.09462e+009
checkprops result -s 1.32364e+007 checkprops result -s 1.32364e+007
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 38 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43 {} $calcul $type
checkprops result -v 7.05903e+008 checkprops result -v 7.05903e+008
checkprops result -s 5.59084e+006 checkprops result -s 5.59084e+006
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 21 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 43 {} $calcul $type
checkprops result -v 5.23391e+008 checkprops result -v 5.23391e+008
checkprops result -s 4.7898e+006 checkprops result -s 4.7898e+006
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 22 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -4,4 +4,7 @@ OFFSETSHAPE 6 {} $calcul $type
checkprops result -v 813077 -s 70451.1 checkprops result -v 813077 -s 70451.1
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 14 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -5,4 +5,7 @@ OFFSETSHAPE 3 {} $calcul $type
checkprops result -v 4422.98 checkprops result -v 4422.98
checkprops result -s 1736.95 checkprops result -s 1736.95
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 14 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png

View File

@ -1,6 +1,6 @@
puts "TODO CR27414 ALL: Error : The area of result shape is" puts "TODO OCC27414 ALL: Error: The command cannot be built"
puts "TODO CR27414 ALL: Error : The volume of result shape is" puts "TODO OCC27414 ALL: gives an empty result"
puts "TODO CR27414 ALL: is not equal to zero" puts "TODO OCC27414 ALL: TEST INCOMPLETE"
restore [locate_data_file bug26917_input_segfault.brep] s restore [locate_data_file bug26917_input_segfault.brep] s

View File

@ -1,13 +1,10 @@
puts "TODO CR27414 ALL: Error : The area of result shape is"
puts "TODO CR27414 ALL: Error : The volume of result shape is"
puts "TODO CR27414 ALL: Error : is WRONG because number of SHELL entities in shape"
puts "TODO CR27414 ALL: is not equal to zero"
restore [locate_data_file bug26917_offset_topology.brep] s restore [locate_data_file bug26917_offset_topology.brep] s
OFFSETSHAPE 10 {} $calcul $type OFFSETSHAPE 10 {} $calcul $type
checkprops result -v 0 checkprops result -s 4.24638e+006 -v 2.9367e+008
checkprops result -s 0
checknbshapes result -shell 1 unifysamedom result_unif result
checknbshapes result_unif -face 100 -shell 1
checkview -display result_unif -2d -path ${imagedir}/${test_image}.png