<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=us-ascii"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=EN-US link="#0563C1" vlink="#954F72"><div class=WordSection1><p style='margin:0in;margin-bottom:.0001pt'>I have written a text-based, interactive gstreamer application to stream audio across my LAN from a "music server" computer to multiple "client" computers. More info and code here:<o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt'><a href="http://audio.claub.net/GSASysCon.html">http://audio.claub.net/GSASysCon.html</a><o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt'>My question is about the client side of this system. <o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt'><o:p> </o:p></p><p style='margin:0in;margin-bottom:.0001pt'>The client computers are located in/at/near active loudspeakers and I have been passing gstreamer’s audio output, via an alsa loopback, to another program (ecasound) that performs routing and implements LADSPA plugins. This comprises audio DSP and the crossover for the loudspeaker system. <o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt'><o:p> </o:p></p><p style='margin:0in;margin-bottom:.0001pt'>When testing some recent single board computers, the OS releases came without the alsa loopback. Despite trying other ways to pass audio between gstreamer and ecasound on the client I have not been able to duplicate the low-latency performance of the loopback, which has created a roadblock for me. But just recently I learned that gstreamer is able to implement LADSPA plugins, including LADSPA plugins that are external to gstreamer (I wrote my own). This means that I could possibly implement the “DSP crossover” functionality right in gstreamer itself and I would no longer need to rely on the alsa loopback (or ecasound). To do this I need to duplicate ecasound’s routing functions, and its time alignment of the various channels obtained by splitting the input. <o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt'><o:p> </o:p></p><p style='margin:0in;margin-bottom:.0001pt'>Currently in ecasound, each input channel (e.g. mono or L&R stereo) is duplicated N times (once per band of the loudspeaker crossover system), a varying number of LADSPA filters are applied to each channel. There may be other operations like merging/mxing channels, etc. At the end of the process all channels are output via a multichannel DAC. I understand that in gstreamer I can use 'deinterleave' and 'tee' to copy/split the input channels. My concern is that varying latency will result depending on how many LADSPA filters are applied to each of the N channels. Each LADSPA filter has some finite processing overhead and this overhead varies by filter type and will change depending on the computing hardware employed. <o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt'><o:p> </o:p></p><p style='margin:0in;margin-bottom:.0001pt'>How do I properly interleave the channels back together after applying an arbitrary number of LADSPA filters and other operations to each channel so that the timing is correct? Should I employ a multiqueue just prior to interleave? What other approaches are needed so that the N channels remain properly synchronized?<o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt'><o:p> </o:p></p><p style='margin:0in;margin-bottom:.0001pt'>If I am able to migrate from alsa_loopback+ecasound to running everything via gstreamer that will streamline and improve the application in many ways. Any advice and guidance to that end is appreciated. <o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt'><o:p> </o:p></p><p style='margin:0in;margin-bottom:.0001pt'>-Charlie<o:p></o:p></p><p style='margin:0in;margin-bottom:.0001pt'><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p></div></body></html>