mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0026717: Error in IntPatch_PrmPrmIntersection: change of local resolution leads to break of walking line
Test case for issue CR26717 Correction of test cases for issue CR26717 Test case for issue CR26717
This commit is contained in:
parent
d0fcf95a09
commit
6fa29cbf06
@ -1018,7 +1018,7 @@ void IntWalk_PWalking::Perform(const TColStd_Array1OfReal& ParDep,
|
||||
LevelOfEmptyInmyIntersectionOn2S=0;
|
||||
if(LevelOfIterWithoutAppend < 10)
|
||||
{
|
||||
Status = TestDeflection();
|
||||
Status = TestDeflection(ChoixIso);
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -1758,7 +1758,7 @@ Standard_Boolean IntWalk_PWalking::ExtendLineInCommonZone(const IntImp_ConstIsop
|
||||
return bOutOfTangentZone;
|
||||
}
|
||||
|
||||
Status = TestDeflection();
|
||||
Status = TestDeflection(ChoixIso);
|
||||
|
||||
if(Status == IntWalk_OK) {
|
||||
|
||||
@ -2782,7 +2782,7 @@ namespace {
|
||||
static const Standard_Real d = 7.0;
|
||||
}
|
||||
|
||||
IntWalk_StatusDeflection IntWalk_PWalking::TestDeflection()
|
||||
IntWalk_StatusDeflection IntWalk_PWalking::TestDeflection(const IntImp_ConstIsoparametric choixIso)
|
||||
|
||||
// test if vector is observed by calculating an increase of vector
|
||||
// or the previous point and its tangent, the new calculated point and its
|
||||
@ -2805,6 +2805,9 @@ IntWalk_StatusDeflection IntWalk_PWalking::TestDeflection()
|
||||
IntWalk_StatusDeflection Status = IntWalk_OK;
|
||||
Standard_Real FlecheCourante ,Ratio;
|
||||
|
||||
// Caro1 and Caro2
|
||||
const Handle(Adaptor3d_HSurface)& Caro1 = myIntersectionOn2S.Function().AuxillarSurface1();
|
||||
const Handle(Adaptor3d_HSurface)& Caro2 = myIntersectionOn2S.Function().AuxillarSurface2();
|
||||
|
||||
const IntSurf_PntOn2S& CurrentPoint = myIntersectionOn2S.Point();
|
||||
//==================================================================================
|
||||
@ -2858,6 +2861,56 @@ IntWalk_StatusDeflection IntWalk_PWalking::TestDeflection()
|
||||
pasuv[1] = Max(5.*ResoV1,Min(1.5*pasuv[1],pasInit[1]));
|
||||
pasuv[2] = Max(5.*ResoU2,Min(1.5*pasuv[2],pasInit[2]));
|
||||
pasuv[3] = Max(5.*ResoV2,Min(1.5*pasuv[3],pasInit[3]));
|
||||
//Compute local resolution: for OCC26717
|
||||
if (Abs(pasuv[choixIso] - pasInit[choixIso]) <= Precision::Confusion())
|
||||
{
|
||||
Standard_Real CurU, CurV;
|
||||
if (choixIso == IntImp_UIsoparametricOnCaro1 ||
|
||||
choixIso == IntImp_VIsoparametricOnCaro1)
|
||||
previousPoint.ParametersOnS1(CurU, CurV);
|
||||
else
|
||||
previousPoint.ParametersOnS2(CurU, CurV);
|
||||
gp_Pnt CurPnt = (choixIso == IntImp_UIsoparametricOnCaro1 ||
|
||||
choixIso == IntImp_VIsoparametricOnCaro1)?
|
||||
Adaptor3d_HSurfaceTool::Value(Caro1, CurU, CurV) :
|
||||
Adaptor3d_HSurfaceTool::Value(Caro2, CurU, CurV);
|
||||
gp_Pnt OffsetPnt;
|
||||
switch(choixIso)
|
||||
{
|
||||
case IntImp_UIsoparametricOnCaro1:
|
||||
OffsetPnt =
|
||||
Adaptor3d_HSurfaceTool::Value(Caro1,
|
||||
CurU + sensCheminement*pasuv[0],
|
||||
CurV);
|
||||
break;
|
||||
case IntImp_VIsoparametricOnCaro1:
|
||||
OffsetPnt =
|
||||
Adaptor3d_HSurfaceTool::Value(Caro1,
|
||||
CurU,
|
||||
CurV + sensCheminement*pasuv[1]);
|
||||
break;
|
||||
case IntImp_UIsoparametricOnCaro2:
|
||||
OffsetPnt =
|
||||
Adaptor3d_HSurfaceTool::Value(Caro2,
|
||||
CurU + sensCheminement*pasuv[2],
|
||||
CurV);
|
||||
break;
|
||||
case IntImp_VIsoparametricOnCaro2:
|
||||
OffsetPnt =
|
||||
Adaptor3d_HSurfaceTool::Value(Caro2,
|
||||
CurU,
|
||||
CurV + sensCheminement*pasuv[3]);
|
||||
break;
|
||||
default:break;
|
||||
}
|
||||
Standard_Real RefDist = CurPnt.Distance(OffsetPnt);
|
||||
Standard_Real LocalResol = 0.;
|
||||
if (RefDist > gp::Resolution())
|
||||
LocalResol = pasuv[choixIso] * tolconf / RefDist;
|
||||
if (pasuv[choixIso] <= LocalResol)
|
||||
pasuv[choixIso] = pasInit[choixIso] = 2*LocalResol;
|
||||
}
|
||||
////////////////////////////////////////
|
||||
Status = IntWalk_PointConfondu;
|
||||
}
|
||||
|
||||
|
@ -126,7 +126,7 @@ public:
|
||||
|
||||
const gp_Dir& TangentAtLine (Standard_Integer& Index) const;
|
||||
|
||||
Standard_EXPORT IntWalk_StatusDeflection TestDeflection();
|
||||
Standard_EXPORT IntWalk_StatusDeflection TestDeflection (const IntImp_ConstIsoparametric ChoixIso) ;
|
||||
|
||||
Standard_EXPORT Standard_Boolean TestArret (const Standard_Boolean DejaReparti, TColStd_Array1OfReal& Param, IntImp_ConstIsoparametric& ChoixIso);
|
||||
|
||||
|
@ -7,4 +7,4 @@ restore [locate_data_file buc60462b.brep] b
|
||||
|
||||
bsection result a b
|
||||
|
||||
set length 268.348
|
||||
set length 282.421
|
@ -1,5 +1,5 @@
|
||||
puts "TODO OCC26018 ALL: Error : The area of the resulting shape is"
|
||||
puts "TODO OCC26018 Linux: Faulty shapes in variables faulty_1 to faulty_"
|
||||
#puts "TODO OCC26018 Linux: Faulty shapes in variables faulty_1 to faulty_"
|
||||
source [locate_data_file 20000_et3_401-ta6037.prt.2.gdml.tcl]
|
||||
|
||||
## image is differ from application
|
||||
|
@ -1,5 +1,4 @@
|
||||
puts "TODO OCC12345 ALL: Faulty : Section is incorrect"
|
||||
puts "TODO OCC12345 ALL: Error : The length of result shape is"
|
||||
#puts "TODO OCC12345 ALL: Error : The length of result shape is"
|
||||
|
||||
puts "============="
|
||||
puts "BUC60462"
|
||||
@ -19,5 +18,5 @@ if { $cs != 0 } {
|
||||
puts "Faulty : Section is incorrect"
|
||||
}
|
||||
|
||||
set length 0
|
||||
set length 282.421
|
||||
set 2dviewer 0
|
||||
|
@ -1,3 +1,5 @@
|
||||
puts "TODO OCC26717 ALL: Faulty shapes in variables faulty_1 to faulty_"
|
||||
|
||||
puts "=========="
|
||||
puts "BUC60462"
|
||||
puts "=========="
|
||||
@ -12,5 +14,5 @@ puts "Fuse end"
|
||||
|
||||
checkshape result r
|
||||
|
||||
set square 94371.7
|
||||
set square 93255.6
|
||||
set 2dviewer 0
|
||||
|
@ -1,6 +1,3 @@
|
||||
puts "TODO OCC12345 ALL: Faulty : Result is BAD. Distance is more than MaxTolerance"
|
||||
puts "TODO OCC12345 ALL: Error : The length of result shape is"
|
||||
|
||||
puts "=========="
|
||||
puts "PRO18892"
|
||||
puts "=========="
|
||||
@ -32,4 +29,4 @@ if { [expr $d > $MaxEdgeTolerance] || [expr $d > $MaxVertexTolerance] } {
|
||||
puts "Faulty : Result is BAD. Distance is more than MaxTolerance"
|
||||
}
|
||||
|
||||
set length 0
|
||||
set length 6.46299
|
||||
|
46
tests/bugs/modalg_6/bug26717
Executable file
46
tests/bugs/modalg_6/bug26717
Executable file
@ -0,0 +1,46 @@
|
||||
puts "============"
|
||||
puts "OCC26717"
|
||||
puts "============"
|
||||
puts ""
|
||||
######################################################
|
||||
# Error in IntPatch_PrmPrmIntersection: change of local resolution leads to break of walking line
|
||||
######################################################
|
||||
|
||||
smallview
|
||||
|
||||
set expected_MaxTolerance 2.14e-05
|
||||
set tol_abs_MaxTolerance 1.e-06
|
||||
set tol_rel_MaxTolerance 1.e-06
|
||||
|
||||
set FileName1 bug26717_xrf1_eval_fuselage.brep
|
||||
restore [locate_data_file ${FileName1}] a
|
||||
|
||||
set FileName2 bug26717_xrf1_eval5_wing.brep
|
||||
restore [locate_data_file ${FileName2}] b
|
||||
|
||||
bfuse r a b
|
||||
|
||||
set aList [explode r]
|
||||
|
||||
# check 1
|
||||
if { [llength ${aList}] == 1} {
|
||||
puts "OK: Good explode of result"
|
||||
} else {
|
||||
puts "Error: Bad explode of result"
|
||||
}
|
||||
|
||||
# check2
|
||||
checknbshapes r -solid 1
|
||||
|
||||
# check3
|
||||
checkshape r
|
||||
|
||||
# check4
|
||||
regexp {Tolerance +MAX=([-0-9.+eE]+)} [tolerance r] full MaxTolerance
|
||||
checkreal "MaxTolerance" ${MaxTolerance} ${expected_MaxTolerance} ${tol_abs_MaxTolerance} ${tol_rel_MaxTolerance}
|
||||
|
||||
clear
|
||||
donly r
|
||||
fit
|
||||
|
||||
xwd ${imagedir}/${test_image}.png
|
Loading…
x
Reference in New Issue
Block a user