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

0025519: BRepMesh can break mesh regularity for BSpline surfaces

Compute parameters to produce regular grid and add new internal points according to calculated values.
Use intervals as an additional parameters to determine regular grid for BSpline surfaces.

Test case for issue CR25519

Correction of test case for issue CR25519

Correction of test cases for issue CR25519
This commit is contained in:
oan 2014-12-11 16:19:31 +03:00 committed by bugmaster
parent b49eaa701f
commit 13cd069dbc
3 changed files with 107 additions and 16 deletions

View File

@ -186,9 +186,10 @@ void BRepMesh_FastDiscretFace::initDataStructure()
// Check the necessity to fill the map of parameters
const Handle(BRepAdaptor_HSurface)& gFace = myAttribute->Surface();
GeomAbs_SurfaceType thetype = gFace->GetType();
const Standard_Boolean useUVParam = (thetype == GeomAbs_Torus ||
thetype == GeomAbs_BezierSurface ||
thetype == GeomAbs_BSplineSurface);
const Standard_Boolean isBSpline = (thetype == GeomAbs_BezierSurface ||
thetype == GeomAbs_BSplineSurface);
const Standard_Boolean useUVParam = (thetype == GeomAbs_Torus ||isBSpline);
myUParam.Clear();
myVParam.Clear();
@ -217,6 +218,40 @@ void BRepMesh_FastDiscretFace::initDataStructure()
}
aBoundaryNodes.Nullify();
if (isBSpline)
{
const Standard_Real aRange[2][2] = {
{myAttribute->GetUMin(), myAttribute->GetUMax()},
{myAttribute->GetVMin(), myAttribute->GetVMax()}
};
const GeomAbs_Shape aContinuity = GeomAbs_CN;
for (Standard_Integer i = 0; i < 2; ++i)
{
const Standard_Boolean isU = (i == 0);
const Standard_Integer aIntervalsNb = isU ?
gFace->NbUIntervals(aContinuity) :
gFace->NbVIntervals(aContinuity);
BRepMesh::IMapOfReal& aParams = isU ? myUParam : myVParam;
if (aIntervalsNb < aParams.Size())
continue;
TColStd_Array1OfReal aIntervals(1, aIntervalsNb + 1);
if (isU)
gFace->UIntervals(aIntervals, aContinuity);
else
gFace->VIntervals(aIntervals, aContinuity);
for (Standard_Integer j = 1; j <= aIntervals.Upper(); ++j)
{
const Standard_Real aParam = aIntervals(j);
if (aParam > aRange[i][0] && aParam < aRange[i][1])
aParams.Add(aParam);
}
}
}
////////////////////////////////////////////////////////////
//add internal vertices after self-intersection check
if ( myInternalVerticesMode )
@ -914,25 +949,30 @@ void BRepMesh_FastDiscretFace::insertInternalVerticesBSpline(
{
aPrevParam2 = aParam2;
aPrevPnt2 = aPnt2;
if (!isU && j < aParams2.Length())
{
// Update point parameter.
aStPnt1.SetX(aPrevParam2);
// Classify intersection point
if (aClassifier->Perform(aStPnt1) == TopAbs_IN)
{
insertVertex(aPrevPnt2, aStPnt1.Coord(), theNewVertices);
}
}
++j;
}
}
}
}
}
// insert nodes of the regular grid
for (Standard_Integer i = 1; i <= aParams[0].Length(); ++i)
{
const Standard_Real aParam1 = aParams[0].Value(i);
for (Standard_Integer j = 1; j <= aParams[1].Length(); ++j)
{
gp_Pnt2d aPnt2d(aParam1, aParams[1].Value(j));
// Classify intersection point
if (aClassifier->Perform(aPnt2d) == TopAbs_IN)
{
gp_Pnt aPnt;
gFace->D0(aPnt2d.X(), aPnt2d.Y(), aPnt);
insertVertex(aPnt, aPnt2d.Coord(), theNewVertices);
}
}
}
}
//=======================================================================

45
tests/bugs/mesh/bug25519 Executable file
View File

@ -0,0 +1,45 @@
puts "================"
puts "CR25519"
puts "================"
puts ""
###############################################
## BRepMesh can break mesh regularity for BSpline surfaces
###############################################
restore [locate_data_file bug25519_testtriangulation.brep] a
tclean a
incmesh a 0.01
front
fit
isos a 0
triangles a
set trinfo_s [trinfo a]
regexp {([0-9]+) triangles} ${trinfo_s} str nbtri_s
regexp {([0-9]+) nodes} ${trinfo_s} str nbnod_s
regexp {deflection ([0-9.+e-]+)} ${trinfo_s} str defl_s
set good_nbtri 2721
set good_nbnod 1405
set good_defl 0.082010129769776202
set good_percent 5
set nbtri_percent [expr abs (${good_nbtri} - ${nbtri_s}) / double (${nbtri_s}) * 100 ]
set nbnod_percent [expr abs (${good_nbnod} - ${nbnod_s}) / double (${nbnod_s}) * 100 ]
set defl_percent [expr abs (${good_defl} - ${defl_s}) / ${defl_s} * 100 ]
if { ${nbtri_percent} > ${good_percent} } {
puts "Error: triangle number is bad, it has changed to ${nbtri_percent} %"
}
if { ${nbnod_percent} > ${good_percent} } {
puts "Error: node number is bad, it has changed to ${nbnod_percent} %"
}
if { ${defl_percent} > ${good_percent} } {
puts "Error: deflection is bad, it has changed to ${defl_percent} %"
}
set only_screen_axo 1

View File

@ -1 +1,7 @@
set TheFileName OCC22247.brep
if { [string compare $command "incmesh"] == 0 ||
[string compare $command "mesh"] == 0 ||
[string compare $command "incmesh_parallel"] == 0 } {
set bug_area "OCC25519"
set rel_tol 1.3654
}