scide: implement selectionLength for openDocument
[supercollider.git] / HelpSource / Classes / Vibrato.schelp
blobf97b732cf2605cbd0d242b2f956a29237321cb6d
1 class:: Vibrato
2 summary:: The Vibrato oscillator models a slow frequency modulation.
3 categories::  UGens>Generators>Deterministic, UGens>Generators>Stochastic, UGens>Filters>Pitch
5 Description::
7 Vibrato is a slow frequency modulation. Consider the systematic deviation in pitch of a singer around a fundamental frequency, or a violinist whose finger wobbles in position on the fingerboard, slightly tightening and loosening the string to add shimmer to the pitch. There is often also a delay before vibrato is established on a note. This UGen models these processes; by setting more extreme settings, you can get back to the timbres of FM synthesis. You can also add in some noise to the vibrato rate and vibrato size (modulation depth) to make for a more realistic motor pattern.
9 The vibrato output is a waveform based on a squared envelope shape with four stages marking out 0.0 to 1.0, 1.0 to 0.0, 0.0 to -1.0, and -1.0 back to 0.0. Vibrato rate determines how quickly you move through these stages.
12 classmethods::
14 method::ar, kr
16 argument::freq
18 Fundamental frequency in Hertz. If the Vibrato UGen is running at audio rate, this must not be a constant, but an actual audio rate UGen (see example below)
20 argument::rate
22 Vibrato rate, speed of wobble in Hertz. Note that if this is set to a low value (and definitely with 0.0), you may never get vibrato back, since the rate input is only checked at the end of a cycle.
24 argument::depth
26 Size of vibrato frequency deviation around the fundamental, as a proportion of the fundamental. 0.02 = 2% of the fundamental.
28 argument::delay
30 Delay before vibrato is established in seconds (a singer tends to attack a note and then stabilise with vibrato, for instance).
32 argument::onset
34 Transition time in seconds from no vibrato to full vibrato after the initial delay time.
36 argument::rateVariation
38 Noise on the rate, expressed as a proportion of the rate; can change once per cycle of vibrato.
40 argument::depthVariation
42 Noise on the depth of modulation, expressed as a proportion of the depth; can change once per cycle of vibrato. The noise affects independently the up and the down part of vibrato shape within a cycle.
44 argument::iphase
46 Initial phase of vibrato modulation, allowing starting above or below the fundamental rather than on it.
48 Examples::
50 code::
52 //vibrato at 1 Hz, note the use of DC.ar UGen; a constant of 400.0 doesn't work
53 {SinOsc.ar(Vibrato.ar(DC.ar(400.0),1,0.02) )}.play
55 //compare: k-rate freq input can be a constant
56 {SinOsc.ar(Vibrato.kr(400.0,1,0.02))}.play
58 //control rate and rateVariation
59 {SinOsc.ar(Vibrato.ar(DC.ar(400.0),MouseX.kr(2.0,100.0),0.1,1.0,1.0,MouseY.kr(0.0,1.0),0.1) )}.play
61 //control depth and depthVariation
62 {SinOsc.ar(Vibrato.ar(DC.ar(400.0),LFNoise1.kr(1,3,7),MouseX.kr(0.0,1.0),1.0,1.0,MouseY.kr(0.0,1.0),0.1) )}.play