~ubuntu-branches/ubuntu/trusty/aeolus/trusty

« back to all changes in this revision

Viewing changes to division.h

  • Committer: Bazaar Package Importer
  • Author(s): Free Ekanayaka
  • Date: 2007-05-14 22:18:54 UTC
  • Revision ID: james.westby@ubuntu.com-20070514221854-274rj6fqs5tegu7q
Tags: upstream-0.6.6+2
ImportĀ upstreamĀ versionĀ 0.6.6+2

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
    Copyright (C) 2003 Fons Adriaensen <fons.adriaensen@skynet.be>
 
3
    
 
4
    This program is free software; you can redistribute it and/or modify
 
5
    it under the terms of the GNU General Public License as published by
 
6
    the Free Software Foundation; either version 2 of the License, or
 
7
    (at your option) any later version.
 
8
 
 
9
    This program is distributed in the hope that it will be useful,
 
10
    but WITHOUT ANY WARRANTY; without even the implied warranty of
 
11
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
12
    GNU General Public License for more details.
 
13
 
 
14
    You should have received a copy of the GNU General Public License
 
15
    along with this program; if not, write to the Free Software
 
16
    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
17
*/
 
18
 
 
19
 
 
20
#ifndef __DIVISION_H
 
21
#define __DIVISION_H
 
22
 
 
23
 
 
24
#include "asection.h"
 
25
#include "rankwave.h"
 
26
 
 
27
 
 
28
class Division
 
29
{
 
30
public:
 
31
 
 
32
    Division (Asection *asect, float fsam);
 
33
    ~Division (void);
 
34
 
 
35
    void set_rank (int ind, Rankwave *W, int pan, int del);
 
36
    void set_swell (float stat) { _swel = 0.2 + 0.8 * stat * stat; }
 
37
    void set_tfreq (float freq) { _w = 6.283184f * PERIOD * freq / _fsam; }
 
38
    void set_tmodd (float modd) { _m = modd; }
 
39
    void set_div_mask (int bits);
 
40
    void clr_div_mask (int bits);
 
41
    void set_rank_mask (int ind, int bits);
 
42
    void clr_rank_mask (int ind, int bits);
 
43
    void trem_on (void)  { _trem = 1; }
 
44
    void trem_off (void) { _trem = 2; }
 
45
 
 
46
    void process (void);
 
47
    void update (int note, int mask);
 
48
    void update (unsigned char *keys);
 
49
 
 
50
private:
 
51
   
 
52
    Asection  *_asect;
 
53
    Rankwave  *_ranks [NRANKS];
 
54
    int        _nrank;
 
55
    int        _dmask;
 
56
    int        _trem;
 
57
    float      _fsam;
 
58
    float      _swel;
 
59
    float      _gain;
 
60
    float      _w;    
 
61
    float      _c;
 
62
    float      _s;
 
63
    float      _m;
 
64
    float      _buff [NCHANN * PERIOD];
 
65
};
 
66
 
 
67
 
 
68
#endif
 
69