Массив автобусов в суперколлайдере

У меня есть Synth, сгенерированный с помощью do:

(
SynthDef(\siny, { arg freq, outBus=0; Out.ar( outBus, SinOsc.ar(freq!2,0,0.2) ) } ).send(s);
SynthDef(\filter, { arg cFreq,q=0.8, inBus; Out.ar( 0, BPF.ar(In.ar(inBus), cFreq!2, 1/q ) ) } ).send(s);

)

(
~sourceOut = Bus.audio(s);
~sine_Group = ParGroup.new;
z = [100,500,1000,1500,250];

{
z.do({ arg val; Synth.head(~sine_Group, \siny, [\freq: val, \outBus: ~sourceOut]) });
z.do({ arg val; Synth.after(~sine_Group, \filter, [\inBus: ~sourceOut, \cFreq: 200] ) });

}.play;
)

На данный момент я понимаю, что выходные данные нескольких экземпляров Synth \siny смешиваются в шине ~sourceOut и отправляются как входные данные в synth \filter.

Что я на самом деле хочу сделать, так это иметь непосредственное соединение между несколькими экземплярами \ siny и \ filter. Могу ли я использовать массив шин для их соединения? Если так, то как мне это сделать?

1 ответ

Решение

Да, ты можешь. Здесь я изменил ваш код минимально. Сначала я сделал ~sourceOut массив Bus, а не один Bus. Во-вторых, внутри do Я использовал тот факт, что основные итерационные функции в SuperCollider могут обеспечить второй index аргумент, а также каждый элемент сам. В-третьих, я использую это index Аргумент для выбора желаемой шины:

(
z = [100,500,1000,1500,250];
~sourceOut = z.collect{ Bus.audio(s) };
~sine_Group = ParGroup.new;

{
z.do({ arg val, index; Synth.head(~sine_Group, \siny, [\freq: val, \outBus: ~sourceOut[index]]) });
z.do({ arg val, index; Synth.after(~sine_Group, \filter, [\inBus: ~sourceOut[index], \cFreq: 200] ) });

}.play;
)

В зависимости от ваших потребностей, вы также можете посмотреть на NodeProxy который полезен для создания прототипов и живого кодирования, и предоставляет некоторые приемы для подключения вывода синтезаторов друг к другу.

Другие вопросы по тегам