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

0025376: Inconsistence between function and derivatives evaluation in Extrema_GlobOptFuncCS.

Changed "value" function behavior in Extrema/Extrema_GlobOptFuncCS.cxx. Now it compute square distance between point on curve and point on surface.

Fixed description in Extrema_GlobOptFuncCC.
This commit is contained in:
aml 2014-10-15 11:44:53 +04:00 committed by bugmaster
parent ed06327034
commit f82a9555dc
4 changed files with 28 additions and 21 deletions

View File

@ -24,8 +24,8 @@
#include <math_MultipleVarFunctionWithGradient.hxx> #include <math_MultipleVarFunctionWithGradient.hxx>
#include <math_MultipleVarFunctionWithHessian.hxx> #include <math_MultipleVarFunctionWithHessian.hxx>
//! This class implements function which operates with Eucluidean distance <br> //! This class implements function which calculate Eucluidean distance
//! between 2 curves in case of C1 and C2 continuity is C0. //! between point on curve and point on other curve in case of C1 and C2 continuity is C0.
class Extrema_GlobOptFuncCCC0 : public math_MultipleVarFunction class Extrema_GlobOptFuncCCC0 : public math_MultipleVarFunction
{ {
public: public:
@ -53,8 +53,8 @@ private:
}; };
//! This class implements function which operates with Eucluidean distance <br> //! This class implements function which calculate Eucluidean distance
//! between 2 curves in case of C1 and C2 continuity is C1. //! between point on curve and point on other curve in case of C1 and C2 continuity is C1.
class Extrema_GlobOptFuncCCC1 : public math_MultipleVarFunctionWithGradient class Extrema_GlobOptFuncCCC1 : public math_MultipleVarFunctionWithGradient
{ {
public: public:
@ -84,8 +84,8 @@ private:
}; };
//! This class implements function which operates with Eucluidean distance <br> //! This class implements function which calculate Eucluidean distance
//! between 2 curves in case of C1 and C2 continuity is C2 or more. //! between point on curve and point on other curve in case of C1 and C2 continuity is C2.
class Extrema_GlobOptFuncCCC2 : public math_MultipleVarFunctionWithHessian class Extrema_GlobOptFuncCCC2 : public math_MultipleVarFunctionWithHessian
{ {
public: public:

View File

@ -21,9 +21,9 @@
#include <Standard_Integer.hxx> #include <Standard_Integer.hxx>
#include <Standard_OutOfRange.hxx> #include <Standard_OutOfRange.hxx>
//! F = Sqrt( (x1(cu) - x2(su,sv))^2 //!F(cu, su, sv)=(C^{(x)}(cu)-S^{(x)}(su,sv))^{2}+
// + (y1(cu) - y2(su,sv))^2 // (C^{(y)}(cu)-S^{(y)}(su,sv))^{2}+
// + (z1(cu) - z2(su,sv))^2 ) // (C^{(z)}(cu)-S^{(z)}(su,sv))^{2}
//======================================================================= //=======================================================================
@ -35,7 +35,7 @@ void Extrema_GlobOptFuncCS::value(Standard_Real cu,
Standard_Real sv, Standard_Real sv,
Standard_Real &F) Standard_Real &F)
{ {
F = myC->Value(cu).Distance(myS->Value(su, sv)); F = myC->Value(cu).SquareDistance(myS->Value(su, sv));
} }
//======================================================================= //=======================================================================
@ -85,33 +85,41 @@ void Extrema_GlobOptFuncCS::hessian(Standard_Real cu,
+ (CD0.X() - SD0.X()) * CD2.X() + (CD0.X() - SD0.X()) * CD2.X()
+ (CD0.Y() - SD0.Y()) * CD2.Y() + (CD0.Y() - SD0.Y()) * CD2.Y()
+ (CD0.Z() - SD0.Z()) * CD2.Z(); + (CD0.Z() - SD0.Z()) * CD2.Z();
H(1,2) = - CD1.X() * SD1U.X() H(1,2) = - CD1.X() * SD1U.X()
- CD1.Y() * SD1U.Y() - CD1.Y() * SD1U.Y()
- CD1.Z() * SD1U.Z(); - CD1.Z() * SD1U.Z();
H(1,3) = - CD1.X() * SD1V.X() H(1,3) = - CD1.X() * SD1V.X()
- CD1.Y() * SD1V.Y() - CD1.Y() * SD1V.Y()
- CD1.Z() * SD1V.Z(); - CD1.Z() * SD1V.Z();
H(2,1) = H(1,2); H(2,1) = H(1,2);
H(2,2) = + SD1U.X() * SD1U.X() H(2,2) = + SD1U.X() * SD1U.X()
+ SD1U.Y() * SD1U.Y() + SD1U.Y() * SD1U.Y()
+ SD1U.Z() * SD1U.Z() + SD1U.Z() * SD1U.Z()
- (CD0.X() - SD0.X()) * SD2UU.X() - (CD0.X() - SD0.X()) * SD2UU.X()
- (CD0.X() - SD0.X()) * SD2UU.Y() - (CD0.Y() - SD0.Y()) * SD2UU.Y()
- (CD0.X() - SD0.X()) * SD2UU.Z(); - (CD0.Z() - SD0.Z()) * SD2UU.Z();
H(2,3) = + SD1U.X() * SD1V.X() H(2,3) = + SD1U.X() * SD1V.X()
+ SD1U.Y() * SD1V.Y() + SD1U.Y() * SD1V.Y()
+ SD1U.Z() * SD1V.Z() + SD1U.Z() * SD1V.Z()
- (CD0.X() - SD0.X()) * SD2UV.X() - (CD0.X() - SD0.X()) * SD2UV.X()
- (CD0.X() - SD0.X()) * SD2UV.Y() - (CD0.Y() - SD0.Y()) * SD2UV.Y()
- (CD0.X() - SD0.X()) * SD2UV.Z(); - (CD0.Z() - SD0.Z()) * SD2UV.Z();
H(3,1) = H(1,3); H(3,1) = H(1,3);
H(3,2) = H(2,3); H(3,2) = H(2,3);
H(3,3) = + SD1V.X() * SD1V.X() H(3,3) = + SD1V.X() * SD1V.X()
+ SD1V.Y() * SD1V.Y() + SD1V.Y() * SD1V.Y()
+ SD1V.Z() * SD1V.Z() + SD1V.Z() * SD1V.Z()
- (CD0.X() - SD0.X()) * SD2VV.X() - (CD0.X() - SD0.X()) * SD2VV.X()
- (CD0.X() - SD0.X()) * SD2VV.Y() - (CD0.Y() - SD0.Y()) * SD2VV.Y()
- (CD0.X() - SD0.X()) * SD2VV.Z(); - (CD0.Z() - SD0.Z()) * SD2VV.Z();
} }
//======================================================================= //=======================================================================

View File

@ -23,7 +23,7 @@
#include <math_Vector.hxx> #include <math_Vector.hxx>
#include <math_MultipleVarFunctionWithHessian.hxx> #include <math_MultipleVarFunctionWithHessian.hxx>
//! This class implements function which calculate Eucluidean distance //! This class implements function which calculate square Eucluidean distance
//! between point on curve and point on surface in case of continuity is C2. //! between point on curve and point on surface in case of continuity is C2.
class Extrema_GlobOptFuncCS : public math_MultipleVarFunctionWithHessian class Extrema_GlobOptFuncCS : public math_MultipleVarFunctionWithHessian
{ {

View File

@ -85,7 +85,7 @@ void math_PSO::Perform(const math_Vector& theSteps,
{ {
myFunc->Value(aCurrPoint, aCurrValue); myFunc->Value(aCurrPoint, aCurrValue);
if (aCurrValue * aCurrValue < aParticle->Distance) if (aCurrValue < aParticle->Distance)
{ {
Standard_Integer aDimIdx; Standard_Integer aDimIdx;
for(aDimIdx = 0; aDimIdx < myN; ++aDimIdx) for(aDimIdx = 0; aDimIdx < myN; ++aDimIdx)
@ -93,8 +93,8 @@ void math_PSO::Perform(const math_Vector& theSteps,
aParticle->Position[aDimIdx] = aCurrPoint(aDimIdx + 1); aParticle->Position[aDimIdx] = aCurrPoint(aDimIdx + 1);
aParticle->BestPosition[aDimIdx] = aCurrPoint(aDimIdx + 1); aParticle->BestPosition[aDimIdx] = aCurrPoint(aDimIdx + 1);
} }
aParticle->Distance = aCurrValue * aCurrValue; aParticle->Distance = aCurrValue;
aParticle->BestDistance = aCurrValue * aCurrValue; aParticle->BestDistance = aCurrValue;
aParticle = aPool.GetWorstParticle(); aParticle = aPool.GetWorstParticle();
} }
@ -199,7 +199,6 @@ void math_PSO::performPSOWithGivenParticles(math_PSOParticlesPool& theParticles,
} }
myFunc->Value(aCurrPoint, aParticle->Distance); myFunc->Value(aCurrPoint, aParticle->Distance);
aParticle->Distance *= aParticle->Distance;
if(aParticle->Distance < aParticle->BestDistance) if(aParticle->Distance < aParticle->BestDistance)
{ {
aParticle->BestDistance = aParticle->Distance; aParticle->BestDistance = aParticle->Distance;