// hamburg soft frog loops, by Julian Rohrhuber July 2005
// Published under the Creative Commons licence
// http://creativecommons.org/licenses/by/2.0/
(
[\kr, \ar].do { |x|
	SynthDef("softfrog_"++x, { arg out, freq=440, prate=180, pwidth=0.5, sustain=0.3, amp=0.1;
		var env, u;
			env = Env.linen(Rand(0.001, 0.003), Rand(0.1, 0.3), 0.01);
			freq = freq + LFNoise2.kr(5, 10);
			u = SinOsc.ar(
						freq,
						LFPulse.perform(x,
							prate,
							0,
							Line.kr(pwidth, 0, sustain)
						),
						amp
				);
			u = BRF.ar(u, freq, 0.1) * EnvGen.kr(env, doneAction:2);
			Out.ar(out, Pan2.ar(u, Rand(-1,1)))
	}).store;
};
)
(
	var arr, arr2, arr3, arr4, arfill, prob, node1, node2;
	var dt = 1/8;
	var n = 16;
	arfill = { arr = Array.fill(n div: 2, { 180 + 180.5.rand2 }) };
	arr2 = Array.fill(n, { rrand(1, pi) });
	arr3 = Array.fill(n, { 1300 + 100.rand2 });
	arr4 = Array.fill(n, { if(0.6.coin, { 0.5.rand } , { 0.1.rand })  });
	prob = [4,1].normalizeSum;
	
	node1 = NodeProxy.audio(s, 2);
	node2 = NodeProxy.audio(s, 2);
	node2.source = { RLPF.ar(node1.ar, LFNoise2.kr(3).range(300, MouseY.kr(300, 10000, 1)), 0.5) };
	node2.play;
	
	fork {
		inf.do {|i|
			if(i % 64 == 0) { arfill.value };
			Synth(["softfrog_kr", "softfrog_ar"].wchoose(prob), 
					[
					\out, node1.index,
					\freq, arr3 @@ i, 
					\prate, arr @@ i, 
					\pwidth, arr2 @@ i, 
					\amp, arr4 @@ i
					]
			);
			dt.wait;
		}
	};
	
	CmdPeriod.doOnce { node2.clear; node1.clear };
)