You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
94 lines
3.5 KiB
94 lines
3.5 KiB
3 months ago
|
# License: Apache 2.0. See LICENSE file in root directory.
|
||
|
# Copyright(c) 2021 Intel Corporation. All Rights Reserved.
|
||
|
|
||
|
import pyrealsense2 as rs
|
||
|
from rspy import log, test
|
||
|
import sw
|
||
|
|
||
|
|
||
|
# The timestamp jumps are closely correlated to the FPS passed to the video streams:
|
||
|
# syncer expects frames to arrive every 1000/FPS milliseconds!
|
||
|
sw.fps_c = sw.fps_d = 60
|
||
|
sw.init()
|
||
|
sw.start()
|
||
|
|
||
|
|
||
|
#############################################################################################
|
||
|
#
|
||
|
test.start( "Wait for framesets" )
|
||
|
|
||
|
# It can take a few frames for the syncer to actually produce a matched frameset (it doesn't
|
||
|
# know what to match to in the beginning)
|
||
|
|
||
|
sw.generate_depth_and_color( frame_number = 0, timestamp = 0 )
|
||
|
sw.expect( depth_frame = 0 ) # syncer doesn't know about color yet
|
||
|
sw.expect( color_frame = 0, nothing_else = True ) # less than next expected of D
|
||
|
#
|
||
|
# NOTE: if the syncer queue wasn't 100 (see above) then we'd only get the color frame!
|
||
|
#
|
||
|
sw.generate_depth_and_color( 1, sw.gap_d * 1 )
|
||
|
sw.expect( depth_frame = 1, color_frame = 1, nothing_else = True ) # frameset 1
|
||
|
|
||
|
test.finish()
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
test.start( "Keep going" )
|
||
|
|
||
|
sw.generate_depth_and_color( 2, sw.gap_d * 2 )
|
||
|
sw.expect( depth_frame = 2, color_frame = 2, nothing_else = True ) # frameset 2
|
||
|
sw.generate_depth_and_color( 3, sw.gap_d * 3 )
|
||
|
sw.generate_depth_and_color( 4, sw.gap_d * 4 )
|
||
|
sw.expect( depth_frame = 3, color_frame = 3 ) # frameset 3
|
||
|
sw.expect( depth_frame = 4, color_frame = 4, nothing_else = True ) # frameset 4
|
||
|
|
||
|
test.finish()
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
test.start( "Stop giving color; wait_for_frames() should throw (after 5s)" )
|
||
|
|
||
|
sw.generate_depth_frame( 5, sw.gap_d * 5 )
|
||
|
|
||
|
# We expect the syncer to try and wait for a Color frame to fit the Depth we just gave it.
|
||
|
# The syncer relies on frame inputs to actually run -- and, if we wait for a frame, we're
|
||
|
# not feeding it frames so can't get back any, either.
|
||
|
try:
|
||
|
fs = sw.syncer.wait_for_frames()
|
||
|
except RuntimeError as e:
|
||
|
test.check_exception( e, RuntimeError, "Frame did not arrive in time!" )
|
||
|
else:
|
||
|
test.info( "Unexpected frameset", fs )
|
||
|
test.unreachable()
|
||
|
|
||
|
test.finish()
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
test.start( "try_wait_for_frames() allows us to keep feeding frames; eventually we get one" )
|
||
|
|
||
|
# The syncer will not immediately release framesets because it's still waiting for a color frame to
|
||
|
# match Depth #10. But, if we advance the timestamp sufficiently, it should eventually release it
|
||
|
# as it deems Color "inactive".
|
||
|
|
||
|
# The last color frame we sent was at gap*4, so it's next expected at gap*5 plus a buffer of gap*7
|
||
|
# (see the code in the syncer)... so we expect depth frame 5 to be released only when we're past gap*12
|
||
|
|
||
|
sw.generate_depth_frame( 6, sw.gap_d * 6 )
|
||
|
sw.expect( nothing_else = True )
|
||
|
sw.generate_depth_frame( 7, sw.gap_d * 11.5 )
|
||
|
sw.expect( nothing_else = True )
|
||
|
sw.generate_depth_frame( 8, sw.gap_d * 12.5 )
|
||
|
#
|
||
|
# We'll get all frames in a burst. Again, if the syncer queue was 1, we'd only get the last!
|
||
|
#
|
||
|
sw.expect( depth_frame = 5 )
|
||
|
sw.expect( depth_frame = 6 )
|
||
|
sw.expect( depth_frame = 7 )
|
||
|
sw.expect( depth_frame = 8, nothing_else = True )
|
||
|
|
||
|
test.finish()
|
||
|
#
|
||
|
#############################################################################################
|
||
|
test.print_results_and_exit()
|