diff options
author | David Runge <dave@sleepmap.de> | 2017-04-30 19:36:14 +0200 |
---|---|---|
committer | David Runge <dave@sleepmap.de> | 2017-04-30 19:36:14 +0200 |
commit | df13df2257f98d98fa200a32fac94c043254e19f (patch) | |
tree | 1739af7b24777e1fa9534dc802196ec0accba785 | |
download | zzz-df13df2257f98d98fa200a32fac94c043254e19f.tar.gz zzz-df13df2257f98d98fa200a32fac94c043254e19f.tar.bz2 zzz-df13df2257f98d98fa200a32fac94c043254e19f.tar.xz zzz-df13df2257f98d98fa200a32fac94c043254e19f.zip |
classes/ZZZ.sc: Adding first version of base class for Expert Sleepers devices. The class functions ampToVAC and vacToAmp have been tested using a RME Babyface and the implemented ZZZHold SynthDef. Above an amplitude of 1.0 the output turns out to be logarithmic (ln), instead of linear, so anywhere above that should be used with caution, as the implemented calculation functions are only an approximation in that region.
-rw-r--r-- | classes/ZZZ.sc | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/classes/ZZZ.sc b/classes/ZZZ.sc new file mode 100644 index 0000000..a71b1c1 --- /dev/null +++ b/classes/ZZZ.sc @@ -0,0 +1,84 @@ +ZZZ{ + + classvar <cvMinLFO = -2.5, + < cvMaxLFO = 2.5, + < cvMinADSR = 0.0, + < cvMaxADSR = 8.0, + < cvMinTriggerGateClock = 0.0, + < cvMaxTriggerGateClock = 5.0, + < ampToVACConst = 6.8925, + < zzzSynth; + var <channels; + + *new{ + arg channels; + ^super.newCopyArgs(channels).init; + } + + init{ + ("Using the following channels:").postln; + channels.postln; + } + + *initClass{ + StartUp.add{ + //adding synth for percussive environments (trigger, gate, clock) + SynthDef(\ZZZPerc, { |out = 0, freq = 20000, amp = 0.0, attack = 0.001, release = 1, time = 1, curve = -4| + var signal, envelope; + envelope = EnvGen.kr(Env.perc(attack, release, amp, curve), doneAction: 2); + signal = SinOsc.ar(freq, 0, envelope); + Out.ar(out, signal); + }).add; + // adding synth for note environments (adsr, v/o) + SynthDef(\ZZZHold, { |out = 0, freq = 20000, amp = 0.0| + var signal; + signal = SinOsc.ar(freq, 0, amp); + Out.ar(out, signal); + }).add; + } + } + + /** + * Calculates voltage for supplied amplitude. + * Linear until ampToVACConst, exponential above. + * Maximum voltage: 7.68096 VAC + * @return voltage that corresponds to the amplitude supplied. + */ + *ampToVAC{ + arg amplitude; + var voltage; + if((amplitude <= 1.0), { + voltage = amplitude * ampToVACConst; + },{ + if((amplitude > 2.2), { + voltage = 2.2.log + ampToVACConst; + },{ + voltage = amplitude.log + ampToVACConst; + }); + }); + voltage.postln; + ^voltage; + } + + /** + * Calculates amplitude for supplied voltage. + * Linear until ampToVACConst. + * Maximum amplitude output: 2.2 + * @return amplitude needed to achieve the voltage supplied. + */ + *vacToAmp{ + arg voltage; + var amplitude; + if((voltage <= ampToVACConst), { + amplitude = voltage/ampToVACConst; + },{ + amplitude = (voltage-ampToVACConst).exp; + if(amplitude > 2.2, { + amplitude = 2.2; + }); + }); + amplitude.postln; + ^amplitude; + } + +} |