/[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 2220 by iliev, Thu Jul 28 15:47:51 2011 UTC revision 2235 by iliev, Wed Aug 10 19:40:39 2011 UTC
# Line 27  Line 27 
27  #include "EG.h"  #include "EG.h"
28  #include "EGADSR.h"  #include "EGADSR.h"
29  #include "../common/AbstractVoice.h"  #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 50  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                Smoother Smoothers[128];
94            public:
95                SmoothCCUnit(SfzSignalUnitRack* rack, Listener* l = NULL): CurveCCUnit(rack, l) { }
96                
97                virtual void AddSmoothCC(uint8_t Controller, float Influence, short int Curve, float Smooth);
98        };
99        
100        
101      template <class T>      template <class T>
102      class EGUnit: public SfzSignalUnit {      class EGUnit: public SfzSignalUnit {
103          public:          public:
# Line 106  namespace LinuxSampler { namespace sfz { Line 152  namespace LinuxSampler { namespace sfz {
152          public:          public:
153              int depth;              int depth;
154              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }
             virtual void Trigger();  
155      };      };
156            
157      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {      class EGv2Unit: public EGUnit< ::LinuxSampler::sfz::EG> {
158            protected:
159                ::sfz::EG egInfo;
160          public:          public:
161              EGv2Unit(SfzSignalUnitRack* rack): EGUnit< ::LinuxSampler::sfz::EG>(rack) { }              CCUnit suAmpOnCC;
162                CCUnit suVolOnCC;
163                CCUnit suPitchOnCC;
164                CCUnit suCutoffOnCC;
165                CCUnit suResOnCC;
166                
167                EGv2Unit(SfzSignalUnitRack* rack);
168              virtual void Trigger();              virtual void Trigger();
169      };      };
170            
# Line 121  namespace LinuxSampler { namespace sfz { Line 174  namespace LinuxSampler { namespace sfz {
174              virtual void Trigger();              virtual void Trigger();
175      };      };
176            
177      class LFOUnit: public SfzSignalUnit {      class FilEGUnit: public EGv1Unit {
178            public:
179                FilEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
180                virtual void Trigger();
181        };
182        
183        class AmpEGUnit: public EGv1Unit {
184            public:
185                AmpEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
186                virtual void Trigger();
187        };
188        
189        class AbstractLfo {
190            public:
191                virtual float Render() = 0;
192                virtual void Update(const uint16_t& ExtControlValue) = 0;
193                virtual void Trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) = 0;
194                virtual void SetPhase(float phase) = 0;
195                virtual void SetFrequency(float Frequency, unsigned int SampleRate) = 0;
196        };
197        
198        template <class T>
199        class LfoBase: public AbstractLfo, public T {
200          public:          public:
201              ::sfz::LFO* pLfoInfo;              LfoBase(float Max): T(Max) { }
202              LFOSigned lfo;              virtual float Render() { return T::render(); }
203                
204                virtual void Update(const uint16_t& ExtControlValue) { T::update(ExtControlValue); }
205                            
206              LFOUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pLfoInfo(NULL), lfo(1200.0f) { }              virtual void Trigger (
207              LFOUnit(const LFOUnit& Unit): SfzSignalUnit(Unit), lfo(1200.0f) { Copy(Unit); }                  float Frequency, start_level_t StartLevel, uint16_t InternalDepth,
208                    uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate
209                ) {
210                    T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate);
211                }
212                
213                virtual void SetPhase(float phase) { T::setPhase(phase); }
214                
215                virtual void SetFrequency(float Frequency, unsigned int SampleRate) {
216                    T::setFrequency(Frequency, SampleRate);
217                }
218        };
219        
220        class LFOUnit;
221        
222        class FadeEGUnit: public EGUnit<EGADSR> {
223            public:
224                FadeEGUnit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }
225                virtual void Trigger() { }
226                virtual void EnterReleaseStage() { }
227                virtual void CancelRelease() { }
228                
229                friend class LFOUnit;
230        };
231        
232        class LFOUnit: public SfzSignalUnit, public CCSignalUnit::Listener {
233            public:
234                ::sfz::LFO*  pLfoInfo;
235                AbstractLfo* pLFO;
236                FadeEGUnit   suFadeEG;
237                SmoothCCUnit suDepthOnCC;
238                SmoothCCUnit suFreqOnCC;
239                
240                LFOUnit(SfzSignalUnitRack* rack);
241                LFOUnit(const LFOUnit& Unit);
242              void operator=(const LFOUnit& Unit) { Copy(Unit); }              void operator=(const LFOUnit& Unit) { Copy(Unit); }
243                            
244              void Copy(const LFOUnit& Unit) {              void Copy(const LFOUnit& Unit) {
245                  pLfoInfo = Unit.pLfoInfo;                  pLfoInfo   = Unit.pLfoInfo;
246                    suFadeEG   = Unit.suFadeEG;
247                                    
248                  SfzSignalUnit::Copy(Unit);                  SfzSignalUnit::Copy(Unit);
249              }              }
250                            
251              virtual bool  Active() { return true; }              virtual bool  Active() { return pLfoInfo->freq > 0; }
252              virtual void  Trigger();              virtual void  Trigger();
253              virtual void  Increment();              virtual void  Increment();
254              virtual float GetLevel() { return Level; }              virtual float GetLevel() { return Level; }
255                virtual void  ValueChanged(CCSignalUnit* pUnit);
256        };
257        
258        class LFOv1Unit: public LFOUnit {
259            public:
260                ::sfz::LFO lfoInfo;
261                LfoBase<LFOSigned> lfo;
262                
263                LFOv1Unit(SfzSignalUnitRack* rack): LFOUnit(rack), lfo(1200.0f) {
264                    pLfoInfo = &lfoInfo; pLFO = &lfo;
265                }
266                
267                virtual void Trigger();
268      };      };
269            
270      class LFOv2Unit: public LFOUnit {      class LFOv2Unit: public LFOUnit {
271            protected:
272                FixedArray<AbstractLfo*> lfos;
273                LfoBase<LFOSigned>                       lfo0; // triangle
274                LfoBase<SineLFO<range_signed> >          lfo1; // sine
275                LfoBase<PulseLFO<range_unsigned, 750> >  lfo2; // pulse 75%
276                LfoBase<SquareLFO<range_signed> >        lfo3; // square
277                LfoBase<PulseLFO<range_unsigned, 250> >  lfo4; // pulse 25%
278                LfoBase<PulseLFO<range_unsigned, 125> >  lfo5; // pulse 12,5%
279                LfoBase<SawLFO<range_unsigned, true> >   lfo6; // saw up
280                LfoBase<SawLFO<range_unsigned, false> >  lfo7; // saw down
281                
282                
283            public:
284                SmoothCCUnit suVolOnCC;
285                SmoothCCUnit suPitchOnCC;
286                SmoothCCUnit suPanOnCC;
287                SmoothCCUnit suCutoffOnCC;
288                SmoothCCUnit suResOnCC;
289                
290                LFOv2Unit(SfzSignalUnitRack* rack);
291                
292                virtual void Trigger();
293        };
294        
295        class AmpLFOUnit: public LFOv1Unit {
296          public:          public:
297              LFOv2Unit(SfzSignalUnitRack* rack): LFOUnit(rack) { }              AmpLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
298                            
299              virtual void Trigger();              virtual void Trigger();
300      };      };
301            
302        class PitchLFOUnit: public LFOv1Unit {
303            public:
304                PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
305                
306                virtual void Trigger();
307        };
308            
309        class FilLFOUnit: public LFOv1Unit {
310            public:
311                FilLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
312                
313                virtual void Trigger();
314        };
315            
316      class EndpointUnit : public EndpointSignalUnit {      
317        class EndpointUnit: public EndpointSignalUnit {
318          public:          public:
319              Voice* pVoice;              Voice* pVoice;
320    
# Line 173  namespace LinuxSampler { namespace sfz { Line 336  namespace LinuxSampler { namespace sfz {
336              virtual float CalculateResonance(float res) {              virtual float CalculateResonance(float res) {
337                  return GetResonance() + res;                  return GetResonance() + res;
338              }              }
339                
340                virtual float CalculateFilterCutoff(float cutoff);
341      };      };
342            
343            
344      class SfzSignalUnitRack : public SignalUnitRack {      class SfzSignalUnitRack : public SignalUnitRack {
345          private:          private:
346              EndpointUnit  suEndpoint;              EndpointUnit  suEndpoint;
347              EGv1Unit      suVolEG;              AmpEGUnit     suVolEG;
348                FilEGUnit     suFilEG;
349              PitchEGUnit   suPitchEG;              PitchEGUnit   suPitchEG;
350                            
351                AmpLFOUnit   suAmpLFO;
352                PitchLFOUnit suPitchLFO;
353                FilLFOUnit   suFilLFO;
354                
355                // SFZ v2
356                
357                SmoothCCUnit suVolOnCC;
358                
359              FixedArray<EGv2Unit*> EGs;              FixedArray<EGv2Unit*> EGs;
360                            
361              // used for optimization - contains only the ones that are modulating volume              // used for optimization - contains only the ones that are modulating volume
# Line 190  namespace LinuxSampler { namespace sfz { Line 364  namespace LinuxSampler { namespace sfz {
364              // used for optimization - contains only the ones that are modulating pitch              // used for optimization - contains only the ones that are modulating pitch
365              FixedArray<EGv2Unit*> pitchEGs;              FixedArray<EGv2Unit*> pitchEGs;
366                            
367                // used for optimization - contains only the ones that are modulating filter cutoff
368                FixedArray<EGv2Unit*> filEGs;
369                
370                // used for optimization - contains only the ones that are modulating filter cutoff
371                FixedArray<EGv2Unit*> resEGs;
372                
373                            
374              FixedArray<LFOv2Unit*> LFOs;              FixedArray<LFOv2Unit*> LFOs;
375                            
376                // used for optimization - contains only the ones that are modulating volume
377                FixedArray<LFOv2Unit*> volLFOs;
378                
379                // used for optimization - contains only the ones that are modulating pitch
380                FixedArray<LFOv2Unit*> pitchLFOs;
381                
382              // used for optimization - contains only the ones that are modulating filter cutoff              // used for optimization - contains only the ones that are modulating filter cutoff
383              FixedArray<LFOv2Unit*> filLFOs;              FixedArray<LFOv2Unit*> filLFOs;
384                            

Legend:
Removed from v.2220  
changed lines
  Added in v.2235

  ViewVC Help
Powered by ViewVC