2 summary:: Buffer based simple delay line with cubic interpolation.
3 related:: Classes/BufDelayL, Classes/BufDelayN, Classes/DelayC
4 categories:: UGens>Delays>Buffer
9 Simple delay line with cubic interpolation which uses a buffer for its
10 internal memory. See also link::Classes/BufDelayN:: which uses no
11 interpolation, and link::Classes/BufDelayL:: which uses linear
12 interpolation. Cubic interpolation is more computationally expensive
13 than linear, but more accurate.
23 note:: The buffers provided to any of the BufDelay units must be one channel. If you want to delay a multichannel signal, you must provide as many separate (one-channel) buffers as there are input channels.::
29 Delay time in seconds.
32 Warning:: For reasons of efficiency, the effective buffer size is limited to the previous power of two. So, if 44100 samples are allocated, the maximum delay would be 32768 samples.
40 b = Buffer.alloc(s,44100,1);
43 // Dust randomly triggers Decay to create an exponential
44 // decay envelope for the WhiteNoise input source
46 z = Decay.ar(Dust.ar(1,0.5), 0.3, WhiteNoise.ar);
47 BufDelayC.ar(b.bufnum, z, 0.2, 1, z); // input is mixed with delay via the add input
56 // two channels, two buffers
57 b = Buffer.allocConsecutive(2, s, 32768, 1);
59 a = { |bufs = #[0, 1]|
60 var sig = SinOsc.ar([440, 880]) * Decay2.kr(Impulse.kr([2, 4]), 0.01, 0.15);
61 sig + BufDelayC.ar(bufs, sig, delaytime: 0.125)
62 }.play(args: [bufs: b]);