/[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 2244 by iliev, Thu Aug 18 11:32:33 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 = 200;
36      const int maxEgCount = 100; // Maximum number of v2 envelope generators      const int maxEgCount = 30; // Maximum number of v2 envelope generators
37      const int maxLfoCount = 100; // Maximum number of v2 LFOs      const int maxLfoCount = 30; // Maximum number of v2 LFOs
38            
39      class Voice;      class Voice;
40      class SfzSignalUnitRack;      class SfzSignalUnitRack;
# 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                virtual void AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth);
72                
73                inline int GetCurveCount();
74                inline ::sfz::Curve* GetCurve(int idx);
75                
76                double GetSampleRate();
77        };
78        
79        class CurveCCUnit: public CCUnit {
80            public:
81                CurveCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CCUnit(rack, l) { }
82                
83                virtual float Normalize(uint8_t val, short int curve = -1) {
84                    if (curve == -1) return val / 127.0f;
85                    return GetCurve(curve)->v[val];
86                }
87        };
88        
89        
90        
91        class SmoothCCUnit: public CurveCCUnit {
92            protected:
93                RTList<Smoother>* pSmoothers;
94            public:
95                SmoothCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CurveCCUnit(rack, l), pSmoothers(NULL) { }
96                virtual ~SmoothCCUnit();
97                
98                virtual void AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth);
99                virtual void RemoveAllCCs() { CurveCCUnit::RemoveAllCCs(); pSmoothers->clear(); }
100                virtual void InitCCList(Pool<CC>* pCCPool, Pool<Smoother>* pSmootherPool);
101                
102                void InitSmoothers(Pool<Smoother>* pSmootherPool);
103        };
104        
105        
106        class XFInCCUnit: public CCUnit {
107            public:
108                XFInCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CCUnit(rack, l) { }
109                
110                virtual bool Active() { return !pCtrls->isEmpty(); }
111                virtual void Calculate();
112                virtual void SetCrossFadeCCs(::sfz::Array<int>& loCCs, ::sfz::Array<int>& hiCCs);
113        };
114        
115        
116        class XFOutCCUnit: public XFInCCUnit {
117            public:
118                XFOutCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): XFInCCUnit(rack, l) { }
119                
120                virtual void Calculate();
121        };
122        
123        
124      template <class T>      template <class T>
125      class EGUnit : public SfzSignalUnit {      class EGUnit: public SfzSignalUnit {
126          public:          public:
127              ::sfz::EG* pEGInfo;              ::sfz::EG* pEGInfo;
128              T EG;              T EG;
129    
130              EGUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pEGInfo(NULL) { }              EGUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pEGInfo(NULL) { }
131              EGUnit(const EGUnit& Unit): SfzSignalUnit(Unit.pRack) { Copy(Unit); }              EGUnit(const EGUnit& Unit): SfzSignalUnit(Unit) { Copy(Unit); }
132              void operator=(const EGUnit& Unit) { Copy(Unit); }              void operator=(const EGUnit& Unit) { Copy(Unit); }
133                            
134              void Copy(const EGUnit& Unit) {              void Copy(const EGUnit& Unit) {
# Line 68  namespace LinuxSampler { namespace sfz { Line 138  namespace LinuxSampler { namespace sfz {
138              }              }
139    
140              virtual bool  Active() { return EG.active(); }              virtual bool  Active() { return EG.active(); }
141              virtual float GetLevel() { return EG.getLevel(); }              virtual float GetLevel() { return DelayStage() ? 0 : EG.getLevel(); }
142                            
143              virtual void EnterReleaseStage() { EG.update(EG::event_release, GetSampleRate()); }              virtual void EnterReleaseStage() { EG.update(EG::event_release, GetSampleRate()); }
144              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 173  namespace LinuxSampler { namespace sfz {
173            
174      class EGv1Unit: public EGUnit<EGADSR> {      class EGv1Unit: public EGUnit<EGADSR> {
175          public:          public:
176              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }              int depth;
177              virtual void Trigger();              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }
178      };      };
179            
180      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {
181            protected:
182                ::sfz::EG egInfo;
183            public:
184                CCUnit suAmpOnCC;
185                CCUnit suVolOnCC;
186                CCUnit suPitchOnCC;
187                CCUnit suCutoffOnCC;
188                CCUnit suResOnCC;
189                CurveCCUnit suPanOnCC;
190                
191                EGv2Unit(SfzSignalUnitRack* rack);
192                virtual void Trigger();
193        };
194        
195        class PitchEGUnit: public EGv1Unit {
196            public:
197                PitchEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
198                virtual void Trigger();
199        };
200        
201        class FilEGUnit: public EGv1Unit {
202            public:
203                FilEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
204                virtual void Trigger();
205        };
206        
207        class AmpEGUnit: public EGv1Unit {
208            public:
209                AmpEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
210                virtual void Trigger();
211        };
212        
213        class AbstractLfo {
214            public:
215                virtual float Render() = 0;
216                virtual void Update(const uint16_t& ExtControlValue) = 0;
217                virtual void Trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) = 0;
218                virtual void SetPhase(float phase) = 0;
219                virtual void SetFrequency(float Frequency, unsigned int SampleRate) = 0;
220        };
221        
222        template <class T>
223        class LfoBase: public AbstractLfo, public T {
224            public:
225                LfoBase(float Max): T(Max) { }
226                virtual float Render() { return T::render(); }
227                
228                virtual void Update(const uint16_t& ExtControlValue) { T::update(ExtControlValue); }
229                
230                virtual void Trigger (
231                    float Frequency, start_level_t StartLevel, uint16_t InternalDepth,
232                    uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate
233                ) {
234                    T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate);
235                }
236                
237                virtual void SetPhase(float phase) { T::setPhase(phase); }
238                
239                virtual void SetFrequency(float Frequency, unsigned int SampleRate) {
240                    T::setFrequency(Frequency, SampleRate);
241                }
242        };
243        
244        class LFOUnit;
245        
246        class FadeEGUnit: public EGUnit<EGADSR> {
247            public:
248                FadeEGUnit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }
249                virtual void Trigger() { }
250                virtual void EnterReleaseStage() { }
251                virtual void CancelRelease() { }
252                
253                friend class LFOUnit;
254        };
255        
256        class LFOUnit: public SfzSignalUnit, public CCSignalUnit::Listener {
257            public:
258                ::sfz::LFO*  pLfoInfo;
259                AbstractLfo* pLFO;
260                FadeEGUnit   suFadeEG;
261                SmoothCCUnit suDepthOnCC;
262                SmoothCCUnit suFreqOnCC;
263                
264                LFOUnit(SfzSignalUnitRack* rack);
265                LFOUnit(const LFOUnit& Unit);
266                void operator=(const LFOUnit& Unit) { Copy(Unit); }
267                
268                void Copy(const LFOUnit& Unit) {
269                    pLfoInfo   = Unit.pLfoInfo;
270                    suFadeEG   = Unit.suFadeEG;
271                    
272                    SfzSignalUnit::Copy(Unit);
273                }
274                
275                virtual bool  Active() { return pLfoInfo->freq > 0; }
276                virtual void  Trigger();
277                virtual void  Increment();
278                virtual float GetLevel() { return Level; }
279                
280                // CCSignalUnit::Listener interface implementation
281                virtual void ValueChanged(CCSignalUnit* pUnit);
282        };
283        
284        class LFOv1Unit: public LFOUnit {
285            public:
286                ::sfz::LFO lfoInfo;
287                LfoBase<LFOSigned> lfo;
288                
289                LFOv1Unit(SfzSignalUnitRack* rack): LFOUnit(rack), lfo(1200.0f) {
290                    pLfoInfo = &lfoInfo; pLFO = &lfo;
291                }
292                
293                virtual void Trigger();
294        };
295        
296        class LFOv2Unit: public LFOUnit {
297            protected:
298                FixedArray<AbstractLfo*> lfos;
299                LfoBase<LFOSigned>                       lfo0; // triangle
300                LfoBase<SineLFO<range_signed> >          lfo1; // sine
301                LfoBase<PulseLFO<range_unsigned, 750> >  lfo2; // pulse 75%
302                LfoBase<SquareLFO<range_signed> >        lfo3; // square
303                LfoBase<PulseLFO<range_unsigned, 250> >  lfo4; // pulse 25%
304                LfoBase<PulseLFO<range_unsigned, 125> >  lfo5; // pulse 12,5%
305                LfoBase<SawLFO<range_unsigned, true> >   lfo6; // saw up
306                LfoBase<SawLFO<range_unsigned, false> >  lfo7; // saw down
307                
308                
309            public:
310                SmoothCCUnit suVolOnCC;
311                SmoothCCUnit suPitchOnCC;
312                SmoothCCUnit suPanOnCC;
313                SmoothCCUnit suCutoffOnCC;
314                SmoothCCUnit suResOnCC;
315                
316                LFOv2Unit(SfzSignalUnitRack* rack);
317                
318                virtual void Trigger();
319        };
320        
321        class AmpLFOUnit: public LFOv1Unit {
322            public:
323                AmpLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
324                
325                virtual void Trigger();
326        };
327        
328        class PitchLFOUnit: public LFOv1Unit {
329          public:          public:
330              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }              PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
331                
332              virtual void Trigger();              virtual void Trigger();
333      };      };
334            
335        class FilLFOUnit: public LFOv1Unit {
336            public:
337                FilLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
338                
339                virtual void Trigger();
340        };
341            
342            
343      class EndpointUnit : public EndpointSignalUnit {      class EndpointUnit: public EndpointSignalUnit {
344            private:
345                float xfCoeff; // crossfade coefficient
346                float pitchVeltrackRatio;
347                
348          public:          public:
349              Voice* pVoice;              Voice* pVoice;
350                XFInCCUnit   suXFInCC;
351                XFOutCCUnit  suXFOutCC;
352                SmoothCCUnit suPanOnCC;
353    
354              EndpointUnit(SfzSignalUnitRack* rack);              EndpointUnit(SfzSignalUnitRack* rack);
355    
# Line 130  namespace LinuxSampler { namespace sfz { Line 362  namespace LinuxSampler { namespace sfz {
362              virtual float GetFilterCutoff();              virtual float GetFilterCutoff();
363              virtual float GetPitch();              virtual float GetPitch();
364              virtual float GetResonance();              virtual float GetResonance();
365                virtual float GetPan();
366                            
367              SfzSignalUnitRack* const GetRack();              SfzSignalUnitRack* const GetRack();
368                
369                virtual float CalculateResonance(float res) {
370                    return GetResonance() + res;
371                }
372                
373                virtual float CalculateFilterCutoff(float cutoff);
374      };      };
375            
376            
377      class SfzSignalUnitRack : public SignalUnitRack {      class SfzSignalUnitRack : public SignalUnitRack {
378          private:          private:
379              EndpointUnit  suEndpoint;              EndpointUnit  suEndpoint;
380              EGv1Unit      suVolEG;              AmpEGUnit     suVolEG;
381                FilEGUnit     suFilEG;
382                PitchEGUnit   suPitchEG;
383                
384                AmpLFOUnit   suAmpLFO;
385                PitchLFOUnit suPitchLFO;
386                FilLFOUnit   suFilLFO;
387                
388                // SFZ v2
389                
390                SmoothCCUnit suVolOnCC;
391                            
392              FixedArray<EGv2Unit*> EGs;              FixedArray<EGv2Unit*> EGs;
393                            
# Line 148  namespace LinuxSampler { namespace sfz { Line 397  namespace LinuxSampler { namespace sfz {
397              // used for optimization - contains only the ones that are modulating pitch              // used for optimization - contains only the ones that are modulating pitch
398              FixedArray<EGv2Unit*> pitchEGs;              FixedArray<EGv2Unit*> pitchEGs;
399                            
400                // used for optimization - contains only the ones that are modulating filter cutoff
401                FixedArray<EGv2Unit*> filEGs;
402                
403                // used for optimization - contains only the ones that are modulating resonance
404                FixedArray<EGv2Unit*> resEGs;
405                
406                // used for optimization - contains only the ones that are modulating pitch
407                FixedArray<EGv2Unit*> panEGs;
408                
409                
410                FixedArray<LFOv2Unit*> LFOs;
411                
412                // used for optimization - contains only the ones that are modulating volume
413                FixedArray<LFOv2Unit*> volLFOs;
414                
415                // used for optimization - contains only the ones that are modulating pitch
416                FixedArray<LFOv2Unit*> pitchLFOs;
417                
418                // used for optimization - contains only the ones that are modulating filter cutoff
419                FixedArray<LFOv2Unit*> filLFOs;
420                
421                // used for optimization - contains only the ones that are modulating resonance
422                FixedArray<LFOv2Unit*> resLFOs;
423                
424                // used for optimization - contains only the ones that are modulating pan
425                FixedArray<LFOv2Unit*> panLFOs;
426                
427    
428          public:          public:
429              Voice* const pVoice;              Voice* const pVoice;
# Line 163  namespace LinuxSampler { namespace sfz { Line 439  namespace LinuxSampler { namespace sfz {
439              virtual void Trigger();              virtual void Trigger();
440              virtual void EnterFadeOutStage();              virtual void EnterFadeOutStage();
441                            
442                /** Called when the engine is set and the engine's pools are ready to use. */
443                void InitRTLists();
444                
445                /** Invoked when the voice gone inactive. */
446                void Reset();
447                
448              friend class EndpointUnit;              friend class EndpointUnit;
449      };      };
450  }} // namespace LinuxSampler::sfz  }} // namespace LinuxSampler::sfz

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

  ViewVC Help
Powered by ViewVC