Mystery solved - Michiel was right! In the current version of EP (2.0.10.242) canvas calls internally wait for the vertical blank. <div>Too bad that PST didn't consider it worth a comment in the canvas documentation... </div><div>Here is the answer I got from PST, followed by my own conclusions:<div><br></div><div>============================================================================================================================================================</div><div>In E-Prime 2.0.10.242, the default setting for flipping is enabled. You can disable this in the Experiment Object Property Pages > Devices tab.<br><br>E-Prime 2.0 offers the ability to use Display flipping to perform any drawing operations. The use of flipping is recommended to reduce the possibility of display tearing.<br><br>Use of flipping will require a PreRelease value approximately of one refresh duration for the object that precedes the drawing object to ensure proper scheduling. Without ample PreRelease, the object will schedule for the following refresh period. This would be reflected in the OnseTime and OnsetDelay properties.<br><br>When flipping is enabled, all E-Basic Canvas calls targeting the on-screen canvas will internally wait for the vertical blank refresh period. The use of Display.WaitForVerticalBlank will thus not be necessary and if used would cause the Canvas operation to draw a refresh later. Whether using flipping or not, it is recommend when performing any drawing commands to do so on an offscreen canvas and then use one Canvas.Copy operation to update the screen. <br><div>=================================================================================================================================================================</div><div><br></div><div>Upon receiving this answer, I first tried to cancel my dispaly.WaitForVerticalBlank lines, preceding the canvas operations. Unfortunately, this didn't work very well either, and yielded smaller but more inconsistent delays in timing... Eventually, the only solution I could find to overcome the delays and get my desired precise timing, was to disable the flipping and go back to the good old waitForVerticalBlank. I don't know exactly what the flipping does (couldn't find any word about it in the E-prime knowledge base or in the user guide, apart from the paragraph that appears in PST's response to my question) - but it didn't work out good enough for me.</div><div><br></div><div>I hope all this correspondence will help others in the future... </div><div>Thank you all for your help. </div><div>And if you know something more about flipping - please share...</div><div><br></div><div>Tamar</div><div><br><br>On Friday, April 26, 2013 3:54:45 PM UTC+3, Michiel Sovijärvi-Spapé wrote:<blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;">Hi,
<br>So, for anyone who'd like to test this. I use win7, 64bits (to do the coding
<br>anyway), EP2.0.10.242. This is the full code of the experiment and should
<br>work on any E-Prime with just a single inline bit in which you can paste the
<br>following:
<br>
<br>
<br>------------------------
<br>
<br>Dim cnvs As Canvas 'the active display
<br>Dim cnvsnext As Canvas 'the buffered canvas
<br>Dim j As Integer
<br>Dim clocktimes(1 To 100,1 To 4) As Long
<br>
<br>Set cnvs = Display.Canvas
<br>Set cnvsnext = Display.CreateCanvas()
<br>sleep 8000 'this is required for early experiment timing errors
<br>
<br>debug.print "*****WAIT BEFORE CNVSCOPY****"
<br>For j = 1 To 100
<br>        clocktimes(j,1) = clock.read        
<br>        cnvsnext.Line random(0,100), random(0,100),  random(0,100),
<br>random(0,100)
<br>        clocktimes(j,2) = clock.read - clocktimes(j,1)
<br>        display.<wbr>waitforverticalblank
<br>        clocktimes(j,3) = clock.read - clocktimes(j,1)        
<br>        cnvs.copy cnvsnext        
<br>        clocktimes(j,4) = clock.read - clocktimes(j,1)               <wbr> 
<br>Next j
<br>
<br>For j = 1 To 100
<br>        debug.print "Trial " &CStr(j) & ": " & CStr(clocktimes(j,1)) & " " &
<br>CStr(clocktimes(j,2)) & " " & CStr(clocktimes(j,3)) & " " &
<br>CStr(clocktimes(j,4))
<br>Next j
<br>debug.print "Debug printing took " & CStr(clock.read -
<br>(clocktimes(100,1)+clocktimes(<wbr>100,4)))
<br>For j = 1 To 100
<br>        clocktimes(j,1) = clock.read        
<br>        cnvsnext.Line random(100,200), random(0,100),  random(100,200),
<br>random(0,100)
<br>        clocktimes(j,2) = clock.read - clocktimes(j,1)
<br>        cnvs.copy cnvsnext        
<br>        clocktimes(j,3) = clock.read - clocktimes(j,1)               <wbr> 
<br>        display.<wbr>waitforverticalblank
<br>        clocktimes(j,4) = clock.read - clocktimes(j,1)        
<br>Next j
<br>debug.print "*****WAIT AFTER CNVSCOPY****"
<br>For j = 1 To 100
<br>        debug.print "Trial " &CStr(j) & ": " & CStr(clocktimes(j,1)) & " " &
<br>CStr(clocktimes(j,2)) & " " & CStr(clocktimes(j,3)) & " " &
<br>CStr(clocktimes(j,4))
<br>Next j
<br>        
<br>---------------------------
<br>
<br>Apart from showing beautiful lines, it gives me the following info in the
<br>debug output:
<br>
<br>*****WAIT BEFORE CNVSCOPY****
<br>Trial 1: 15854 1 7 24
<br>Trial 2: 15878 2 17 33
<br>Trial 3: 15912 1 16 33
<br>Trial 4: 15945 1 16 33
<br>Trial 5: 15978 2 17 33
<br>Trial 6: 16012 1 16 33
<br>Trial 7: 16045 1 16 33
<br>Trial 8: 16078 1 17 33
<br>Trial 9: 16111 2 17 34
<br>Trial 10: 16145 1 16 33
<br>Trial 11: 16178 1 17 33
<br>Trial 12: 16211 2 17 34
<br>Trial 13: 16245 1 16 33
<br>Trial 14: 16278 1 17 33
<br>Trial 15: 16311 2 17 34
<br>Trial 16: 16345 1 16 33
<br>Trial 17: 16378 2 17 33
<br>Trial 18: 16411 2 17 34
<br>Trial 19: 16445 1 16 33
<br>Trial 20: 16478 1 17 33
<br>Trial 21: 16511 2 17 34
<br>Trial 22: 16545 1 16 33
<br>Trial 23: 16578 1 17 33
<br>Trial 24: 16611 2 17 34
<br>Trial 25: 16645 1 16 33
<br>Trial 26: 16678 2 17 33
<br>Trial 27: 16711 2 17 34
<br>Trial 28: 16745 1 16 33
<br>Trial 29: 16778 1 17 33
<br>Trial 30: 16811 2 17 34
<br>Trial 31: 16845 1 16 33
<br>Trial 32: 16878 1 17 33
<br>Trial 33: 16911 2 17 34
<br>Trial 34: 16945 1 16 33
<br>Trial 35: 16978 1 17 33
<br>Trial 36: 17011 2 17 34
<br>Trial 37: 17045 1 16 33
<br>Trial 38: 17078 2 17 33
<br>Trial 39: 17111 2 17 34
<br>Trial 40: 17145 1 16 33
<br>Trial 41: 17178 1 17 33
<br>Trial 42: 17211 2 17 34
<br>Trial 43: 17245 1 16 33
<br>Trial 44: 17278 1 16 33
<br>Trial 45: 17311 2 17 34
<br>Trial 46: 17345 1 16 33
<br>Trial 47: 17378 1 16 33
<br>Trial 48: 17411 2 17 33
<br>Trial 49: 17445 1 16 33
<br>Trial 50: 17478 1 16 33
<br>Trial 51: 17511 2 17 34
<br>Trial 52: 17545 1 16 33
<br>Trial 53: 17578 2 17 33
<br>Trial 54: 17611 2 17 34
<br>Trial 55: 17645 1 16 33
<br>Trial 56: 17678 1 16 33
<br>Trial 57: 17711 2 17 33
<br>Trial 58: 17745 1 16 33
<br>Trial 59: 17778 1 16 33
<br>Trial 60: 17812 1 16 32
<br>Trial 61: 17845 1 16 33
<br>Trial 62: 17878 1 16 33
<br>Trial 63: 17911 2 17 33
<br>Trial 64: 17944 2 17 34
<br>Trial 65: 17978 1 16 33
<br>Trial 66: 18011 2 17 33
<br>Trial 67: 18044 2 17 34
<br>Trial 68: 18078 1 16 33
<br>Trial 69: 18111 1 17 33
<br>Trial 70: 18144 2 17 34
<br>Trial 71: 18178 1 16 33
<br>Trial 72: 18211 1 17 33
<br>Trial 73: 18244 2 17 34
<br>Trial 74: 18278 1 16 33
<br>Trial 75: 18311 2 17 33
<br>Trial 76: 18344 2 17 34
<br>Trial 77: 18378 1 16 33
<br>Trial 78: 18411 2 17 33
<br>Trial 79: 18444 2 17 34
<br>Trial 80: 18478 1 16 33
<br>Trial 81: 18511 2 17 33
<br>Trial 82: 18544 2 17 34
<br>Trial 83: 18578 1 16 33
<br>Trial 84: 18611 2 17 33
<br>Trial 85: 18644 2 17 34
<br>Trial 86: 18678 1 16 33
<br>Trial 87: 18711 1 17 33
<br>Trial 88: 18744 2 17 34
<br>Trial 89: 18778 1 16 33
<br>Trial 90: 18811 1 17 33
<br>Trial 91: 18844 2 17 34
<br>Trial 92: 18878 1 16 33
<br>Trial 93: 18911 1 17 33
<br>Trial 94: 18944 2 17 34
<br>Trial 95: 18978 1 16 33
<br>Trial 96: 19011 1 17 33
<br>Trial 97: 19044 2 17 34
<br>Trial 98: 19078 1 16 33
<br>Trial 99: 19111 2 17 33
<br>Trial 100: 19144 2 17 33
<br>Debug printing took 214
<br>*****WAIT AFTER CNVSCOPY****
<br>Trial 1: 19393 2 18 18
<br>Trial 2: 19411 1 16 17
<br>Trial 3: 19428 1 16 16
<br>Trial 4: 19445 1 16 16
<br>Trial 5: 19461 1 16 17
<br>Trial 6: 19478 1 16 16
<br>Trial 7: 19495 1 16 16
<br>Trial 8: 19511 2 17 17
<br>Trial 9: 19528 2 16 16
<br>Trial 10: 19544 2 17 17
<br>Trial 11: 19561 1 16 17
<br>Trial 12: 19578 1 16 16
<br>Trial 13: 19594 2 17 17
<br>Trial 14: 19611 1 16 17
<br>Trial 15: 19628 1 16 16
<br>Trial 16: 19644 2 17 17
<br>Trial 17: 19661 1 16 17
<br>Trial 18: 19678 1 16 16
<br>Trial 19: 19694 2 17 17
<br>Trial 20: 19711 1 16 17
<br>Trial 21: 19728 1 16 16
<br>Trial 22: 19744 2 17 17
<br>Trial 23: 19761 2 16 17
<br>Trial 24: 19778 1 16 16
<br>Trial 25: 19794 2 17 17
<br>Trial 26: 19811 1 16 17
<br>Trial 27: 19828 1 16 16
<br>Trial 28: 19844 2 17 17
<br>Trial 29: 19861 1 16 17
<br>Trial 30: 19878 1 16 16
<br>Trial 31: 19894 2 17 17
<br>Trial 32: 19911 1 16 17
<br>Trial 33: 19928 1 16 16
<br>Trial 34: 19944 2 17 17
<br>Trial 35: 19961 1 16 16
<br>Trial 36: 19978 1 16 16
<br>Trial 37: 19994 2 17 17
<br>Trial 38: 20011 1 16 17
<br>Trial 39: 20028 1 16 16
<br>Trial 40: 20044 2 17 17
<br>Trial 41: 20061 1 16 17
<br>Trial 42: 20078 1 16 16
<br>Trial 43: 20094 2 17 17
<br>Trial 44: 20111 1 16 16
<br>Trial 45: 20128 1 16 16
<br>Trial 46: 20144 2 17 17
<br>Trial 47: 20161 1 16 16
<br>Trial 48: 20178 1 16 16
<br>Trial 49: 20194 2 17 17
<br>Trial 50: 20211 1 16 17
<br>Trial 51: 20228 1 16 16
<br>Trial 52: 20244 2 17 17
<br>Trial 53: 20261 1 16 17
<br>Trial 54: 20278 1 16 16
<br>Trial 55: 20294 1 17 17
<br>Trial 56: 20311 1 16 16
<br>Trial 57: 20328 1 16 16
<br>Trial 58: 20344 2 17 17
<br>Trial 59: 20361 1 16 16
<br>Trial 60: 20377 2 17 17
<br>Trial 61: 20394 2 17 17
<br>Trial 62: 20411 1 16 16
<br>Trial 63: 20427 2 17 17
<br>Trial 64: 20444 2 17 17
<br>Trial 65: 20461 1 16 16
<br>Trial 66: 20478 1 16 16
<br>Trial 67: 20494 2 17 17
<br>Trial 68: 20511 1 16 16
<br>Trial 69: 20528 1 16 16
<br>Trial 70: 20544 1 17 17
<br>Trial 71: 20561 1 16 16
<br>Trial 72: 20577 2 17 17
<br>Trial 73: 20594 2 17 17
<br>Trial 74: 20611 1 16 16
<br>Trial 75: 20627 2 17 17
<br>Trial 76: 20644 1 17 17
<br>Trial 77: 20661 1 16 16
<br>Trial 78: 20677 2 17 17
<br>Trial 79: 20694 1 17 17
<br>Trial 80: 20711 1 16 16
<br>Trial 81: 20728 1 16 16
<br>Trial 82: 20744 2 17 17
<br>Trial 83: 20761 1 16 16
<br>Trial 84: 20778 1 16 16
<br>Trial 85: 20794 2 17 17
<br>Trial 86: 20811 1 16 16
<br>Trial 87: 20828 1 16 16
<br>Trial 88: 20844 2 17 17
<br>Trial 89: 20861 1 16 16
<br>Trial 90: 20877 2 17 17
<br>Trial 91: 20894 1 17 17
<br>Trial 92: 20911 1 16 16
<br>Trial 93: 20928 1 16 16
<br>Trial 94: 20944 1 17 17
<br>Trial 95: 20961 1 16 16
<br>Trial 96: 20977 2 17 17
<br>Trial 97: 20994 2 17 17
<br>Trial 98: 21011 1 16 16
<br>Trial 99: 21027 2 17 17
<br>Trial 100: 21044 1 16 17
<br>
<br>----
<br>Clearly then, something strange is going on. If anyone would like to verify
<br>this on their own PC/E-Prime, be my guest.
<br>Best,
<br>Michiel
<br>
<br>
<br>
<br>
<br>-----Original Message-----
<br>From: <a href="javascript:" target="_blank" gdf-obfuscated-mailto="asgyBC2onLQJ">e-p...@googlegroups.com</a> [mailto:<a href="javascript:" target="_blank" gdf-obfuscated-mailto="asgyBC2onLQJ">e-p...@googlegroups.<wbr>com</a>] On Behalf
<br>Of David McFarlane
<br>Sent: 25. April 2013 18:16
<br>To: <a href="javascript:" target="_blank" gdf-obfuscated-mailto="asgyBC2onLQJ">e-p...@googlegroups.com</a>; <a href="javascript:" target="_blank" gdf-obfuscated-mailto="asgyBC2onLQJ">e-p...@googlegroups.com</a>
<br>Subject: Re: Canvas.Copy is taking too long to complete
<br>
<br>Tamar,
<br>
<br>Very curious indeed, I wish I had the time to explore this further myself.
<br>You should definitely take this now to PST Web Support at
<br><a href="http://support.pstnet.com/e%2Dprime/support/login.asp" target="_blank">http://support.pstnet.com/e%<wbr>2Dprime/support/login.asp</a>
<br>, and send them a link to this discussion (for your convenience, that link
<br>is <a href="https://groups.google.com/d/topic/e-prime/OX528cBioek" target="_blank">https://groups.google.com/d/<wbr>topic/e-prime/OX528cBioek</a>
<br>).  And then please post back with the results.
<br>
<br>Thanks,
<br>-----
<br>David McFarlane
<br>E-Prime training
<br>online:  <a href="http://psychology.msu.edu/Workshops_Courses/eprime.aspx" target="_blank">http://psychology.msu.edu/<wbr>Workshops_Courses/eprime.aspx</a>
<br>Twitter:  @EPrimeMaster (<a href="https://twitter.com/EPrimeMaster" target="_blank">https://twitter.com/<wbr>EPrimeMaster</a>)
<br>
<br>
<br>At 4/25/2013 03:24 AM Thursday, Peter Quain wrote:
<br>
<br>>there must be some interfacing routines we can't 
<br>>see in the *.ebs files that differ between v1.? 
<br>>and v.2.?, and that e-prime calls when the 
<br>>scripts are run??? They both(?) must be 
<br>>allowable, and they must call upon different 
<br>>routines in e-prime that communicate with the hardware?
<br>>
<br>>At 05:08 PM 25/04/2013, you wrote:
<br>>>o.k., here is what I found, following your input:
<br>>>
<br>>>In any experiment I create in EP1 (in a 
<br>>>neighboring lab...), canvas.copy takes under 1 ms.
<br>>>In any experiment I create in EP2, canvas.copy takes a whole refresh
<br>cycle.
<br>>>If I take an experiment created in EP1 and 
<br>>>convert it to EP2 - then canvas.copy time is 
<br>>>under 1 ms... although nothing in the inline changed...
<br>>>How can that be?
<br>>>
<br>>>
<br>>>
<br>>>On Thursday, April 25, 2013 8:29:06 AM UTC+3, Peter Quain wrote:
<br>>>I haven't tested any code examples, but have a 
<br>>>lot of data showing canvas.copy in v.1.?.? 
<br>>>takes under a ms, supporting David's 
<br>>>observations. Perhaps something here is less 
<br>>>instant in v2.?, and a bug has been identified?
<br>>>At 03:19 PM 25/04/2013, you wrote:
<br>>>>Thank you both your replies!
<br>>>>I am using E-prime 2.0.10, and a CRT iiyama 
<br>>>>Vision Master screen, with display resolution
<br>>>>of 1024 x 768 and a refresh rate of 100 Hz. My 
<br>>>>operating system is windows XP.
<br>>>>I'm troubled with this timing issue because my 
<br>>>>experiment includes EEG recording, thus the
<br>>>>synchronization is terribly important. I need 
<br>>>>to send triggers via the parallel port exactly at the
<br>>>>onset of each stimulus, or else my EEG signal 
<br>>>>might be smeared. Considering that the canvas.copy
<br>>>>takes a refresh cycle to complete - I'm not 
<br>>>>sure what time ought to be considered the stimulus onset...
<br>>>>Anyhow, David, I've tried running your code - 
<br>>>>and I get dt's of 13-14ms. Do you think that all the difference
<br>>>>between your 0.22ms to my 13-14ms is due to 
<br>>>>E-prime1 vs. E-prime2 differences? That's shocking...
<br>>>>I get the same results as Michiel for the loop 
<br>>>>codes, as puzzling as they are...
<br>>>>Thanks again for your help,
<br>>>>Tamar
<br>>>>
<br>>>>
<br>>>>
<br>>>>On Wednesday, April 24, 2013 4:44:46 PM UTC+3, McFarlane, David wrote:
<br>>>>Hmm.  I explored this issue myself three years ago, using EP1 (still my
<br>>>>favorite version for this type of exploration).  I just dug up my test
<br>>>>program and ran it again on my trusty old XP laptop at home after
<br>>>>breakfast, and got times of 0.22 ms even for full screen copies, much as
<br>>>>I remember from before (where full screen means 1024 x 768; and yes,
<br>>>>that is less than a millisecond).  To be sure, here is the core of my
<br>>>>test code:
<br>>>>      t0 = clock.readmicrosec
<br>>>>      dcnvs.copy cnvs
<br>>>>      dt = clock.readmicrosec - t0
<br>>>>      msgbox format$( dt/1000, "Standard" ) & " ms"
<br>>>>where all variables are defined and initialized earlier as expected
<br>>>>(dcnvs is set to Display.Canvas just for notational convenience).
<br>>>>Also, I looked at the Canvas.Copy topic in the E-Basic Help -- no
<br>>>>evidence that .Copy includes an implicit Display.WaitForVerticalBlank,
<br>>>>to the contrary, the code example there includes an explicit
<br>>>>Display.<wbr>WaitForVerticalBlank just before the cnvs.Copy.  I would be
<br>>>>*extremely* surprised if Canvas.Copy included a
<br>>>>Display.<wbr>WaitForVerticalBlank, as that would greatly compromise its
<br>>>>utility (e.g., when wanting to Copy several segments to an offscreen
<br>>>>Canvas before copying the complete result to Display.Canvas).
<br>>>>So I do not know how to account for your results.  Mind you, I did all
<br>>>>my tests using good-old EP1 with 1024x768 display resolution.  For all I
<br>>>>know things changed with the latest EP version, or things get slower
<br>>>>with larger display resolutions.  What EP version do you use?  What
<br>>>>display resolution?
<br>>>>Michiel, I am especially puzzled by your results.  Both of your tests
<br>>>>measure the total time to perform a Canvas.Copy and
<br>>>>Display.<wbr>WaitForVerticalBlank, only in different orders.  So you should
<br>>>>get the same time for both tests, regardless of whether Canvas.Copy
<br>>>>includes its own Display.WaitForVerticalBlank.  What am I missing?
<br>>>>Nevertheless, Michiel's advice still stands  -- as long as your program
<br>>>>does everything it needs to do within one screen refresh (and assuming
<br>>>>that you *do* synchronize visual displays to the screen refresh, as you
<br>>>>should), then that is good enough.
<br>>>>-----
<br>>>>David McFarlane
<br>>>>E-Prime training online:
<br>>>><<a href="http://psychology.msu.edu/Workshops_Courses/eprime.aspx" target="_blank">http://psychology.msu.edu/<wbr>Workshops_Courses/eprime.aspx</a>><a href="http://psycholog" target="_blank"><wbr>http://psycholog</a>
<br><a href="http://y.msu.edu/Workshops_Courses/eprime.aspx" target="_blank">y.msu.edu/Workshops_Courses/<wbr>eprime.aspx</a> 
<br>>>>
<br>>>>Twitter:  @EPrimeMaster 
<br>>>>(<<a href="http://twitter.com/EPrimeMaster" target="_blank">http://twitter.com/<wbr>EPrimeMaster</a>><a href="http://twitter.com/EPrimeMaster" target="_blank">twitter.com/<wbr>EPrimeMaster</a>)
<br>>>>/-----------
<br>>>>Stock reminder:  1) I do not work for PST.  2) PST's trained staff take
<br>>>>any and all questions at
<br>>>><<a href="http://support.pstnet.com/e%2Dprime/support/login.asp" target="_blank">http://support.pstnet.com/<wbr>e%2Dprime/support/login.asp</a>><a href="http://support.pst" target="_blank">ht<wbr>tp://support.pst</a>
<br><a href="http://net.com/e%2Dprime/support/login.asp" target="_blank">net.com/e%2Dprime/support/<wbr>login.asp</a> 
<br>>>>, and they strive
<br>>>>to respond to all requests in 24-48 hours, so make full use of it.  3)
<br>>>>In addition, PST takes questions at their Facebook page
<br>>>>(
<br><a href="http://www.facebook.com/pages/Psychology-Software-Tools-Inc/241802160683" target="_blank">http://www.facebook.com/pages/<wbr>Psychology-Software-Tools-Inc/<wbr>241802160683</a>
<br>>>>), and offers several instructional videos there and on their YouTube
<br>>>>channel ( <a href="http://www.youtube.com/user/PSTNET" target="_blank">http://www.youtube.com/user/<wbr>PSTNET</a> ) (no Twitter feed yet,
<br>>>>though).  4) If you do get an answer from PST staff, please extend the
<br>>>>courtesy of posting their reply back here for the sake of others.
<br>>>>\-----------
<br>>>>Cognitology wrote:
<br>>>> > Hi,
<br>>>> >
<br>>>> > A quick look, but I think that you pretty much nailed it: it can take
<br>>>> > quite long to do any canvas operation. Given that your screen refresh
<br>>>> > rate presumably isn�t more than 100 Hz (and in any ways, your foveal
<br>>>> > vision isn�t), I don�t see the problem? 
<br>>>> Indeed, if you were to draw many
<br>>>> > things to the main canvas, one after the other, then indeed, it gets
<br>to
<br>>>> > be a problem, but as long as the only 
<br>>>> operation is copying a ï¿½preloaded�
<br>>>> > canvas to the shown one, it doesn�t 
<br>>>> matter all that much. Notice, given
<br>>>> > that you�re not using E-Prime�s 
<br>>>> stimdisplays, it�s not clear at what
<br>>>> > time the stimulus is actually displayed ï¿½ 
<br>>>> only when it�s done sending
<br>>>> > the command. I think it�s generally better for critical timing
<br>aspects
<br>>>> > of your experiment to avoid canvas as much as possible. Personally, I
<br>>>> > think ï¿½critical timing� is when it concerns a subliminal vs barely
<br>>>> > supraliminal prime or some such, for other types of stimuli the 10 ms
<br>of
<br>>>> > (constant, therefore presumably stimulus independent) delay is of
<br>>>> > trivial concern.
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> > Just testing some of it myself, and I get values ranging between 15
<br>and
<br>>>> > 17 ï¿½ which is funny, given that my refresh rate is indeed 60, so it
<br>>>> > seems a bit like there�s some sort of 
<br>>>> display.waitforverticalblank built
<br>>>> > into canvas.copy. Curiously, this:
<br>>>> >
<br>>>> > For j = 1 To 100
<br>>>> >
<br>>>> >       DrawFixation ï¿½this is just a custom function drawing a line to
<br>>>> > cnvsnext
<br>>>> >
<br>>>> >       cnvs.copy cnvsnext
<br>>>> >
<br>>>> >       display.waitforverticalblank
<br>>>> >
<br>>>> >       debug.print clock.read - clocktime
<br>>>> >
<br>>>> >       clocktime = clock.read
<br>>>> >
<br>>>> > Next j
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> > Gives me latencies equal to refresh rates (+- 1 ms).
<br>>>> >
<br>>>> > Whereas:
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> > For j = 1 To 100
<br>>>> >
<br>>>> >       DrawFixation ï¿½this is just a custom function drawing a line to
<br>>>> > cnvsnext
<br>>>> >
<br>>>> >       display.waitforverticalblank
<br>>>> >
<br>>>> > cnvs.copy cnvsnext
<br>>>> >
<br>>>> >       debug.print clock.read - clocktime
<br>>>> >
<br>>>> >       clocktime = clock.read
<br>>>> >
<br>>>> > Next j
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> > Gives me latencies equal to 2xrefresh rates. Somebody with young eyes
<br>>>> > should tell us if the first one doesn�t have cutting-off errors,
<br>>>> > otherwise I�d suggest there might be some sort of
<br>waitforverticalblank
<br>>>> > built into canvas.copy.
<br>>>> >
<br>>>> > Best,
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> > Michiel Sovij�rvi-Spap�
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> > Helsinki Institute for Information Technology
<br>>>> >
<br>>>> > Aalto & University of Helsinki
<br>>>> >
<br>>>> > Finland
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> > BTW: notice that using debug.print also incurs a delay (last measured
<br>at
<br>>>> > 0.7 ms).
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> > *From:* <a>e-p...@googlegroups.com</a> [ mailto:<a>e-p...@googlegroups.com</a><wbr>] *On
<br>>>> > Behalf Of *Tamar
<br>>>> > *Sent:* 24. April 2013 08:33
<br>>>> > *To:* <a>e-p...@googlegroups.com</a>
<br>>>> > *Subject:* Canvas.Copy is taking too long to complete
<br>>>> >
<br>>>> >
<br>>>> >
<br>>>> > I'm programming a visual experiment, and suffering from some timing
<br>>>> > issues. It seems that the line presenting the stimuli (canvas.copy) is
<br>>>> > considerably time consuming: 10-12 ms. I can't figure out the cause
<br>for
<br>>>> > this delay, and I would appreciate any help...
<br>>>> >
<br>>>> > Here is the relevant piece of code:
<br>>>> >
<br>>>> > ====== in an initializing inline script, at the begining of
<br>SessionProc:
<br>>>> > ======
<br>>>> > Set MainCanvas = Display.Canvas
<br>>>> > MainCanvas.fillColor = CColor(background_color)
<br>>>> > MainCanvas.clear
<br>>>> >
<br>>>> > For i = 1 To NumStim
<br>>>> >    Set StimCanvases(i) = Display.CreateCanvas
<br>>>> >
<br>>>> >    'define destination rect as center of screen
<br>>>> >    destRects(i).Left = Display.XRes/2-stim_w/2
<br>>>> >    destRects(i).Top = Display.YRes/2-stim_h/2
<br>>>> >    destRects(i).Right = Display.XRes/2+stim_w/2
<br>>>> >    destRects(i).Bottom = Display.YRes/2+stim_h/2
<br>>>> >
<br>>>> >    'define source rect as upper left corner
<br>>>> >    srcRects(i).Left = 0
<br>>>> >    srcRects(i).Top = 0
<br>>>> >    srcRects(i).Right = stim_w
<br>>>> >    srcRects(i).Bottom = stim_h
<br>>>> >
<br>>>> >    'Load the image file
<br>>>> >    StimCanvases(i).LoadImage "Stimuli/" & FileNames(i) & ".bmp"
<br>>>> >
<br>>>> > Next i
<br>>>> >
<br>>>> > ====== in the inline of TrialProc: =======
<br>>>> > Debug.Print "1:" & clock.read
<br>>>> > StartTrialTime = clock.read
<br>>>> > n = c.GetAttrib("CanvasNum")
<br>>>> > c.SetAttrib "TrialStart", StartTrialTime
<br>>>> > display.WaitForVerticalBlank
<br>>>> > Debug.Print "4:" & clock.read
<br>>>> > StartStimTime = clock.read
<br>>>> > c.SetAttrib "StimStart", StartStimTime
<br>>>> > Debug.Print "5:" & clock.read
<br>>>> > mainCanvas.copy StimCanvases(n),srcRects(n),<wbr>destRects(n)
<br>>>> > Debug.Print "6:" & clock.read
<br>>>> >
<br>>>> >
<br>>>> > I've tried a few things:
<br>>>> > - to create variables taking the values of
<br>>>> > StimCanvases(n),srcRects(n),<wbr>destRects(n) in the beginning of the
<br>trial,
<br>>>> > so the mainCanvas.copy line would not need to approach the arrays.
<br>>>> > - to present other simple canvases instead of my real stimuli (just a
<br>>>> > fixation, for example. or an empty canvas)
<br>>>> > - to draw something on the mainCanvas rather than copy a new canvas to
<br>>>> > it (e.g. mainCanvas.Circle).
<br>>>> >
<br>>>> > All of these takes 10-12 ms! (as calculated by subtracting time5 from
<br>>>> > time6). The only way I managed to get rid of the delay was to erase
<br>the
<br>>>> > entire row...
<br>>>> >
<br>>>> > Am I missing something here?...
<br>>>> >
<br>>>> > Thanks,
<br>>>> > Tamar
<br>
<br>-- 
<br>You received this message because you are subscribed to the Google Groups
<br>"E-Prime" group.
<br>To unsubscribe from this group and stop receiving emails from it, send an
<br>email to <a href="javascript:" target="_blank" gdf-obfuscated-mailto="asgyBC2onLQJ">e-prime+u...@<wbr>googlegroups.com</a>.
<br>To post to this group, send email to <a href="javascript:" target="_blank" gdf-obfuscated-mailto="asgyBC2onLQJ">e-p...@googlegroups.com</a>.
<br>For more options, visit <a href="https://groups.google.com/groups/opt_out" target="_blank">https://groups.google.com/<wbr>groups/opt_out</a>.
<br>
<br>
<br>
<br></blockquote></div></div></div>

<p></p>

-- <br />
You received this message because you are subscribed to the Google Groups "E-Prime" group.<br />
To unsubscribe from this group and stop receiving emails from it, send an email to e-prime+unsubscribe@googlegroups.com.<br />
To post to this group, send email to e-prime@googlegroups.com.<br />
To view this discussion on the web visit <a href="https://groups.google.com/d/msg/e-prime/-/RlvWoU9cqxYJ">https://groups.google.com/d/msg/e-prime/-/RlvWoU9cqxYJ</a>.<br />
For more options, visit <a href="https://groups.google.com/groups/opt_out">https://groups.google.com/groups/opt_out</a>.<br />
 <br />
 <br />