if you care about precise timing (at the cost of of some loss of throughput)you can compile your code with -fno-omit-yields, and also the context switching timerdefault context switching rate for threads is -C0.02 (20ms), but you can set the rate as small as you like, and -C0 will trigger a context switch at every yield.happy experimenting!On Sat, Oct 18, 2014 at 10:19 PM, Brandon Allbery <allbery.b@gmail.com> wrote:_______________________________________________On Sat, Oct 18, 2014 at 9:36 PM, Jeffrey Brown <jeffbrown.the@gmail.com> wrote:threadDelay is guaranteedto wait at least as long, but potentially longer than, what the caller specifies. Another potential problem could be buffering in printf. (Eventually I intend to replace the printf statement with OSC output to a sound generator.)
This isn't going to be solved completely within Haskell; the behavior of threadDelay is the behavior of the system scheduler for a normal process, possibly modified by garbage collection delays. You'll need to switch the process to a realtime scheduling class to remove --- or at least reduce --- the OS's contribution to the uncertainties in sleep times.--brandon s allbery kf8nh sine nomine associatesunix, openafs, kerberos, infrastructure, xmonad http://sinenomine.net
Haskell-Cafe mailing list
Haskell-Cafe@haskell.org
http://www.haskell.org/mailman/listinfo/haskell-cafe