<HTML><BODY style="word-wrap: break-word; -khtml-nbsp-mode: space; -khtml-line-break: after-white-space; "><BR><DIV><DIV>On Jul 4, 2006, at 10:08 AM, rubber glove wrote:</DIV><BR class="Apple-interchange-newline"><BLOCKQUOTE type="cite"><BR><DIV><BLOCKQUOTE class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">The main factor seems to be that pd only processes control messages in<BR> between audio frames. Reducing the audio latency seems to bring the<BR>jitter down to about 5ms but no further when I try it on WinXP or Linux.</BLOCKQUOTE><DIV><BR>Aha... that makes sense to me. So it is not so much just the 'hardware to pd' step, but also the control message passing within PD that is throwing off the timing here. <BR><BR> </DIV><BLOCKQUOTE class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">I would expect USB to add more jitter, as it passes through a more <BR>complex path than serial or MIDI data before being handed to pd.</BLOCKQUOTE><DIV><BR>I think I am basically stuck with USB no matter how I go, as the computers involved here are all eMacs. Using midi or serial would involve a USB interface anyway. <BR><BR> </DIV><BLOCKQUOTE class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">If you need better timing, why not record the audio into one channel<BR>along with the button on the other channel? There is essentially no <BR>jitter with the audio stream because it passes through the sound <BR>hardware at a fixed rate. The button could just emit a click when<BR>pressed. Then you have no jitter beyond the time it takes to push the<BR>button.</BLOCKQUOTE><DIV><BR>That's an interesting possibility, but I am only really using the button clicking as a simple way to test the timing. In actual use, the input would be a range of values from the rotary encoder of the knob... converting that into audio and back into numerical values seems altogether too complicated (frequency modulation?) <BR> </DIV></DIV>However, it brings to mind other possibilities: <BR><BR>If I modify the HID object to convert it into a signal-based external, then pass the values as signals, the timing should be much tighter?  This seems to have the advantage that the input values will always be automatically lined up with the audio, no matter what the latency is set to. <BR><BR>Alternatively, If I incorporate the HID code into my external, and process the knob events myself, I would avoid any additional timing errors and be left with only the jitter inherent to the device, no?<BR><BR>Thanks much for the info... <BR></BLOCKQUOTE><BR></DIV><DIV>I would also like to see the [hid] code be as low jitter as possible.  I haven't had a chance to measure it yet tho.  Unless things are really taxing the CPU, I don't think that the Pd messaging will cause more than ~1.5ms of jitter (1 block of 64 samples divided by 44100 samples).  Perhaps running Pd at 96KHz or 192KHz would reduce that jitter, provided that the block size remains 64.</DIV><DIV><BR class="khtml-block-placeholder"></DIV><DIV>I think that the first step is to devise some tests to find the true source of the jitter.  I did some quick searches about USB HID jitter and didn't find much, except this:</DIV><DIV><BR class="khtml-block-placeholder"></DIV><DIV><A href="http://elists.resynthesize.com/max-msp/2005/08/1515529/">http://elists.resynthesize.com/max-msp/2005/08/1515529/</A></DIV><DIV><BR class="khtml-block-placeholder"></DIV><DIV>It seems that this person thinks that Mac OS X's USB MIDI driver has lower jitter than the USB HID driver.  Ultimately, if we find the source of the problem, I would like to include it in the next version of [hid].</DIV><DIV><BR class="khtml-block-placeholder"></DIV><DIV>.hc</DIV><DIV><BR class="khtml-block-placeholder"></DIV><DIV><SPAN class="Apple-style-span" style="border-collapse: separate; border-spacing: 0px 0px; color: rgb(0, 0, 0); font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; text-align: auto; -khtml-text-decorations-in-effect: none; text-indent: 0px; -apple-text-size-adjust: auto; text-transform: none; orphans: 2; white-space: normal; widows: 2; word-spacing: 0px; "><DIV><BR></DIV><DIV>------------------------------------------------------------------------</DIV><DIV><BR></DIV><DIV>Using ReBirth is like trying to play an 808 with a long stick.    -David Zicarelli</DIV><BR class="Apple-interchange-newline"></SPAN> </DIV><BR></BODY></HTML>