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

0024359: Crash on BRepAlgoAPI_Fuse

Test case for issue CR24359
This commit is contained in:
ifv 2013-12-05 15:36:22 +04:00 committed by bugmaster
parent d4a2c5155a
commit ef2d8af761
2 changed files with 488 additions and 449 deletions

View File

@ -133,6 +133,7 @@ static gp_Pnt2d Function_Value(const Standard_Real U,
}
if ( UCouture) {
if(S < U1 || S > U2)
S = ElCLib::InPeriod(S, U1, U2);
}
@ -142,8 +143,10 @@ static gp_Pnt2d Function_Value(const Standard_Real U,
T = M_PI - T;
S = M_PI + S;
}
if(S > U1 || S < U2)
S = ElCLib::InPeriod(S, U1, U2);
}
if(T < V1 || T > V2)
T = ElCLib::InPeriod(T, V1, V2);
}
@ -477,18 +480,60 @@ static void Function_SetUVBounds(Standard_Real& myU1,
// box+sphere >>
Standard_Real UU = 0.;
ElSLib::Parameters(SP, P1, U1, V1);
Standard_Real eps = 2.*Epsilon(1.);
Standard_Real dt = Max(Precision::PConfusion(), 0.01*(W2-W1));
if(Abs(U1) < eps)
{
//May be U1 must be equal 2*PI?
gp_Pnt Pd = myCurve->Value(W1+dt);
Standard_Real ud, vd;
ElSLib::Parameters(SP, Pd, ud, vd);
if(Abs(U1 - ud) > M_PI)
{
U1 = 2.*M_PI;
}
}
else if(Abs(2.*M_PI - U1) < eps)
{
//maybe U1 = 0.?
gp_Pnt Pd = myCurve->Value(W1+dt);
Standard_Real ud, vd;
ElSLib::Parameters(SP, Pd, ud, vd);
if(Abs(U1 - ud) > M_PI)
{
U1 = 0.;
}
}
//
ElSLib::Parameters(SP, P2, U2, V1);
if(Abs(U2) < eps)
{
//May be U2 must be equal 2*PI?
gp_Pnt Pd = myCurve->Value(W2-dt);
Standard_Real ud, vd;
ElSLib::Parameters(SP, Pd, ud, vd);
if(Abs(U2 - ud) > M_PI)
{
U2 = 2.*M_PI;
}
}
else if(Abs(2.*M_PI - U2) < eps)
{
//maybe U2 = 0.?
gp_Pnt Pd = myCurve->Value(W2-dt);
Standard_Real ud, vd;
ElSLib::Parameters(SP, Pd, ud, vd);
if(Abs(U2 - ud) > M_PI)
{
U2 = 0.;
}
}
//
ElSLib::Parameters(SP, P, UU, V1);
Standard_Real UUmi = Min(Min(U1,UU),Min(UU,U2));
Standard_Real UUma = Max(Max(U1,UU),Max(UU,U2));
Standard_Boolean reCalc = ((UUmi >= 0. && UUmi <= M_PI) && (UUma >= 0. && UUma <= M_PI));
// box+sphere <<
ElSLib::Parameters(SP, P1, U1, V1);//*
//
Parameters(myCurve, mySurface, P1, 1, aTPC, U1, V1);
//
//
P2 = myCurve->Value(W1+M_PI/8);
ElSLib::Parameters(SP,P2,U2,V2);
//
@ -550,35 +595,6 @@ static void Function_SetUVBounds(Standard_Real& myU1,
myU2 = U+M_PI;
VCouture = Standard_False;
}
else {
ElSLib::Parameters(SP,P1,U1,V1);//*
//
Parameters(myCurve, mySurface, P1, 1, aTPC, U1, V1);
//
P2 = myCurve->Value(W1+M_PI/8);
ElSLib::Parameters(SP,P2,U2,V2);
if ( Abs(U1-U2) > M_PI) { // on traverse la couture
if ( U1 > M_PI) {
myU1 = U1;
myU2 = U1+2*M_PI;
}
else {
myU2 = U1;
myU1 = U1-2*M_PI;
}
}
else { // on ne traverse pas la couture
if ( U1 > U2) {
myU2 = U1;
myU1 = U1-2*M_PI;
}
else {
myU1 = U1;
myU2 = U1+2*M_PI;
}
}
}
}
// box+sphere >>
@ -589,9 +605,8 @@ static void Function_SetUVBounds(Standard_Real& myU1,
Standard_Real U,V;
ElSLib::SphereParameters(gp_Ax3(gp::XOY()),1,Center, U, V);
myU1 = U-M_PI;
myU2 = U+M_PI;
myU1 = Min(UU1,myU1);
myU2 = Max(UU2,myU2);
myU2 = myU1 + 2.*M_PI;
}
// box+sphere <<
@ -751,58 +766,6 @@ static void Function_SetUVBounds(Standard_Real& myU1,
}
}
//
//=======================================================================
//function : Parameters
//purpose :
//=======================================================================
void Parameters(const Handle(Adaptor3d_HCurve)& myCurve,
const Handle(Adaptor3d_HSurface)& mySurface,
const gp_Pnt& aP1,
const Standard_Integer iFirst,
const Standard_Real aTolU,
Standard_Real& aU,
Standard_Real& aV)
{
Standard_Real aTwoPI, aU1, aV1, aU2, aV2, aRSp, aTol3D;
Standard_Real aTF, aTL, aT2, dT;
GeomAbs_SurfaceType aSType;
GeomAbs_CurveType aCType;
gp_Pnt aP2;
//
aTwoPI=2.*M_PI;
//
aSType=mySurface->GetType();
aCType=myCurve->GetType();
//
if (aSType==GeomAbs_Sphere && aCType==GeomAbs_Circle) {
gp_Sphere aSp=mySurface->Sphere();
//
aRSp=aSp.Radius();
aTol3D=aRSp*aTolU;
//
aTF = myCurve->FirstParameter();
aTL = myCurve->LastParameter ();
dT=myCurve->Resolution(aTol3D);
//
ElSLib::Parameters(aSp, aP1, aU1, aV1);
if (fabs(aU)<aTolU || fabs(aU-aTwoPI)<aTolU){
aT2=aTF+dT;
if (!iFirst) {
aT2=aTL-dT;
}
//
aP2=myCurve->Value(aT2);
ElSLib::Parameters(aSp, aP2, aU2, aV2);
//
aU1=0.;
if (aU2>M_PI) {
aU1=aTwoPI;
}
}
aU=aU1;
aV=aV1;
}
}
//
//=======================================================================
//classn : ProjLib_Function

76
tests/bugs/modalg_5/bug24359 Executable file
View File

@ -0,0 +1,76 @@
puts "================"
puts "OCC24359"
puts "================"
puts ""
#######################################################
# Crash on BRepAlgoAPI_Fuse
#######################################################
psphere s01 2; ttranslate s01 1 1 1
psphere s02 2; ttranslate s02 1 1 2
psphere s03 2; ttranslate s03 1 1 3
psphere s04 2; ttranslate s04 1 2 1
psphere s05 2; ttranslate s05 1 2 2
psphere s06 2; ttranslate s06 1 2 3
psphere s07 2; ttranslate s07 1 3 1
psphere s08 2; ttranslate s08 1 3 2
psphere s09 2; ttranslate s09 1 3 3
psphere s10 2; ttranslate s10 2 1 1
psphere s11 2; ttranslate s11 2 1 2
psphere s12 2; ttranslate s12 2 1 3
psphere s13 2; ttranslate s13 2 2 1
psphere s14 2; ttranslate s14 2 2 2
psphere s15 2; ttranslate s15 2 2 3
psphere s16 2; ttranslate s16 2 3 1
psphere s17 2; ttranslate s17 2 3 2
psphere s18 2; ttranslate s18 2 3 3
psphere s19 2; ttranslate s19 3 1 1
psphere s20 2; ttranslate s20 3 1 2
psphere s21 2; ttranslate s21 3 1 3
psphere s22 2; ttranslate s22 3 2 1
psphere s23 2; ttranslate s23 3 2 2
psphere s24 2; ttranslate s24 3 2 3
psphere s25 2; ttranslate s25 3 3 1
psphere s26 2; ttranslate s26 3 3 2
psphere s27 2; ttranslate s27 3 3 3
bop s01 s02; bopfuse s
bop s s03; bopfuse s
bop s s04; bopfuse s
bop s s05; bopfuse s
bop s s06; bopfuse s
bop s s07; bopfuse s
bop s s08; bopfuse s
bop s s09; bopfuse s
bop s s10; bopfuse s
bop s s11; bopfuse s
bop s s12; bopfuse s
bop s s13; bopfuse s
bop s s14; bopfuse s
bop s s15; bopfuse s
bop s s16; bopfuse s
bop s s17; bopfuse s
bop s s18; bopfuse s
bop s s19; bopfuse s
bop s s20; bopfuse s
bop s s21; bopfuse s
bop s s22; bopfuse s
bop s s23; bopfuse s
bop s s24; bopfuse s
bop s s25; bopfuse s
bop s s26; bopfuse s
bop s s27; bopfuse result
set nb_v_good 60
set nb_e_good 105
set nb_w_good 29
set nb_f_good 29
set nb_sh_good 1
set nb_sol_good 1
set nb_compsol_good 0
set nb_compound_good 1
set nb_shape_good 226
set square 150.187
set 2dviewer 1