1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00
occt/tests/bugs/modalg_7/bug30595_3
emv 1bb67d3844 0030595: Oriented Bounding Box seems not optimal for some shapes
Add possibility of construction of the Optimal Oriented Bounding Box from set of points (the case of shape with triangulation).

The interface of the BRepBndLib::AddOBB method is not changed, but the option <theIsOptimal> now controls also the construction of the OBB from Set of points.
The slightly modified DiTo algorithm will be used, checking all possible axes created by the extreme points.
The performance of the construction of the Optimal OBB is lower but the quality is usually much higher (can't be worse by definition).

Test cases for the issue.
2019-06-17 09:26:54 +03:00

51 lines
1.4 KiB
Plaintext

puts "==============================================================="
puts "0030595: Oriented Bounding Box seems not optimal for some shapes"
puts "==============================================================="
puts ""
# test is the copy of the test case bug29311_2
# but computing the optimal OBB comparing to tight AABB
# with 1.e-6% precision
set NbIters 101
set step [expr 360.0/($NbIters-1) ]
restore [locate_data_file bug29237_no_overlap.rhs.brep] a
# Create AABB for a and put it into "r1" variable
# Draw[]> bounding a -shape r1
# The volume of one AABB is
# Draw[]> vprops r1 1.0e-12 -full
# 32736000.184203226
set Vexp 32736000.184203226
set VMax 0
set MaxIteration 0
for {set i 1} { $i <= $NbIters} { incr i } {
bounding a -obb -shape rr$i -optimal
regexp {Mass +: +([-0-9.+eE]+)} [vprops rr$i 1.0e-12 -full] full Vreal
if { $Vreal > $VMax } {
set VMax $Vreal
set MaxIteration $i
copy a amax
}
if { $i != $NbIters } { trotate a 283 162 317 2 7 9 $step }
}
set aDeltaMax [ expr 100.0*abs($VMax/$Vexp - 1.0) ]
puts "Delta of computation not greater than $aDeltaMax %. Maximal delta is achieved in $MaxIteration iteration. See \"amax\" shape."
if { $aDeltaMax > 1.e-6 } {
puts "Error: The obtained OBB(s) is not precise."
}
smallview
donly amax rr${MaxIteration}
fit
checkview -screenshot -2d -path ${imagedir}/${test_image}.png