136 lines
3.6 KiB
Text
136 lines
3.6 KiB
Text
|
class:: Ref
|
||
|
summary:: a reference to a value
|
||
|
categories:: Core
|
||
|
|
||
|
description::
|
||
|
|
||
|
A Ref holds an object which may be retrieved and altered with the messages value and value_(obj).
|
||
|
The backquote code:: ` :: is a unary operator that is equivalent to calling code::Ref.new(obj)::.
|
||
|
|
||
|
Refs are most commonly used to prevent multi-channel expansion in link::Classes/SynthDef::s and link::Classes/Pattern::s (see link::Classes/Klank:: for an example).
|
||
|
Refs can also be used to simplify the coding of co-routines used in EventStreams (see link::Classes/Prout:: for an example).
|
||
|
|
||
|
code::
|
||
|
|
||
|
x = Ref(nil);
|
||
|
z = obj.method(x); // method puts something in reference
|
||
|
x.value.doSomething; // retrieve value and use it
|
||
|
|
||
|
::
|
||
|
|
||
|
Ref is also used as a quoting device to protect against multi channel expansion in certain UGens that require Arrays.
|
||
|
|
||
|
classmethods::
|
||
|
|
||
|
method::new
|
||
|
|
||
|
create a Ref of an object.
|
||
|
discussion::
|
||
|
Another syntax:
|
||
|
|
||
|
code::
|
||
|
`5
|
||
|
::
|
||
|
|
||
|
instancemethods::
|
||
|
|
||
|
method::dereference
|
||
|
|
||
|
Answer the value. This message is also defined in class Object where it just returns the receiver. Therefore anything.dereference will remove a Ref if there is one. This is slightly different than the value message, because value will also cause functions to evaluate themselves whereas dereference will not.
|
||
|
|
||
|
method::asRef
|
||
|
|
||
|
Answers the receiver. In class Object this message is defined to create a Ref of the object.
|
||
|
|
||
|
method::value
|
||
|
|
||
|
Get or set the value.
|
||
|
|
||
|
method::get
|
||
|
|
||
|
Returns value.
|
||
|
|
||
|
method::set
|
||
|
|
||
|
Sets value.
|
||
|
|
||
|
method::at
|
||
|
|
||
|
Returns code::value.at(index)::
|
||
|
|
||
|
method::put
|
||
|
Executes value.put(index, value)
|
||
|
|
||
|
method::seq
|
||
|
|
||
|
this method is used to return values from within a Routine definition
|
||
|
|
||
|
discussion::
|
||
|
code::
|
||
|
{ this.value = output.embedInStream(this.value); }
|
||
|
::
|
||
|
|
||
|
method::asUGenInput
|
||
|
|
||
|
Returns the Ref - this prevents multi-channel expansion in a SynthDef
|
||
|
|
||
|
method::asControlInput
|
||
|
|
||
|
Returns the value - this is used when sending a Ref as a control value to a server Node.
|
||
|
|
||
|
section::Typical uses of Ref:
|
||
|
|
||
|
subsection::preventing multi-channel expansion
|
||
|
|
||
|
Consult link::Guides/Multichannel-Expansion:: for details on multi-channel expansion in SynthDefs.
|
||
|
|
||
|
Refs prevent multi-channel expansion in a SynthDef, so the array below defines one Klank UGen rather than three.
|
||
|
|
||
|
code::
|
||
|
{ Klank.ar(`[[800, 1071, 1153, 1723], nil, [1, 1, 1, 1]], Impulse.ar(2, 0, 0.1)) }.play;
|
||
|
::
|
||
|
|
||
|
Refs cannot be used reliably to suppress multi-channel expansion within Events and Patterns.
|
||
|
Instead, it is necessary to enclose the array of values in another array:
|
||
|
|
||
|
code::
|
||
|
(
|
||
|
SynthDef(\multi, { | out, freq = #[100,200,300], amp = 0.1, pan = 0, sustain = 1|
|
||
|
var audio, env;
|
||
|
env = EnvGen.kr(Env.perc(0.01, sustain), doneAction: Done.freeSelf);
|
||
|
audio = Mix(Saw.ar(freq));
|
||
|
audio = Pan2.ar(audio * env, pan, amp);
|
||
|
OffsetOut.ar(out, audio)
|
||
|
}).add;
|
||
|
|
||
|
( instrument: \multi, freq: [ [500, 501, 700] ], sustain: 2).play
|
||
|
|
||
|
)
|
||
|
::
|
||
|
|
||
|
code::
|
||
|
(
|
||
|
Pbind(*[
|
||
|
instrument: \multi,
|
||
|
freq: Prand([
|
||
|
[[100, 141, 103] ],
|
||
|
[[100, 310, 190] ],
|
||
|
[[100, 100.1, 110] ],
|
||
|
], inf),
|
||
|
dur: 0.2,
|
||
|
sustain: 0.3
|
||
|
]).play;
|
||
|
)
|
||
|
::
|
||
|
|
||
|
|
||
|
method::multichannelExpandRef
|
||
|
This method is called internally on inputs to UGens that take multidimensional arrays, like link::Classes/Klank:: and it allows proper multichannel expansion even in those cases. For SequenceableCollection, this returns the collection itself, assuming that it contains already a number of Refs.
|
||
|
|
||
|
argument::rank
|
||
|
The depth at which the list is expanded. For instance the Klank spec has a rank of 2.
|
||
|
code::
|
||
|
`([[[100, 200], 500], nil, [[[0.01, 0.3], 0.8]]]).multichannelExpandRef(2);
|
||
|
[`[[100, 200], nil, [0.2, 0.8]], `[[130, 202], nil, [0.2, 0.5]]].multichannelExpandRef(2);
|
||
|
::
|