/usr/share/SuperCollider/HelpSource/Classes/Pluck.schelp is in supercollider-common 1:3.8.0~repack-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | class:: Pluck
summary:: A Karplus-Strong UGen
categories:: UGens>Delays
description::
A Karplus-Strong UGen
classmethods::
method:: ar
argument:: in
an excitation signal.
argument:: trig
upon a negative to positive transition, emphasis::n:: samples of the excitation signal will be fed into the delay line, where emphasis::n = delaytime * sample_rate / 2::, using a rectangular envelope (no fading).
argument:: maxdelaytime
the max delay time in seconds (initializes the internal delay buffer).
argument:: delaytime
delay time in seconds.
argument:: decaytime
time for the echoes to decay by 60 decibels. Negative times emphasize odd partials.
argument:: coef
the coef of the internal OnePole filter. Values should be between -1 and +1 (larger values will be unstable... so be careful!).
argument:: mul
argument:: add
examples::
code::
s.boot;
// excitation signal is WhiteNoise, triggered twice a second with varying OnePole coef
(
{Pluck.ar(WhiteNoise.ar(0.1), Impulse.kr(2), 440.reciprocal, 440.reciprocal, 10,
coef:MouseX.kr(-0.999, 0.999))
}.play(s)
)
s.quit;
// a group of angry fretless mandolin players
(
{
var freq, numparts;
numparts = 50;
freq = SinOsc.kr(Array.fill(numparts, {Rand(0.05, 0.2)}),
Array.fill(numparts, {Rand(0, 1.0)})).range(1000, 3000);
LeakDC.ar(
Pan2.ar(
Pluck.ar(
WhiteNoise.ar(0.1).dup(numparts),
Impulse.kr(Array.fill(numparts, {Rand(10, 12)})),
100.reciprocal, freq.reciprocal, 2, Rand(0.01, 0.2), mul: 1),
Array.fill(numparts, {Rand.new(-1.0, 1.0)}))
.sum
);
}.play(s);
)
::
|