1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

0027664: Incomplete intersection curve from the attached shapes

Computation of correct offset values in order to make correspondence (with adjusting to periods) between Domain of WLine and surface domain.

Creation of test cases for this issue.

Small correction in the test case.
This commit is contained in:
nbv 2016-07-06 16:42:19 +03:00 committed by bugmaster
parent a7cc4fdd0d
commit f7991731de
3 changed files with 159 additions and 33 deletions

View File

@ -47,6 +47,8 @@
#include <TColgp_SequenceOfPnt.hxx>
#include <TColgp_SequenceOfPnt2d.hxx>
#include <ElCLib.hxx>
#define myInfinite 1.e15 // the same as was in Adaptor3d_TopolTool
static void Recadre(GeomAbs_SurfaceType typeS1,
@ -589,29 +591,40 @@ void IntPatch_RstInt::PutVertexOnLine (const Handle(IntPatch_Line)& L,
}
Bnd_Box2d BPLin = PLin.Bounding();
if(SurfaceIsPeriodic) {
Standard_Real xmin,ymin,xmax,ymax,g;
BPLin.Get(xmin,ymin,xmax,ymax);
g = BPLin.GetGap();
BPLin.SetVoid();
BPLin.Update(xmin-M_PI-M_PI,ymin,
xmax+M_PI+M_PI,ymax);
BPLin.SetGap(g);
}
if(SurfaceIsBiPeriodic) {
Standard_Real xmin,ymin,xmax,ymax,g;
BPLin.Get(xmin,ymin,xmax,ymax);
g = BPLin.GetGap();
BPLin.SetVoid();
BPLin.Update(xmin,ymin-M_PI-M_PI,
xmax,ymax+M_PI+M_PI);
BPLin.SetGap(g);
}
Standard_Real OffsetV = 0.0;
Standard_Real OffsetU = 0.0;
switch(arc->GetType())
{
case GeomAbs_Line: NbEchant=10; break;
case GeomAbs_Line:
{
NbEchant=10;
Standard_Real aXmin, aYmin, aXmax, aYmax;
BPLin.Get(aXmin, aYmin, aXmax, aYmax);
gp_Lin2d aLin = arc->Curve2d().Line();
const gp_Pnt2d& aLoc = aLin.Location();
const gp_Dir2d& aDir = aLin.Direction();
//Here, we consider rectangular axis-aligned domain only.
const Standard_Boolean isAlongU = (Abs(aDir.X()) > Abs(aDir.Y()));
if(SurfaceIsPeriodic && !isAlongU)
{
//Shift along U-direction
const Standard_Real aNewLocation =
ElCLib::InPeriod(aLoc.X(), aXmin, aXmin + M_PI + M_PI);
OffsetU = aNewLocation - aLoc.X();
}
else if(SurfaceIsBiPeriodic && isAlongU)
{
//Shift along V-direction
const Standard_Real aNewLocation =
ElCLib::InPeriod(aLoc.Y(), aYmin, aYmin + M_PI + M_PI);
OffsetV = aNewLocation - aLoc.Y();
}
}
break;
case GeomAbs_BezierCurve:
{
NbEchant = (3 + arc->NbPoles());
@ -634,26 +647,45 @@ void IntPatch_RstInt::PutVertexOnLine (const Handle(IntPatch_Line)& L,
}
}
if(SurfaceIsPeriodic) {
Standard_Real xmin,ymin,xmax,ymax,g;
BPLin.Get(xmin,ymin,xmax,ymax);
g = BPLin.GetGap();
BPLin.SetVoid();
BPLin.Update(xmin-M_PI-M_PI,ymin,
xmax+M_PI+M_PI,ymax);
BPLin.SetGap(g);
}
if(SurfaceIsBiPeriodic) {
Standard_Real xmin,ymin,xmax,ymax,g;
BPLin.Get(xmin,ymin,xmax,ymax);
g = BPLin.GetGap();
BPLin.SetVoid();
BPLin.Update(xmin,ymin-M_PI-M_PI,
xmax,ymax+M_PI+M_PI);
BPLin.SetGap(g);
}
IntPatch_PolyArc Brise(arc,NbEchant,PFirst,PLast,BPLin);
Standard_Integer IndiceOffsetBiPeriodic = 0;
Standard_Integer IndiceOffsetPeriodic = 0;
Standard_Real OffsetV = 0.0;
Standard_Real OffsetU = 0.0;
Standard_Integer IndiceOffsetPeriodic = 0;
const Standard_Real aRefOU = OffsetU,
aRefOV = OffsetV;
do {
if(IndiceOffsetBiPeriodic == 1)
OffsetV = -M_PI-M_PI;
OffsetV = aRefOV - M_PI - M_PI;
else if(IndiceOffsetBiPeriodic == 2)
OffsetV = M_PI+M_PI;
OffsetV = aRefOV + M_PI + M_PI;
do {
if(IndiceOffsetPeriodic == 1)
OffsetU = -M_PI-M_PI;
else if(IndiceOffsetPeriodic == 2)
OffsetU = M_PI+M_PI;
Brise.SetOffset(OffsetU,OffsetV);
if(IndiceOffsetPeriodic == 1)
OffsetU = aRefOU - M_PI - M_PI;
else if(IndiceOffsetPeriodic == 2)
OffsetU = aRefOU + M_PI + M_PI;
Brise.SetOffset(OffsetU,OffsetV);
static int debug_polygon2d =0;
if(debug_polygon2d) {

View File

@ -0,0 +1,56 @@
puts "========"
puts "OCC27664"
puts "========"
puts ""
#################################################
# Incomplete intersection curve from the attached shapes
#################################################
set ExpTol 1.0e-7
set GoodNbCurv 3
set GoodLength 0.6288896355727489
restore [locate_data_file bug27664_pl0.brep] pl0
restore [locate_data_file bug27664_nsh_8.brep] nsh_8
explode nsh_8 f
explode pl0 f
set log [bopcurves pl0_1 nsh_8_4 -2d]
regexp {Tolerance Reached=+([-0-9.+eE]+)\n+([-0-9.+eE]+)} ${log} full Toler NbCurv
if {${NbCurv} != ${GoodNbCurv}} {
puts "Error: Number of curves is bad!"
}
checkreal TolReached $Toler $ExpTol 0.0 0.1
set clen 0.0
for {set ic 1} { $ic <= ${NbCurv} } { incr ic} {
set le [length c_$ic]
regexp "The length c_$ic is +(\[-0-9.+eE\]+)" ${le} full ll
puts "ll = $ll"
set clen [expr $clen+$ll]
}
puts "Summary length = $clen"
checkreal Length $clen $GoodLength 0.0 1.0e-5
smallview
don c_*
fit
display pl0_1 nsh_8_4
checkview -screenshot -2d -path ${imagedir}/${test_image}_1.png
top
don c_*
fit
display pl0_1 nsh_8_4
checkview -screenshot -2d -path ${imagedir}/${test_image}_2.png

View File

@ -0,0 +1,38 @@
puts "========"
puts "OCC27664"
puts "========"
puts ""
#################################################
# Incomplete intersection curve from the attached shapes
#################################################
restore [locate_data_file bug27664_pl0.brep] pl0
restore [locate_data_file bug27664_nsh_8.brep] nsh_8
bclearobjects
bcleartools
baddobjects pl0
baddtools nsh_8
bfillds
# section
bbop rs 4
if { [string compare -nocase [checksection rs] " nb alone Vertices : 0\n\n"] } {
puts "ERROR: the section is not closed"
} else {
puts "The section is OK"
}
# cut
bbop result 2
smallview
donly result
fit
checkview -screenshot -2d -path ${imagedir}/${test_image}.png
checkprops result -s 33.8629