On Fri, Mar 11, 2016 at 11:53 AM, Jonathan Brickman <jeb@ponderworthy.com> wrote:

the "engines" i'm referring to are your many multiple clients (19 or so).
OK, I think I see what you are referring to: the switching nature of the client list, where the JACK server has to switch between.  And this is entirely why it helps to run multiple JACK servers on multiple motherboards, and why it will help to run multiple JACK servers on my box, because the client list reduces tremendously per JACK server

No, it will not. The entire graph is driven by a single time/clock source (your audio interface).

From the moment that clock ticks (generally via an interrupt to the CPU) until it ticks again, the entire JACK graph (regardless of how clients and/or network-connected other JACK servers are involved) MUST complete execution.

If you use sequential execution, then everything will happen on 1 core. If the dataflow is parallel (which your case does include, partially) then this may waste computational resources that could be used to drop the DSP load.

So you can parallelize it to the extent possible, which JACK2 already does. In your case, there are times when it could be using up to

But you get NOTHING from using additional JACK servers except for more time spent on context switches and communication overhead. The clients are already being parallelized as much as they can be.

You are not maximising the CPU resources you have available because you don't have a fully parallelizable data flow. There's no way that using multiple computers, multiple JACK servers or anything can get around the fact that clients D, E and F cannot be executed until clients A, B and C are done. This happens multiple times in your data flow.