rsc3/doc-schelp/HelpSource/Classes/Ref.schelp

136 lines
3.6 KiB
Text
Raw Normal View History

2022-08-24 13:53:18 +00:00
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);
::