mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
Removed testgrids 'bugs/vis' and '3rdparty'; tests have been redistributed across other grids. Moved testgrid 'v3d/ivtk' into dedicated 'vtk/ivtk'. Added testgrid 'vselect' dedicated to 3D viewer picking/selection functionality and filled with tests from 'v3d/vertex', 'v3d/face' and similar groups. Added testgrid 'opengl' dedicated to OpenGL driver low-level functionality (GLSL programs and similar) and filled with tests from 'v3d/glsl', 'v3d/raytrace', '3rdparty/fonts', 'bugs/vis' (portion) and similar. Added testgrid 'opengles3' dedicated to OpenGL ES 3.0 driver low-level functionality and reusing tests from 'opengl' testgrid. Subgroup 'opengles3/raytrace' is disabled on Windows, as Ray-Tracing currently requires OpenGL ES 3.2. while ANGLE library implements only OpenGL ES 3.0. Added testgrid 'opengles2' dedicated to OpenGL ES 2.0 driver low-level functionality and reusing a limited subset of passing tests from 'opengl' testgrid. Currently testgrid is activated only on Windows platform when using ANGLE library (properietary OpenGL ES drivers do not allow creation of restricted 2.0 context). Test cases have been cleaned out to put bug description into log, to properly load necessary plugins and to explicitly dump viewer.
88 lines
2.8 KiB
Plaintext
88 lines
2.8 KiB
Plaintext
puts "========"
|
|
puts "OCC24307 Objects clipping algorithm using BVH performance test: Simple boxes test"
|
|
puts "========"
|
|
|
|
# object characteristics
|
|
set BOXES_NUM 10
|
|
set BOX_SIZE 100
|
|
set PERCENT_OF_INNER_BOXES 30
|
|
|
|
# window parameters
|
|
set SMALL_WIN_WIDTH 512
|
|
set SMALL_WIN_HEIGHT 512
|
|
|
|
# other
|
|
array set aBoxNames {}
|
|
|
|
pload VISUALIZATION MODELING
|
|
vclear
|
|
vinit name=small_wnd l=32 t=32 w=$SMALL_WIN_WIDTH h=$SMALL_WIN_HEIGHT
|
|
vactivate small_wnd
|
|
vrenderparams -perfUpdateInterval 0
|
|
vrenderparams -frustumculling off
|
|
vautozfit 0
|
|
vviewparams -scale 1.953125 -eye 0.57735026918962573 -0.57735026918962573 0.57735026918962573
|
|
vzrange 1 512
|
|
vremove -all -noinfo
|
|
|
|
set aInnerBoxesNum [expr $BOXES_NUM * $PERCENT_OF_INNER_BOXES / 100]
|
|
puts ""
|
|
set aDebugInfo "Total number of visible objects: "
|
|
append aDebugInfo $aInnerBoxesNum
|
|
puts $aDebugInfo
|
|
puts ""
|
|
|
|
puts "Start boxes generation..."
|
|
set aInnerWidthStep [expr $SMALL_WIN_WIDTH / (2 * ($aInnerBoxesNum + 1))]
|
|
set aInnerHeightStep [expr $SMALL_WIN_HEIGHT / (2 * ($aInnerBoxesNum + 1))]
|
|
set aOuterStep [expr $BOX_SIZE * 3 / ($BOXES_NUM - $aInnerBoxesNum + 1)]
|
|
for {set i 0} {$i < $aInnerBoxesNum} {incr i} {
|
|
set aCurrName "inner_box"
|
|
append aCurrName $i
|
|
set aX [expr - $SMALL_WIN_WIDTH / 4 + ($i + 1) * $aInnerWidthStep ]
|
|
set aY [expr - $SMALL_WIN_HEIGHT / 4 + ($i + 1) * $aInnerHeightStep ]
|
|
box $aCurrName $aX $aY 0 $BOX_SIZE $BOX_SIZE $BOX_SIZE
|
|
set aBoxNames($i) $aCurrName
|
|
}
|
|
for {set i $aInnerBoxesNum} {$i < $BOXES_NUM} {incr i} {
|
|
set aCurrName "outer_box"
|
|
append aCurrName $i
|
|
set aX [expr - $SMALL_WIN_WIDTH - $BOX_SIZE * 3 + ($i - $aInnerBoxesNum + 1) * $aOuterStep]
|
|
set aY [expr - $SMALL_WIN_HEIGHT - $BOX_SIZE * 3 + ($i - $aInnerBoxesNum + 1) * $aOuterStep]
|
|
box $aCurrName $aX $aY 0 $BOX_SIZE $BOX_SIZE $BOX_SIZE
|
|
set aBoxNames($i) $aCurrName
|
|
}
|
|
puts "$BOXES_NUM boxes generated."
|
|
puts ""
|
|
|
|
puts "Start displaying boxes without clipping..."
|
|
for {set i 0} {$i < $BOXES_NUM} {incr i} {
|
|
vdisplay -noupdate $aBoxNames($i)
|
|
}
|
|
puts [vfps]
|
|
vrenderparams -perfCounters none
|
|
vdump $imagedir/${casename}_cull_off_ref.png
|
|
vrenderparams -perfCounters verbose|nofps|nocpu
|
|
vdump $imagedir/${casename}_cull_off.png
|
|
puts "All boxes were displayed."
|
|
puts ""
|
|
|
|
verase
|
|
|
|
vrenderparams -frustumculling on
|
|
puts "Start displaying boxes with clipping..."
|
|
for {set i 0} {$i < $BOXES_NUM} {incr i} {
|
|
vdisplay -noupdate $aBoxNames($i)
|
|
}
|
|
puts [vfps]
|
|
vrenderparams -perfCounters none
|
|
vdump $imagedir/${casename}_cull_on_ref.png
|
|
vrenderparams -perfCounters verbose|nofps|nocpu
|
|
vdump $imagedir/${casename}_cull_on.png
|
|
puts "All boxes were displayed."
|
|
|
|
set aDiffImageResult [diffimage $imagedir/${casename}_cull_on_ref.png $imagedir/${casename}_cull_off_ref.png 0.1 0 0 $imagedir/${casename}_diff.png]
|
|
if {$aDiffImageResult != 0} {
|
|
puts "ERROR : Test failed: there is a difference between images rendered with and without clipping"
|
|
}
|