mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
1. The class Bnd_OBB has been created to describe the Oriented Bounding Box. 2. Several key methods have been implemented: Bnd_OBB::IsOut(...), Bnd_OBB::Add(...) and Bnd_OBB::Enlarge(...). 3. Interface of Bnd_Box class has changed. New methods have been created. See Bnd_Box.hxx for detailed information. 4. BRepBndLib and Draw_Box classes have been amended in order to provide correct work with Bnd_OBB class. 5. Interface of "bounding" DRAW-command has been changed. Please see help for detailed information. 6. New DRAW-command "isbbinterf" has been created. Please see help for detailed information. 7. "boundingstr" and "optbounding" DRAW-commands have been eliminated because their function can be made by "bounding" DRAW-command (e.g. see tests/bugs/vis/buc60857 or samples/tcl/snowflake.tcl test cases). 8. Documentation has been updated.
50 lines
1.2 KiB
Plaintext
50 lines
1.2 KiB
Plaintext
puts "========"
|
|
puts "OCC29311"
|
|
puts "========"
|
|
puts ""
|
|
#################################################
|
|
# Implementation of the Oriented Bounding Boxes (OBB) functionality
|
|
#################################################
|
|
|
|
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 -s 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 -s a -obb -shape rr$i
|
|
|
|
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 > 30 } {
|
|
puts "Error: The obtained OBB(s) is not precise."
|
|
}
|
|
|
|
axo
|
|
donly amax rr${MaxIteration}
|
|
fit
|
|
checkview -screenshot -2d -path ${imagedir}/${test_image}.png
|