1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00
occt/tests/bugs/modalg_7/bug29900
emv d3578357e3 0029711: General Fuse operation produces invalid result
The following improvements have been introduced in Boolean Operations algorithm s:
1. UBTree is replaced with EBTree in Boolean operations to be able to add/remove elements into the tree of bounding boxes.
2. Repeated (nested) intersection of sub-shapes is performed with argument vertices whose tolerances increased during the operation.
3. The algorithms of Edge/Edge and Edge/Face intersection have been improved for the cases when the intersection point is located close to the edge boundaries .
4. New procedure has been implemented to ensure forced creation of Edge/Face common blocks in cases when the edge is really close to the face.
5. Post-processing of Face/Face intersection results has been improved.
6. Extension of the planar faces for Plane/Plane intersection is avoided.
7. Builder Face now better classifies potentially internal edges relatively to new faces with filtering by bounding boxes.

Side effect changes:
1. IntTools_ShrunkRange now keeps the length of the valid range of the edge.
2. The method BOPDS_DS::UpdateEdgeTolerance() has been removed as unused (replaced by the BOPAlgo_PaveFiller::UpdateEdgeTolerance()).

Test case for the issue 0029900.
Test case for the issue 0029711.
Adjustments of the existing test cases.

Avoid using uninitialized variables.
2018-07-27 16:19:15 +03:00

38 lines
754 B
Plaintext

puts "TODO CR29596 All: Intersection of pair of shapes has failed"
puts "========"
puts "OCC29900: Invalid result of FUSE operation"
puts "========"
puts ""
cpulimit 3000
brestore [locate_data_file bug29900_rotated.brep] s1
brestore [locate_data_file bug29900_sewedShape.brep] s2
bdrawwarnshapes 1
bfuzzyvalue 2.1e-5
brunparallel 1
bclearobjects
bcleartools
baddobjects s1
baddtools s2
bfillds
bbop result 1
checkshape result
checknbshapes result -wire 39 -face 39 -shell 1 -solid 1
checkprops result -s 0.0199382 -v 3.24449e-005
if {![regexp "Meshing statuses: NoError" [incmesh result 0.00001]]} {
puts "Error: Meshing not done"
}
boptions -default
smallview +Y+Z
don result
fit
checkview -screenshot -2d -path ${imagedir}/${test_image}.png