1 // Reverb model implementation
4 // Google Summer of Code 2007
6 // Authors: Biodun Osunkunle <biodun@videolan.org>
8 // Mentor : Jean-Baptiste Kempf <jb@videolan.org>
10 // Original written by Jezar at Dreampoint, June 2000
12 // This code is public domain
14 #include "revmodel.hpp"
19 // Tie the components to their buffers
20 combL[0].setbuffer(bufcombL1,combtuningL1);
21 combR[0].setbuffer(bufcombR1,combtuningR1);
22 combL[1].setbuffer(bufcombL2,combtuningL2);
23 combR[1].setbuffer(bufcombR2,combtuningR2);
24 combL[2].setbuffer(bufcombL3,combtuningL3);
25 combR[2].setbuffer(bufcombR3,combtuningR3);
26 combL[3].setbuffer(bufcombL4,combtuningL4);
27 combR[3].setbuffer(bufcombR4,combtuningR4);
28 combL[4].setbuffer(bufcombL5,combtuningL5);
29 combR[4].setbuffer(bufcombR5,combtuningR5);
30 combL[5].setbuffer(bufcombL6,combtuningL6);
31 combR[5].setbuffer(bufcombR6,combtuningR6);
32 combL[6].setbuffer(bufcombL7,combtuningL7);
33 combR[6].setbuffer(bufcombR7,combtuningR7);
34 combL[7].setbuffer(bufcombL8,combtuningL8);
35 combR[7].setbuffer(bufcombR8,combtuningR8);
36 allpassL[0].setbuffer(bufallpassL1,allpasstuningL1);
37 allpassR[0].setbuffer(bufallpassR1,allpasstuningR1);
38 allpassL[1].setbuffer(bufallpassL2,allpasstuningL2);
39 allpassR[1].setbuffer(bufallpassR2,allpasstuningR2);
40 allpassL[2].setbuffer(bufallpassL3,allpasstuningL3);
41 allpassR[2].setbuffer(bufallpassR3,allpasstuningR3);
42 allpassL[3].setbuffer(bufallpassL4,allpasstuningL4);
43 allpassR[3].setbuffer(bufallpassR4,allpasstuningR4);
46 allpassL[0].setfeedback(0.5f);
47 allpassR[0].setfeedback(0.5f);
48 allpassL[1].setfeedback(0.5f);
49 allpassR[1].setfeedback(0.5f);
50 allpassL[2].setfeedback(0.5f);
51 allpassR[2].setfeedback(0.5f);
52 allpassL[3].setfeedback(0.5f);
53 allpassR[3].setfeedback(0.5f);
55 setroomsize(initialroom);
58 setwidth(initialwidth);
61 // Buffer will be full of rubbish - so we MUST mute them
68 if (getmode() >= freezemode)
71 for (i = 0 ; i < numcombs ; i++)
76 for (i=0;i<numallpasses;i++)
83 void revmodel::processreplace(float *inputL, float *outputL, long numsamples, int skip)
85 float outL,outR,input;
94 input = (inputL[0] + inputR) * gain;
96 // Accumulate comb filters in parallel
97 for(i=0; i<numcombs; i++)
99 outL += combL[i].process(input);
100 outR += combR[i].process(input);
103 // Feed through allpasses in series
104 for(i=0; i<numallpasses; i++)
106 outL = allpassL[i].process(outL);
107 outR = allpassR[i].process(outR);
110 // Calculate output REPLACING anything already there
111 outputL[0] = (outL*wet1 + outR*wet2 + inputR*dry);
113 outputL[1] = (outR*wet1 + outL*wet2 + inputR*dry);
116 void revmodel::processmix(float *inputL, float *outputL, long numsamples, int skip)
118 float outL,outR,input;
127 input = (inputL[0] + inputR) * gain;
129 // Accumulate comb filters in parallel
130 for(i=0; i<numcombs; i++)
132 outL += combL[i].process(input);
133 outR += combR[i].process(input);
136 // Feed through allpasses in series
137 for(i=0; i<numallpasses; i++)
139 outL = allpassL[i].process(outL);
140 outR = allpassR[i].process(outR);
143 // Calculate output REPLACING anything already there
144 outputL[0] += (outL*wet1 + outR*wet2 + inputR*dry);
146 outputL[1] += (outR*wet1 + outL*wet2 + inputR*dry);
149 void revmodel::update()
151 // Recalculate internal values after parameter change
155 wet1 = wet*(width/2 + 0.5f);
156 wet2 = wet*((1-width)/2);
158 if (mode >= freezemode)
166 roomsize1 = roomsize;
171 for(i=0; i<numcombs; i++)
173 combL[i].setfeedback(roomsize1);
174 combR[i].setfeedback(roomsize1);
177 for(i=0; i<numcombs; i++)
179 combL[i].setdamp(damp1);
180 combR[i].setdamp(damp1);
184 // The following get/set functions are not inlined, because
185 // speed is never an issue when calling them, and also
186 // because as you develop the reverb model, you may
187 // wish to take dynamic action when they are called.
189 void revmodel::setroomsize(float value)
191 roomsize = (value*scaleroom) + offsetroom;
195 float revmodel::getroomsize()
197 return (roomsize-offsetroom)/scaleroom;
200 void revmodel::setdamp(float value)
202 damp = value*scaledamp;
206 float revmodel::getdamp()
208 return damp/scaledamp;
211 void revmodel::setwet(float value)
213 wet = value*scalewet;
217 float revmodel::getwet()
222 void revmodel::setdry(float value)
224 dry = value*scaledry;
227 float revmodel::getdry()
232 void revmodel::setwidth(float value)
238 float revmodel::getwidth()
243 void revmodel::setmode(float value)
249 float revmodel::getmode()
251 if (mode >= freezemode)