/[svn]/linuxsampler/trunk/src/engines/sfz/SfzSignalUnitRack.h
ViewVC logotype

Diff of /linuxsampler/trunk/src/engines/sfz/SfzSignalUnitRack.h

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 2218 by iliev, Thu Jul 28 08:05:57 2011 UTC revision 2230 by iliev, Fri Aug 5 17:59:10 2011 UTC
# Line 26  Line 26 
26  #include "../common/SignalUnitRack.h"  #include "../common/SignalUnitRack.h"
27  #include "EG.h"  #include "EG.h"
28  #include "EGADSR.h"  #include "EGADSR.h"
29    #include "../common/AbstractVoice.h"
30    #include "../common/PulseLFO.h"
31    #include "../common/SawLFO.h"
32    #include "../common/SineLFO.h"
33    
34  namespace LinuxSampler { namespace sfz {  namespace LinuxSampler { namespace sfz {
35      const int MaxUnitCount = 1000;      const int MaxUnitCount = 1000;
# Line 49  namespace LinuxSampler { namespace sfz { Line 53  namespace LinuxSampler { namespace sfz {
53              }              }
54                            
55              double GetSampleRate();              double GetSampleRate();
56                float  GetInfluence(ArrayList< ::sfz::CC>& cc);
57      };      };
58            
59        
60        class CCUnit: public CCSignalUnit {
61            public:
62                Voice* pVoice;
63    
64                CCUnit(SfzSignalUnitRack* rack, Listener* l = NULL);
65                
66                virtual void Trigger();
67                
68                void SetCCs(::sfz::Array<int>& pCC);
69                void SetCCs(ArrayList< ::sfz::CC>& cc);
70                
71                inline int GetCurveCount();
72                inline ::sfz::Curve* GetCurve(int idx);
73        };
74        
75        class CurveCCUnit: public CCUnit {
76            public:
77                CurveCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CCUnit(rack, l) { }
78                
79                virtual void Calculate() {
80                    Level = 0;
81                    for (int i = 0; i < Ctrls.size(); i++) {
82                        if (Ctrls[i].Value == 0) continue;
83                        if (Ctrls[i].Curve == -1) {
84                            Level += (Ctrls[i].Value / 127.0f) * Ctrls[i].Influence;
85                        } else {
86                            Level += GetCurve(Ctrls[i].Curve)->v[Ctrls[i].Value] * Ctrls[i].Influence;
87                        }
88                    }
89                }
90        };
91        
92        
93      template <class T>      template <class T>
94      class EGUnit : public SfzSignalUnit {      class EGUnit: public SfzSignalUnit {
95          public:          public:
96              ::sfz::EG* pEGInfo;              ::sfz::EG* pEGInfo;
97              T EG;              T EG;
98    
99              EGUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pEGInfo(NULL) { }              EGUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pEGInfo(NULL) { }
100              EGUnit(const EGUnit& Unit): SfzSignalUnit(Unit.pRack) { Copy(Unit); }              EGUnit(const EGUnit& Unit): SfzSignalUnit(Unit) { Copy(Unit); }
101              void operator=(const EGUnit& Unit) { Copy(Unit); }              void operator=(const EGUnit& Unit) { Copy(Unit); }
102                            
103              void Copy(const EGUnit& Unit) {              void Copy(const EGUnit& Unit) {
# Line 68  namespace LinuxSampler { namespace sfz { Line 107  namespace LinuxSampler { namespace sfz {
107              }              }
108    
109              virtual bool  Active() { return EG.active(); }              virtual bool  Active() { return EG.active(); }
110              virtual float GetLevel() { return EG.getLevel(); }              virtual float GetLevel() { return DelayStage() ? 0 : EG.getLevel(); }
111                            
112              virtual void EnterReleaseStage() { EG.update(EG::event_release, GetSampleRate()); }              virtual void EnterReleaseStage() { EG.update(EG::event_release, GetSampleRate()); }
113              virtual void CancelRelease() { EG.update(EG::event_cancel_release, GetSampleRate()); }              virtual void CancelRelease() { EG.update(EG::event_cancel_release, GetSampleRate()); }
# Line 103  namespace LinuxSampler { namespace sfz { Line 142  namespace LinuxSampler { namespace sfz {
142            
143      class EGv1Unit: public EGUnit<EGADSR> {      class EGv1Unit: public EGUnit<EGADSR> {
144          public:          public:
145              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }              int depth;
146              virtual void Trigger();              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }
147      };      };
148            
149      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {
150            protected:
151                ::sfz::EG egInfo;
152          public:          public:
153              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }
154              virtual void Trigger();              virtual void Trigger();
155      };      };
156            
157        class PitchEGUnit: public EGv1Unit {
158            public:
159                PitchEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
160                virtual void Trigger();
161        };
162            
163        class FilEGUnit: public EGv1Unit {
164            public:
165                FilEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
166                virtual void Trigger();
167        };
168            
169      class EndpointUnit : public EndpointSignalUnit {      class AmpEGUnit: public EGv1Unit {
170            public:
171                AmpEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
172                virtual void Trigger();
173        };
174        
175        class AbstractLfo {
176            public:
177                virtual float Render() = 0;
178                virtual void Update(const uint16_t& ExtControlValue) = 0;
179                virtual void Trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) = 0;
180                virtual void SetPhase(float phase) = 0;
181                virtual void SetFrequency(float Frequency, unsigned int SampleRate) = 0;
182        };
183        
184        template <class T>
185        class LfoBase: public AbstractLfo, public T {
186            public:
187                LfoBase(float Max): T(Max) { }
188                virtual float Render() { return T::render(); }
189                
190                virtual void Update(const uint16_t& ExtControlValue) { T::update(ExtControlValue); }
191                
192                virtual void Trigger (
193                    float Frequency, start_level_t StartLevel, uint16_t InternalDepth,
194                    uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate
195                ) {
196                    T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate);
197                }
198                
199                virtual void SetPhase(float phase) { T::setPhase(phase); }
200                
201                virtual void SetFrequency(float Frequency, unsigned int SampleRate) {
202                    T::setFrequency(Frequency, SampleRate);
203                }
204        };
205        
206        class LFOUnit;
207        
208        class FadeEGUnit: public EGUnit<EGADSR> {
209            public:
210                FadeEGUnit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }
211                virtual void Trigger() { }
212                virtual void EnterReleaseStage() { }
213                virtual void CancelRelease() { }
214                
215                friend class LFOUnit;
216        };
217        
218        class LFOUnit: public SfzSignalUnit, public CCSignalUnit::Listener {
219            public:
220                ::sfz::LFO*  pLfoInfo;
221                AbstractLfo* pLFO;
222                FadeEGUnit   suFadeEG;
223                CCUnit       suFreqOnCC;
224                
225                LFOUnit(SfzSignalUnitRack* rack);
226                LFOUnit(const LFOUnit& Unit);
227                void operator=(const LFOUnit& Unit) { Copy(Unit); }
228                
229                void Copy(const LFOUnit& Unit) {
230                    pLfoInfo   = Unit.pLfoInfo;
231                    suFadeEG   = Unit.suFadeEG;
232                    
233                    SfzSignalUnit::Copy(Unit);
234                }
235                
236                virtual bool  Active() { return pLfoInfo->freq > 0; }
237                virtual void  Trigger();
238                virtual void  Increment();
239                virtual float GetLevel() { return Level; }
240                virtual void  ValueChanged(CCSignalUnit* pUnit);
241        };
242        
243        class LFOv1Unit: public LFOUnit {
244            public:
245                ::sfz::LFO lfoInfo;
246                LfoBase<LFOSigned> lfo;
247                
248                LFOv1Unit(SfzSignalUnitRack* rack): LFOUnit(rack), lfo(1200.0f) {
249                    pLfoInfo = &lfoInfo; pLFO = &lfo;
250                }
251                
252                virtual void Trigger();
253        };
254        
255        class LFOv2Unit: public LFOUnit {
256            protected:
257                FixedArray<AbstractLfo*> lfos;
258                LfoBase<LFOSigned>                       lfo0; // triangle
259                LfoBase<SineLFO<range_signed> >          lfo1; // sine
260                LfoBase<PulseLFO<range_unsigned, 750> >  lfo2; // pulse 75%
261                LfoBase<SquareLFO<range_signed> >        lfo3; // square
262                LfoBase<PulseLFO<range_unsigned, 250> >  lfo4; // pulse 25%
263                LfoBase<PulseLFO<range_unsigned, 125> >  lfo5; // pulse 12,5%
264                LfoBase<SawLFO<range_unsigned, true> >   lfo6; // saw up
265                LfoBase<SawLFO<range_unsigned, false> >  lfo7; // saw down
266                
267                
268            public:
269                CCUnit suPitchOnCC;
270                
271                LFOv2Unit(SfzSignalUnitRack* rack);
272                
273                virtual void Trigger();
274        };
275        
276        class AmpLFOUnit: public LFOv1Unit {
277            public:
278                AmpLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
279                
280                virtual void Trigger();
281        };
282        
283        class PitchLFOUnit: public LFOv1Unit {
284            public:
285                CCUnit suDepthCC;
286                
287                PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack), suDepthCC(rack) { }
288                
289                virtual void Trigger();
290        };
291        
292        class FilLFOUnit: public LFOv1Unit {
293            public:
294                FilLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
295                
296                virtual void Trigger();
297        };
298        
299        
300        class EndpointUnit: public EndpointSignalUnit {
301          public:          public:
302              Voice* pVoice;              Voice* pVoice;
303    
# Line 130  namespace LinuxSampler { namespace sfz { Line 312  namespace LinuxSampler { namespace sfz {
312              virtual float GetFilterCutoff();              virtual float GetFilterCutoff();
313              virtual float GetPitch();              virtual float GetPitch();
314              virtual float GetResonance();              virtual float GetResonance();
315                virtual float GetPan();
316                            
317              SfzSignalUnitRack* const GetRack();              SfzSignalUnitRack* const GetRack();
318                
319                virtual float CalculateResonance(float res) {
320                    return GetResonance() + res;
321                }
322      };      };
323            
324            
325      class SfzSignalUnitRack : public SignalUnitRack {      class SfzSignalUnitRack : public SignalUnitRack {
326          private:          private:
327              EndpointUnit  suEndpoint;              EndpointUnit  suEndpoint;
328              EGv1Unit      suVolEG;              AmpEGUnit     suVolEG;
329                FilEGUnit     suFilEG;
330                PitchEGUnit   suPitchEG;
331                
332                AmpLFOUnit   suAmpLFO;
333                PitchLFOUnit suPitchLFO;
334                FilLFOUnit   suFilLFO;
335                
336                // SFZ v2
337                
338                CurveCCUnit suVolOnCC;
339                            
340              FixedArray<EGv2Unit*> EGs;              FixedArray<EGv2Unit*> EGs;
341                            
# Line 148  namespace LinuxSampler { namespace sfz { Line 345  namespace LinuxSampler { namespace sfz {
345              // used for optimization - contains only the ones that are modulating pitch              // used for optimization - contains only the ones that are modulating pitch
346              FixedArray<EGv2Unit*> pitchEGs;              FixedArray<EGv2Unit*> pitchEGs;
347                            
348                
349                FixedArray<LFOv2Unit*> LFOs;
350                
351                // used for optimization - contains only the ones that are modulating pitch
352                FixedArray<LFOv2Unit*> pitchLFOs;
353                
354                // used for optimization - contains only the ones that are modulating filter cutoff
355                FixedArray<LFOv2Unit*> filLFOs;
356                
357                // used for optimization - contains only the ones that are modulating resonance
358                FixedArray<LFOv2Unit*> resLFOs;
359                
360                // used for optimization - contains only the ones that are modulating pan
361                FixedArray<LFOv2Unit*> panLFOs;
362                
363    
364          public:          public:
365              Voice* const pVoice;              Voice* const pVoice;

Legend:
Removed from v.2218  
changed lines
  Added in v.2230

  ViewVC Help
Powered by ViewVC