WaitSecs

Psychtoolbox>WaitSecs

WaitSecs - Timed waits:

[realWakeupTimeSecs] = WaitSecs(waitPeriodSecs); – Wait for at least ‘waitPeriodSecs’ seconds. Try to be precise.
[realWakeupTimeSecs] = WaitSecs(‘UntilTime’, whenSecs); – Wait until at least time ‘whenSecs’.
[realWakeupTimeSecs] = WaitSecs(‘YieldSecs’, waitPeriodSecs); – Wait for at least ‘waitPeriodSecs’ seconds. Be more sloppy.

The optional ‘realWakeupTimeSecs’ is the real system time when WaitSecs finished waiting,
just as if you’d call realWakeupTimeSecs = GetSecs; after calling WaitSecs. This for your
convenience and to reduce call overhead and drift a bit for this common combo of commands.

wakeup=WaitSecs(s)

Waits “s” seconds with high precision. The timing precision depends on
the model of your computer, but a well configured system will be accurate
to about 1 millisecond if your script is executed with realtime-priority
(See help Priority) and well written.

WaitSecs optionally returns the time at “wakeup” in seconds, just as a
WaitSecs(s); wakeup = GetSecs; would do, but with less overhead.

WaitSecs(s) is similar to Matlab’s built-in PAUSE(s) command. The
advantage of WaitSecs(s) is that it is much more accurate. However, PAUSE
can be turned ‘ON’ and ‘OFF’, which is useful for scripts.

You can also use WaitSecs to wait until a specific time ‘when’ is reached,
instead of waiting for a specific interval. This is a drift-free approach,
even suitable for waiting a given interval, because errors can’t accumulate:

wakeup = WaitSecs(‘UntilTime’, when);

TIMING ADVICE: the first time you access any MEX function or M file,
Matlab takes several hundred milliseconds to load it from disk.
Allocating a variable takes time too. Usually you’ll want to omit those
delays from your timing measurements by making sure all the functions you
use are loaded and that all the variables you use are allocated, before
you start timing. MEX files stay loaded until you flush the MEX files
(e.g. by changing directory or calling CLEAR MEX). M files and variables
stay in memory until you clear them.

OS X: ___________________________________________________________________

WaitSecs always uses the high-precision uptime clock. It sleeps the main
MATLAB thread for the given wait period, surrendering CPU time to other
processes while waiting. WaitSecs is now safe to use at any priority
setting.

WaitSecs ignores the OX MATLAB <ctrl>-C break key sequenece.

WINDOWS:_________________________________________________________________

WaitSecs uses Windows QueryPerformanceCounter() call which, in turn,
reads a high-performance hardware counter in Pentium and better CPUs.

WaitSecs ignores the Win MATLAB <ctrl>-C break key sequenece.

Linux: __________________________________________________________________

WaitSecs always uses the POSIX realtime high-precision timing facilities
(clock_nanosleep(CLOCK_RT,…)). It sleeps the main MATLAB thread for the
given wait period, surrendering CPU time to other processes while waiting.
WaitSecs is now safe to use at any priority setting.

NB.: Use of a modern 2.6.x kernel is recommended, and many modern
distros, e.g., Ubuntu 7.1, offer the option of installing a special
low-latency soft-realtime (preempt) kernel for even higher timing
precision - or even a hard-realtime kernel like RTLinux or RTAI. This is
as easy as a few mouse clicks and waiting a few minutes!
_________________________________________________________________________

See also: GetSecs, GetSecsTick, GetTicks, WaitTicks, PAUSE.