1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00
azv 94f71cad33 0024682: Move out B-spline cache from curves and surfaces to dedicated classes BSplCLib_Cache and BSplSLib_Cache
1. B-spline cache was moved into separated classes: BSplCLib_Cache for 2D and 3D curves and BSplSLib_Cache for surfaces.

2. The cache is used now in corresponding adaptor classes (Geom2dAdaptor_Curve, GeomAdaptor_Curve and GeomAdaptor_Surface) when the curve or surface is a B-spline.

3. Algorithms were changed to use adaptors for B-spline calculations instead of curves or surfaces.

4. Precised calculation of derivatives of surface of revolution is implemented for the points of surface placed on the axis of revolution (Geom_SurfaceOfRevolution.cxx)

5. Small modifications are made to adjust algorithms to new behavior of B-spline calculation.

6. Test cases were modified according to the modern behavior.

7. Changes in BOPAlgo_WireSplitter, BOPTools_AlgoTools, BRepLib_CheckCurveOnSurface and ShapeAnalysis_Wire to use adaptors instead of geometric entities

8. Allow Geom2dAdaptor and GeomAdaptor in case of offset curve to use corresponding adaptor for basis curve

Modification of test-cases according to the new behavior.
2015-05-28 13:38:22 +03:00

47 lines
867 B
Plaintext
Executable File

puts "========="
puts " OCC498 "
puts "========="
puts ""
######################################
## Wrong 3d point from offset surface by parameters
######################################
restore [locate_data_file OCC498.draw] su
set u1 4.71238898038469
set u2 7.85398163397449
svalue su 0 $u1 x1 y1 z1
vertex v1 x1 y1 z1
svalue su 0 $u2 x2 y2 z2
vertex v2 x2 y2 z2
set newU1 [expr $u1 - 1e-11]
set newU2 [expr $u2 + 1e-11]
svalue su 0 $newU1 x1 y1 z1
vertex vv1 x1 y1 z1
svalue su 0 $newU2 x2 y2 z2
vertex vv2 x2 y2 z2
distmini d v1 vv1
regexp {([-0-9.+eE]+)} [dump d_val] full err1
distmini d v2 vv2
regexp {([-0-9.+eE]+)} [dump d_val] full err2
if { $err1 > 1.e-7 || $err2 > 1.e-7} {
puts "Faulty OCC498: Wrong 3d point from offset surface by parameters "
} else {
puts "OCC498 OK: Correct 3d point from offset surface by parameters"
}