/usr/share/psychtoolbox-3/PsychVideoCapture/VideoDelayLoopMiniDemo.m is in psychtoolbox-3-common 3.0.9+svn2579.dfsg1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 | function VideoDelayLoopMiniDemo(delayframes, duration, firewireBasler)
% VideoDelayLoopMiniDemo([delayframes = 0] [, duration = 30] [, firewireBasler = 0]);
%
% Demonstrates most simplistic use of PsychVideoDelayLoop() function for
% delayed visual feedback via a camera + display combo.
%
% 'delayframes' == Requested delay in captured frames: 0 = Minimal delay
% (i.e. request zero delay, get whatever the minimum of your camera +
% display combo is).
%
% The demo takes some startup time to calibrate, then provides visual
% feedback for 30 seconds, then ends, unless you specifiy a different
% 'duration' in seconds.
%
% 'firewireBasler' defaults to zero. If set to 1, customize to a Basler
% A602f IIDC-1394 compliant Firewire camera.
%
% Tested on MacOS/X Intel MacBookPro with builtin iSight camera. However,
% the routine was originally developed, tested and optimized for GNU/Linux,
% so it only provides limited functionality, flexibility and performance on
% other operating systems. The inherent delay of USB cameras like Apples
% builtin iSight is pretty high, so they are not seriously useful for low
% delay feedback. Pick a good IIDC Firewire camera if you want low
% latencies. Use Linux if you want really low latencies and optimal
% control.
%
% This demo is only a proof of concept. Use with caution!
% History:
% 06/09/2007 Written (MK)
% 02/16/2010 Bugfixes and improvements. (MK)
global log
% Installation check:
AssertOpenGL;
KbName('UnifyKeyNames');
if nargin < 1 || isempty(delayframes)
delayframes = 0; % Select zero (==minimal delay) by default.
end
if nargin < 2 || isempty(duration)
duration = 30;
end
if nargin < 3 || isempty(firewireBasler)
% Default to bog standard non IIDC-1394 camera:
firewireBasler = 0;
end
if firewireBasler
% For the Basler cam and other Firewire cams, use the libDC1394 capture
% engine on OS/X instead of Apple's engine. DC1394 gives much better
% results:
oldEngine = Screen('Preference','DefaultVideoCaptureEngine', 1);
end
% Open onscreen window on screen:
screenid = max(Screen('Screens'));
w=Screen('OpenWindow', screenid);
PsychVideoDelayLoop('Verbosity', 10);
% Open video capture engine for delayed visual feedback. This is customized
% for the Apple builtin iSight, may need tweaking for other cams:
% The A602 Basler cam can only do grayscale, so set color flag to 0 if it
% is the Basler cam:
PsychVideoDelayLoop('Open', w , [], [0 0 640 480], 1 - firewireBasler);
% Try to tune and calibrate display and camera for a target framerate of 30
% Hz. This only works fully on Linux. On OS/X or Windows it'll just
% calibrate the internal timing, but not tune the display refresh interval,
% as these OS don't support such tuning:
if firewireBasler
% Basler camera A602 can do 60 fps:
PsychVideoDelayLoop('TuneVideoRefresh', 60);
% Needs to close and reopen the cam after 'TuneVideoRefresh' on OS/X at
% least, due to some bug in the Firewire stack of some versions of
% OS/X, at least Leopard known to have trouble:
PsychVideoDelayLoop('Close');
PsychVideoDelayLoop('Open', w , [], [0 0 640 480], 1 - firewireBasler);
else
% Bog standard cam: Assume no need to reopen the cam and only 30 fps
% capture rate:
PsychVideoDelayLoop('TuneVideoRefresh', 30);
end
% Set a timeout of 'duration' secs. Feedback loop runs for at most that time:
PsychVideoDelayLoop('SetAbortTimeout', duration);
% Set ESCape key as abort key to finish earlier than 'duration' seconds:
PsychVideoDelayLoop('SetAbortKeys', KbName('ESCAPE'));
% Do a fullscreen, left-right mirrored presentation:
PsychVideoDelayLoop('SetPresentation', 1, 1, 0);
% Enable timestamp logging for at most 'duration' seconds:
PsychVideoDelayLoop('SetLogging', 1, duration);
% Run the delay loop with a latency of 'delayframes' frames, allow online
% keyboard control for A602 camera:
PsychVideoDelayLoop('RunLoop', delayframes, firewireBasler);
% Done. Retrieve timing log into 'log:
log = PsychVideoDelayLoop('GetLog');
% Done. Close video capture engine and delay loop:
PsychVideoDelayLoop('Close');
% Close onscreen window, release all other ressources:
Screen('CloseAll');
if firewireBasler
% Restore capture engine settings:
Screen('Preference','DefaultVideoCaptureEngine', oldEngine);
end
% Plot overall latency plot for each captured/displayed frame:
close all;
plot(log(3,:) * 1000);
% Well done.
return;
|