diff --git a/src/IntTools/IntTools_BeanFaceIntersector.cxx b/src/IntTools/IntTools_BeanFaceIntersector.cxx index aa0318de99..d00108bded 100644 --- a/src/IntTools/IntTools_BeanFaceIntersector.cxx +++ b/src/IntTools/IntTools_BeanFaceIntersector.cxx @@ -1166,7 +1166,7 @@ void IntTools_BeanFaceIntersector::ComputeRangeFromStartPoint(const Standard_Boo if(anExtrema.IsDone()) { if(anExtrema.SquareDistance() < myCriteria * myCriteria) { Extrema_POnSurf aPOnSurf = anExtrema.Point(); - aPOnSurf.Parameter(U, V); + aPOnSurf.Parameter(U, V); pointfound = Standard_True; } } @@ -1182,13 +1182,13 @@ void IntTools_BeanFaceIntersector::ComputeRangeFromStartPoint(const Standard_Boo break; } else { - aDeltaRestrictor = aDelta; + aDeltaRestrictor *= 0.5; } // if point found decide to increase aDelta using derivative of distance function // - aDelta = (pointfound) ? (aDelta * 2.) : (aDelta * 0.5); + aDelta *= (pointfound) ? 2.0 : 0.5; aDelta = (aDelta < aDeltaRestrictor) ? aDelta : aDeltaRestrictor; aCurPar = (ToIncreaseParameter) ? (aPrevPar + aDelta) : (aPrevPar - aDelta); @@ -1197,8 +1197,10 @@ void IntTools_BeanFaceIntersector::ComputeRangeFromStartPoint(const Standard_Boo // prevent infinite loop when (aPrevPar +/- aDelta) == aPrevPar == 0. // - if( aCurPar == aPrevPar ) + if (Abs(aCurPar - aPrevPar) < myCurveResolution) + { break; + } BoundaryCondition = (ToIncreaseParameter) ? (aCurPar > aCurrentRange.Last()) : (aCurPar < aCurrentRange.First()); diff --git a/tests/bugs/modalg_7/bug26563 b/tests/bugs/modalg_7/bug26563 index 34557fec8d..d3de2d2319 100644 --- a/tests/bugs/modalg_7/bug26563 +++ b/tests/bugs/modalg_7/bug26563 @@ -18,6 +18,6 @@ bapibop result 2 checkshape result checkprops result -v 1.52043e+7 -checknbshapes result -vertex 234 -edge 354 -wire 122 -face 121 -shell 1 -solid 1 -compsolid 0 -compound 1 -shape 834 +checknbshapes result -vertex 235 -edge 355 -wire 122 -face 121 -shell 1 -solid 1 -compsolid 0 -compound 1 -shape 836 checkview -display result -2d -path ${imagedir}/${test_image}.png diff --git a/tests/perf/modalg/bug29144 b/tests/perf/modalg/bug29144 new file mode 100644 index 0000000000..72dc0f7888 --- /dev/null +++ b/tests/perf/modalg/bug29144 @@ -0,0 +1,27 @@ +puts "========" +puts "0029144: Modeling Algorithms - BOP PaveFiller hangs in some case" +puts "========" +puts "" + +puts "TODO OCC29145 ALL : Faulty shapes in variables faulty_1 to faulty_" + +bclearobjects; +bcleartools; + +restore [locate_data_file bug29093_hung3.brep] a +explode a So +baddobjects a_7 +baddtools a_11 + +dchrono cr restart + +bfillds +bbuild result + +dchrono cr stop counter bbuild + +checkshape result +checkprops result -s 1313890 -v 46778600 +checknbshapes result -vertex 9 -edge 20 -wire 12 -face 12 -shell 3 -solid 3 + +checkview -display result -2d -path ${imagedir}/${test_image}.png