~ubuntu-branches/ubuntu/breezy/muse/breezy

« back to all changes in this revision

Viewing changes to synti/stklib/FM4Alg3.cpp

  • Committer: Bazaar Package Importer
  • Author(s): Daniel Kobras
  • Date: 2004-02-07 15:18:22 UTC
  • mfrom: (1.1.1 upstream)
  • Revision ID: james.westby@ubuntu.com-20040207151822-es27xxkzbcxkebjm
Tags: 0.6.3-1
* New upstream version.
* Added patches:
  + [10_alsa_init_fix] New, from upstream CVS.
    Initialize direction variable when setting Alsa parameters.
  + [10_canvas_translation_fix] New, from upstream CVS.
    Do not translate tooltips twice in canvas popup.
  + [10_checkbox_fix] New, from upstream CVS.
    Use proper set/test methods on metronome checkboxes.
  + [10_html_doc_cleanup] New.
    Fix links and HTML errors in documentation.
  + [20_allow_system_timer] New.
    The new upstream version fails by default if the real-time clock
    could not be accessed (usually the case when not running suid-root).
    This patch reverts the old behaviour of falling back to the more
    inaccurate system timer.
* Updated patches:
  + [11_PIC_fixes_fixup] Rediffed.
* Removed patches:
  + [20_no_atomic_asm] Merged upstream.
* debian/compat: Splice out debhelper compatibility level from rules file.
* debian/control: Build-depend on latest jack release by default.
  Closes: #228788
* debian/control: Bump standards version.
* debian/control: Use auto-generated debconf dependency via misc:Depends.
* debian/control: Minor tweaks to the long description.
* debian/control: Tighten fluidsynth build dependency to sane version.
* debian/muse.doc-base: New. Register HTML documentation with doc-base.
* debian/templates: Tiny rewording, and typo fix.
* debian/templates, debian/po/*: Switch to po-debconf for translations.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/******************************************/
2
 
/*  Algorithm 3 (TX81Z) Subclass of       */ 
3
 
/*  4 Operator FM Synth                   */
4
 
/*  by Perry R. Cook, 1995-96             */ 
5
 
/*                                        */
6
 
/*  Alg 3 is :          4--\              */
7
 
/*                  3-->2-- + -->1-->Out  */
8
 
/*                                        */
9
 
/*  Controls: control1 = total mod index  */
10
 
/*            control2 = crossfade of two */
11
 
/*                          modulators    */
12
 
/*            control3 = LFO speed        */
13
 
/*            modWheel = LFO amount       */
14
 
/*                                        */
15
 
/******************************************/
16
 
 
17
 
#include "FM4Alg3.h"
18
 
 
19
 
FM4Alg3 :: FM4Alg3() : FM4Op()
20
 
{
21
 
        /*  We still don't make the waves here yet, because */
22
 
        /*  we still don't know what they will be.          */
23
 
}  
24
 
 
25
 
FM4Alg3 :: ~FM4Alg3()
26
 
{
27
 
}
28
 
 
29
 
MY_FLOAT FM4Alg3 :: tick()
30
 
{
31
 
    MY_FLOAT temp;
32
 
 
33
 
    temp = vibWave->tick() * modDepth * (MY_FLOAT) 0.2;    
34
 
    waves[0]->setFreq(baseFreq * ((MY_FLOAT) 1.0 + temp) * ratios[0]);
35
 
    waves[1]->setFreq(baseFreq * ((MY_FLOAT) 1.0 + temp) * ratios[1]);
36
 
    waves[2]->setFreq(baseFreq * ((MY_FLOAT) 1.0 + temp) * ratios[2]);
37
 
    waves[3]->setFreq(baseFreq * ((MY_FLOAT) 1.0 + temp) * ratios[3]);
38
 
    
39
 
    temp = gains[2] * adsr[2]->tick() * waves[2]->tick();
40
 
    waves[1]->addPhaseOffset(temp);
41
 
    
42
 
    waves[3]->addPhaseOffset(twozero->lastOut());
43
 
    temp = ((MY_FLOAT) 1.0 - (control2 * (MY_FLOAT) 0.5)) * 
44
 
                                gains[3] * adsr[3]->tick() * waves[3]->tick();
45
 
    twozero->tick(temp);
46
 
    
47
 
    temp += control2 * (MY_FLOAT) 0.5 * gains[1] * adsr[1]->tick() * waves[1]->tick();
48
 
    temp = temp * control1;
49
 
    
50
 
    waves[0]->addPhaseOffset(temp);
51
 
    temp = gains[0] * adsr[0]->tick() * waves[0]->tick();
52
 
    
53
 
    lastOutput = temp * (MY_FLOAT) 0.5;
54
 
    return lastOutput;
55
 
}
56