1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
|
class:: Pstutter
summary:: repeat input stream values
related:: Classes/Pdup, Classes/Pn, Classes/Pattern#-dup
categories:: Streams-Patterns-Events>Patterns>Repetition
note::It is recommended to use link::Classes/Pdup:: instead. This class is retained for backwards compatibility.::
warning::Pstutter will return link::Classes/Pdup::::
description::
repeat each element n times.
code::
(
var a, b;
a = Pstutter(2, Pwhite(-1.0, 1.0));
x = a.asStream;
8.do { x.next.postln };
)
::
This is also a response to link::Classes/Pattern#-dup::
ClassMethods::
method::new
argument::n
The number of repeats for each new element. n may be a pattern, so the number of times can vary each iteration.
argument::pattern
the pattern to repeat.
returns:: link::Classes/Pdup::
Examples::
code::
// the first argument can be a pattern, too:
(
var a, b;
a = Pstutter(Prand([1, 2, 5], inf), Pwhite(-1.0, 1.0)); // repeat either once, twice, or five times
x = a.asStream;
20.do { x.next.postln };
)
// using event patterns:
(
SynthDef(\help_sinegrain,
{ | out=0, freq=440, sustain=0.05 |
var env;
env = Env.perc(0.01, sustain, 0.2).kr(doneAction: Done.freeSelf);
Out.ar(out, SinOsc.ar(freq, 0.5pi, env))
}).add;
)
(
a = Pbind(
\instrument, \help_sinegrain,
\note, Pxrand([0, 5, 7, 9], inf),
\dur, 0.05,
\sustain, 0.1
);
Pstutter(Pseq([1, 2, 3, 4], inf), a).trace.play;
)
// Pstutter used as a sequence of pitches
(
c = Pstutter(3, Pxrand([1, 2, 3], inf) * 4 + 65);
x = c.asStream;
Routine {
loop {
Synth(\help_sinegrain, [\freq, x.next.midicps]);
0.12.wait;
}
}.play;
)
// Voss algorithm for pink noise
// note that pattern.stutter(n) is a synonym for Pstutter(n, pattern)
a = Pwhite();
c = (2 ** (0..10)).sum { |n| a.stutter(n) };
c.asStream.nextN(1000).plot
// Voss-McCartney algorithm: balance calculation for realtime use
a = Pwhite();
c = (2 ** (0..10)).sum { |n| a.stutter(n.div(2).fin(1)) ++ a.stutter(n) };
c.asStream.nextN(1000).plot
::
|