1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
class:: PV_RectComb2
summary:: Make gaps in spectrum.
related:: Classes/FFT, Classes/IFFT, Classes/PV_RectComb
categories:: UGens>FFT
Description::
Alternates blocks of bins between the two inputs.
classmethods::
method::new
argument::bufferA
FFT buffer A.
argument::bufferB
FFT buffer B.
argument::numTeeth
Number of teeth in the comb.
argument::phase
Starting phase of comb pulse.
argument::width
Pulse width of the comb.
Examples::
code::
s.boot;
b = Buffer.read(s, Platform.resourceDir +/+ "sounds/a11wlk01.wav");
(
var exBuf;
Dialog.getPaths({ arg paths; //get a second soundfile;
paths.do({ arg p; exBuf = Buffer.read(s, p);
SynthDef("help-max", { arg out=0, soundBufnum1=2, soundBufnum2 = 3;
var inA, chainA, inB, chainB, chain ;
inA = PlayBuf.ar(1, soundBufnum1, BufRateScale.kr(soundBufnum1), loop: 1);
inB = PlayBuf.ar(1, soundBufnum2, BufRateScale.kr(soundBufnum2), loop: 1);
chainA = FFT(LocalBuf(2048), inA);
chainB = FFT(LocalBuf(2048), inB);
chain = PV_RectComb2(chainA, chainB, MouseX.kr(0, 32), MouseY.kr, 0.3);
Out.ar(out, 0.5 * IFFT(chain).dup);
}).play(s, [\soundBufnum1, b, \soundBufnum2, exBuf]);
})
},{
"cancelled".postln;
});
)
::
|