mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
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.
51 lines
1.4 KiB
Plaintext
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
|