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

0027704: Numeric inaccuracy due to huge extension of the offset faces

The max extension value of the faces in offset operation has been decreased
to 1.e+7 value to avoid the lack of precision in the calculations.

Update of test cases according to the new behavior
This commit is contained in:
emv 2016-07-22 11:53:07 +03:00 committed by bugmaster
parent 4c6b4bc75a
commit 66cce03ae5
8 changed files with 36 additions and 7 deletions
src/BRepOffset
tests
bugs/modalg_6
offset
faces_type_i
shape_type_i

@ -3211,7 +3211,16 @@ Standard_Boolean BRepOffset_Tool::EnLargeFace
Standard_Boolean isVV1degen = Standard_False, isVV2degen = Standard_False;
Standard_Real US1,VS1,US2,VS2;
Standard_Real UF1,VF1,UF2,VF2;
Standard_Real infini = 1.e8;
// The maximal value to enlarge surfaces is decreased to 1.e+7.
// It is justified by the floating point format. As we can have only 15
// valuable decimal numbers, then during intersection of surfaces with
// bounds of 1.e+8 the possible inaccuracy might appear already in seventh
// decimal place which will be more than Precision::Confusion value -
// 1.e-7, default tolerance value for the section curves.
// By decreasing the max enlarge value to 1.e+7 the inaccuracy will be
// shifted to eighth decimal place, i.e. the inaccuracy will be
// decreased to values less than 1.e-7.
Standard_Real infini = 1.e7;//1.e8;
Standard_Boolean SurfaceChange = Standard_False;
if (S->IsUPeriodic() || S->IsVPeriodic()) {

@ -0,0 +1,22 @@
puts "========"
puts "OCC27704"
puts "========"
puts ""
#################################################
# Numeric inaccuracy due to huge extension of the offset faces
#################################################
# Input shell contains two planar faces with linear edges.
# The result of offset operation is also expected to contain
# only simple geometries (planes, lines, 2d lines).
# Due to inaccuracy SameParameter can convert 2d lines
# into 2d BSpline curves.
restore [locate_data_file bug27704.brep] s
offsetparameter 1e-7 p i
offsetload s 1
offsetperform result
if {[regexp {BSpline} [dump result]]} {
puts "Error: BSpline is created"
}

@ -1,5 +1,4 @@
puts "TODO OCC25406 ALL: Error : The volume of result shape is"
puts "TODO OCC25406 Windows: Faulty shapes in variables faulty_1 to"
puts "TODO OCC25406 Linux: Error: bsection of the result and s is not equal to zero"
ellipse w1 0 0 0 15 10

@ -3,4 +3,4 @@ trotate s 0 0 0 0 0 1 90
OFFSETSHAPE 1 {} $calcul $type
checkprops result -v 3.57243e+022
checkprops result -v 3.57246e+019

@ -3,4 +3,4 @@ trotate s 0 0 0 0 0 1 90
OFFSETSHAPE 1 {} $calcul $type
checkprops result -v 2.96865e+016
checkprops result -v 2.96865e+014

@ -3,4 +3,4 @@ trotate s 0 0 0 0 0 1 90
OFFSETSHAPE 1 {} $calcul $type
checkprops result -v 1.77778e+16
checkprops result -v 1.77778e+014

@ -4,5 +4,5 @@ psphere s 15 270
OFFSETSHAPE 1 {} $calcul $type
checkprops result -v 1.77778e+16
checkprops result -v 1.77778e+014

@ -1,5 +1,4 @@
puts "TODO OCC23068 ALL: Error : The volume of result shape is"
puts "TODO OCC23068 Windows: Faulty shapes in variables faulty_1 to"
puts "TODO OCC23068 Linux: Error: bsection of the result and s is not equal to zero"
ellipse w1 0 0 0 15 10