I think you got it now :-)

In Pd every object is a black box (= the concept of the "unit generator"), it doesn't care what's going on inside. DSP computation starts from the outside. An object can be computed when all its input dependencies have been computed. This will never be the case when one of its inlets is in some way connected to one of its outlets - for reason which are hopefully obvious.

The workaround is to use a pair of [s~]/[r~] or [throw~]/[catch~].

Christof

On 26.02.2020 00:26, William Huston wrote:
> in your example with the effect outside your abstraction you can literally *see* the DSP loop, why are you surprised?

You have got to be kidding me!!!

So are you saying....

If I have an audio abstraction FOO,
with has 4 inlets~ and 4 outlets~.

and I have another BAR,
with 2 inlets~ and 2 outlets~,

and I try to connect a pair of FOO's outlets~ to BAR's inlets~,
and BAR's outlets to a pair of FOO's inlet's,
that *PD throws a "DSP loop error" _/whether or not there/_*
*_/is in fact an audio loop in the actual graph/_?*??

And there is not a way to override this behavior??





--
William Huston: williamahus...@gmail.com <mailto:williamahus...@gmail.com>
Binghamton NY

*Public Service Mapping / Videography / Research / Education / Safety Advocacy* Blog <http://WilliamAHuston.blogspot.com> -- Facebook <http://facebook.com/billhuston> -- Twitter <http://twitter.com/WilliamAHuston>-- Youtube <https://www.youtube.com/channel/UCGijK1amWOLglT3YeTyEBNQ?sub_congfirmation=1>*-- Podcast Blog <https://billhustonpodcast.blogspot.com/>
*
*Document collections*: VirtualPipelines <http://TinyURL.com/VirtualPipelines> -- BHDCSDimockArchive <http://bit.ly/BHDCSDimockArchive> *Please support my work! -- *TinyURL.com/DonateToBillHuston <http://TinyURL.com/DonateToBillHuston>

**




On Tue, Feb 25, 2020 at 6:01 PM Christof Ressi <i...@christofressi.com <mailto:i...@christofressi.com>> wrote:

    A DSP loop is when signal connections form a loop. Pd can't look
    into objects so it just treats them as black boxes. It's as simple
    as that.

    After all, in your example with the effect outside your
    abstraction you can literally *see* the DSP loop, why are you
    surprised? And in your other example with the effect inside your
    abstraction you don't get a DSP loop because, well, there's is no
    DSP loop.

    I see where you're coming from. In the analog world your two
    examples are indeed equivalent, but in Pd they are *not*.

    Christof

    On 25.02.2020 23:46, Christof Ressi wrote:

    especially because of additional potential delay of inlet~/outlet~.
    inlet~/outlet~ does *not* add a delay (unless when going to a
    larger blocksize).

        But you're using [r~] and [s~] which is not the same as
        direct signal connections. The former can act like a short
        delay line. Please read "3.audio.examples/G05.execution.order".


    Christof, Yes! Exactly!
    I think you misunderstood. With "former" I meant [r~]/[s~].
    [inlet~]/[outlet~] does not add a delay.

Also, believe me, r~/s~ has nothing to do with it.
    Believe me, it certainly has. Can you finally share a minimal
    test patch, please? I would like to see an actual patch where you
    get an unexpected DSP loop error.

    Christof

    On 25.02.2020 23:40, William Huston wrote:
    On Tue, Feb 25, 2020 at 6:14 AM Christof Ressi
    <i...@christofressi.com <mailto:i...@christofressi.com>> wrote:

        @Dan

        As far as I recall, going between abstraction to parent
        patch via inlet~/outlet~ introduces a block delay, hence no
        error

    Dan, correction-- that is the exact circumstance where I *am*
    getting the error.
    So now I think you are beginning to see why I think it's unexpected,
    especially because of additional potential delay of inlet~/outlet~.

    Dan also wrote:
    > As the error says, you shouldn't create a direct feedback loop
    with signal cords.

    Let me try to explain again:

    *I have taken a WORKING CIRCUIT--*
    **
    (a simple stereo delay circuit, with cris-cross L/R feedback
    implemented with [delwrite~] + [vd~])
    *-- which DOES NOT produce a "DSP Loop Error",
    *
    *pulled a Null (straight-wire) Filter
    *
    *(which had been installed in the feedback path)
    *
    *and moved it externally to the abstraction*
    *(up to the parent patch), via outlet~/inlet~,*
    *which, if anything ADDS additional block delays,
    *
    *yet this produces "DSP Loop Error".
    *
    *
    *
    *Clearly (the way I see it)
    *
    *the logic behind detecting "DSP Loop Error" condition
    *
    *has a bug.*

    *I believe this is a false error,*
    *because as I have stated--*
    *the circuit HAD been working!*
    *
    *
    *All I did was add the potential for additional*
    *blocks of delay on the feedback path.
    *

        But you're using [r~] and [s~] which is not the same as
        direct signal connections. The former can act like a short
        delay line. Please read "3.audio.examples/G05.execution.order".


    Christof, Yes! Exactly!
    Added delay should REDUCE the chance of a "DSP Loop Detected"!

    Also, believe me, r~/s~ has nothing to do with it.
    My original patch was extremely ugly, due to criss-crossed feedback.
    I only implemented with r~/s~ to clean up the patch to share.

    Thanks everyone!
    BH














        Christof

        On 25.02.2020 11:42, Dan Wilcox wrote:
        As far as I recall, going between abstraction to parent
        patch via inlet~/outlet~ introduces a block delay, hence no
        error

        Third patch is like the second, only the effect has been
        moved out of the abstraction, and into the parent patch.
        ONLY HERE do I get the DSP loop error.

        Signal loop in a single patch without abstractions = error.
        Pd has no way to read and write to the same signal buffer
        in the patch at the same time *without* some tiny delay.

        *The point is the last two patches have (or should have)
        an identical graph! *

        At the lower level, they don't. What happens if you put
        part of the path inside a subpath which uses inlet~/outlet~?

        On Feb 25, 2020, at 11:36 AM, William Huston
        <williamahus...@gmail.com
        <mailto:williamahus...@gmail.com>> wrote:

        First abstraction, simple stereo delay:  2 delay lines,
        variable feedback L->R, R->L.
         This *works*, no DSP loop error.

        Second abstraction contains an effect in the feedback
        path. (in my simple example, it's just a null wire: In-L
        passes to Out-L, etc). Again this *works*, no DSP error.

        Third patch is like the second, only the effect has been
        moved out of the abstraction, and into the parent patch.
        ONLY HERE do I get the DSP loop error.

        *The point is the last two patches have (or should have)
        an identical graph! *
        *
        *
        It really seems like a bug to me.

        I'll upload a test patch a little later.

        Thanks,
        BH

        --------
        Dan Wilcox
        @danomatika <http://twitter.com/danomatika>
        danomatika.com <http://danomatika.com>
        robotcowboy.com <http://robotcowboy.com>




        _______________________________________________
        Pd-list@lists.iem.at  <mailto:Pd-list@lists.iem.at>  mailing list
        UNSUBSCRIBE and account-management 
->https://lists.puredata.info/listinfo/pd-list
        _______________________________________________
        Pd-list@lists.iem.at <mailto:Pd-list@lists.iem.at> mailing list
        UNSUBSCRIBE and account-management ->
        https://lists.puredata.info/listinfo/pd-list


    _______________________________________________
    Pd-list@lists.iem.at  <mailto:Pd-list@lists.iem.at>  mailing list
    UNSUBSCRIBE and account-management 
->https://lists.puredata.info/listinfo/pd-list
    _______________________________________________
    Pd-list@lists.iem.at <mailto:Pd-list@lists.iem.at> mailing list
    UNSUBSCRIBE and account-management ->
    https://lists.puredata.info/listinfo/pd-list

_______________________________________________
Pd-list@lists.iem.at mailing list
UNSUBSCRIBE and account-management -> 
https://lists.puredata.info/listinfo/pd-list

Reply via email to