This repository contains easy to use stereo decoders for high order ambisonics using the ambisonic toolkit for SuperCollider that are automatically set up as persistent main effects on the main outputs of SuperCollider. They are respawned when the user hard stops the sound.
This quark depends on the ambisonic toolkit and requires a full installation of it. See these instructions for more information.
It also depends on persistentmainfx which is installed automatically by the quark system.
Open up SuperCollider and evaluate the following line of code:
Quarks.install("https://github.com/madskjeldgaard/stereodecoders")
// Setup decoder
(
~order = ~order ? 3;
StereoDecoderUHJ.new(hoaOrder: ~order);
// Alternative method:
/*
StereoDecoderVirtualMics.new(
hoaOrder: ~order,
angle: 130,
pattern: 0.5 // 0 = omni, 0.5 = cardio, (3-sqrt(3))/2 = super-cardio, 0.75 = Hyper cardio, 1.0 = bi directional
);
*/
)
// Inspect the node tree to see that it is in fact in action:
s.plotTree
// Play some high order ambisonics sound
(
// White Noise going round
Ndef(\hoa_testorientation, {|amp=0.125, freq=100, rotFreq=1, ele=0|
// var sig = LFTri.ar(freq)*amp;
var sig = WhiteNoise.ar(amp);
var azi = LFSaw.kr(rotFreq, mul: pi);
sig = HoaEncodeDirection.ar(
sig,
azi,
ele,
AtkHoa.refRadius,
~order
);
}).play
)
// Bypass the decoder to output raw ambisonics
StereoDecoderUHJ.set(\bypass, 1);