summaryrefslogtreecommitdiff
path: root/muse/synti/zynaddsubfx/Effects/Reverb.h
blob: 99c9890cf6086c3a6e737d5de98db73b6b752dcd (plain)
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/*
  ZynAddSubFX - a software synthesizer
 
  Reverb.h - Reverberation effect
  Copyright (C) 2002-2005 Nasca Octavian Paul
  Author: Nasca Octavian Paul

  This program is free software; you can redistribute it and/or modify
  it under the terms of version 2 of the GNU General Public License 
  as published by the Free Software Foundation.

  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License (version 2) for more details.

  You should have received a copy of the GNU General Public License (version 2)
  along with this program; if not, write to the Free Software Foundation,
  Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA

*/

#ifndef REVERB_H
#define REVERB_H


#include "../globals.h"
#include "../DSP/AnalogFilter.h"
#include "Effect.h"

#define REV_COMBS 8
#define REV_APS 4

class Reverb:public Effect {
    public:
	Reverb(int insertion,REALTYPE *efxoutl_,REALTYPE *efxoutr_);
	~Reverb();
	void out(REALTYPE *smps_l,REALTYPE *smps_r);
	void cleanup();

        void setpreset(unsigned char npreset);
	void changepar(int npar,unsigned char value);
	unsigned char getpar(int npar);

    private:
	//Parametrii
	//Amount of the reverb,
	unsigned char Pvolume;

	//LefT/Right Panning
	unsigned char Ppan;

	//duration of reverb
	unsigned char Ptime;

	//Initial delay 
	unsigned char Pidelay;

	//Initial delay feedback
	unsigned char Pidelayfb;

	//delay between ER/Reverbs
	unsigned char Prdelay;

	//EarlyReflections/Reverb Balance
	unsigned char Perbalance;

	//HighPassFilter 
	unsigned char Plpf;

	//LowPassFilter
	unsigned char Phpf;

	//Low/HighFrequency Damping
	unsigned char Plohidamp;// 0..63 lpf,64=off,65..127=hpf(TODO)

	//Reverb type
	unsigned char Ptype;

	//Room Size
	unsigned char Proomsize;

	//parameter control
	void setvolume(unsigned char Pvolume);
	void setpan(unsigned char Ppan);
	void settime(unsigned char Ptime);
	void setlohidamp(unsigned char Plohidamp);
	void setidelay(unsigned char Pidelay);
	void setidelayfb(unsigned char Pidelayfb);
	void sethpf(unsigned char Phpf);
	void setlpf(unsigned char Plpf);
	void settype(unsigned char Ptype);
	void setroomsize(unsigned char Proomsize);
	
	REALTYPE pan,erbalance;
	//Parametrii 2	
	int lohidamptype;//0=disable,1=highdamp(lowpass),2=lowdamp(highpass)
	int idelaylen,rdelaylen;
	int idelayk;
	REALTYPE lohifb,idelayfb,roomsize,rs;//rs is used to "normalise" the volume according to the roomsize
	int comblen[REV_COMBS*2];		
	int aplen[REV_APS*2];
	
	//Valorile interne
	
	REALTYPE *comb[REV_COMBS*2];
	
	int combk[REV_COMBS*2];
	REALTYPE combfb[REV_COMBS*2];//feedback-ul fiecarui filtru "comb"
	REALTYPE lpcomb[REV_COMBS*2];//pentru Filtrul LowPass

	REALTYPE *ap[REV_APS*2];
	
	int apk[REV_APS*2];
	
	REALTYPE *idelay;
	AnalogFilter *lpf,*hpf;//filters
	REALTYPE *inputbuf;
	
	void processmono(int ch,REALTYPE *output);
};




#endif