From 35dced1c14265519e74fae4fc173bb7514b7d5d7 Mon Sep 17 00:00:00 2001 From: ifv Date: Thu, 15 Jun 2017 11:53:29 +0300 Subject: [PATCH] 0028856: Extrema between two curves gives wrong result Treatment for large Lipschitz constant is added Test case is added --- src/Extrema/Extrema_GenExtCC.gxx | 6 ++++++ src/math/math_GlobOptMin.cxx | 12 ++++++++---- tests/bugs/modalg_7/bug28856 | 13 +++++++++++++ 3 files changed, 27 insertions(+), 4 deletions(-) create mode 100644 tests/bugs/modalg_7/bug28856 diff --git a/src/Extrema/Extrema_GenExtCC.gxx b/src/Extrema/Extrema_GenExtCC.gxx index a03e33d116..250f610c15 100644 --- a/src/Extrema/Extrema_GenExtCC.gxx +++ b/src/Extrema/Extrema_GenExtCC.gxx @@ -211,6 +211,7 @@ void Extrema_GenExtCC::Perform() C2.Intervals(anIntervals2, aContinuity); // Lipchitz constant computation. + const Standard_Real aMaxLC = 10000.; Standard_Real aLC = 9.0; // Default value. const Standard_Real aMaxDer1 = 1.0 / C1.Resolution(1.0); const Standard_Real aMaxDer2 = 1.0 / C2.Resolution(1.0); @@ -226,6 +227,11 @@ void Extrema_GenExtCC::Perform() { isConstLockedFlag = Standard_True; } + if (aMaxDer > aMaxLC) + { + aLC = aMaxLC; + isConstLockedFlag = Standard_True; + } if (C1.GetType() == GeomAbs_Line) { aMaxDer = 1.0 / C2.Resolution(1.0); diff --git a/src/math/math_GlobOptMin.cxx b/src/math/math_GlobOptMin.cxx index ace855134a..15107354c2 100644 --- a/src/math/math_GlobOptMin.cxx +++ b/src/math/math_GlobOptMin.cxx @@ -343,6 +343,10 @@ Standard_Boolean math_GlobOptMin::computeLocalExtremum(const math_Vector& thePnt //======================================================================= void math_GlobOptMin::computeInitialValues() { + const Standard_Real aMinLC = 0.01; + const Standard_Real aMaxLC = 1000.; + const Standard_Real aMinEps = 0.1; + const Standard_Real aMaxEps = 100.; Standard_Integer i; math_Vector aCurrPnt(1, myN); math_Vector aBestPnt(1, myN); @@ -374,10 +378,10 @@ void math_GlobOptMin::computeInitialValues() myC = myInitC; aLipConst *= Sqrt(myN) / aStep; - if (aLipConst < myC * 0.1) - myC = Max(aLipConst * 0.1, 0.01); - else if (aLipConst > myC * 5) - myC = Min(myC * 5, 50.0); + if (aLipConst < myC * aMinEps) + myC = Max(aLipConst * aMinEps, aMinLC); + else if (aLipConst > myC * aMaxEps) + myC = Min(myC * aMaxEps, aMaxLC); // Clear all solutions except one. if (myY.Size() != myN) diff --git a/tests/bugs/modalg_7/bug28856 b/tests/bugs/modalg_7/bug28856 new file mode 100644 index 0000000000..29a1c61fc4 --- /dev/null +++ b/tests/bugs/modalg_7/bug28856 @@ -0,0 +1,13 @@ +puts "========" +puts "OCC28856" +puts "========" +puts "" +######################################## +# Extrema between two curves gives wrong result +######################################## + +# Restore the initial shape +restore [locate_data_file bug28856_shapes.brep] e +explode e +distmini dd e_1 e_2 +checkprops dd -l 0.101881