/[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 2223 by iliev, Fri Jul 29 13:39:58 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 52  namespace LinuxSampler { namespace sfz { Line 56  namespace LinuxSampler { namespace sfz {
56      };      };
57            
58      template <class T>      template <class T>
59      class EGUnit : public SfzSignalUnit {      class EGUnit: public SfzSignalUnit {
60          public:          public:
61              ::sfz::EG* pEGInfo;              ::sfz::EG* pEGInfo;
62              T EG;              T EG;
63    
64              EGUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pEGInfo(NULL) { }              EGUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pEGInfo(NULL) { }
65              EGUnit(const EGUnit& Unit): SfzSignalUnit(Unit.pRack) { Copy(Unit); }              EGUnit(const EGUnit& Unit): SfzSignalUnit(Unit) { Copy(Unit); }
66              void operator=(const EGUnit& Unit) { Copy(Unit); }              void operator=(const EGUnit& Unit) { Copy(Unit); }
67                            
68              void Copy(const EGUnit& Unit) {              void Copy(const EGUnit& Unit) {
# Line 68  namespace LinuxSampler { namespace sfz { Line 72  namespace LinuxSampler { namespace sfz {
72              }              }
73    
74              virtual bool  Active() { return EG.active(); }              virtual bool  Active() { return EG.active(); }
75              virtual float GetLevel() { return EG.getLevel(); }              virtual float GetLevel() { return DelayStage() ? 0 : EG.getLevel(); }
76                            
77              virtual void EnterReleaseStage() { EG.update(EG::event_release, GetSampleRate()); }              virtual void EnterReleaseStage() { EG.update(EG::event_release, GetSampleRate()); }
78              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 107  namespace LinuxSampler { namespace sfz {
107            
108      class EGv1Unit: public EGUnit<EGADSR> {      class EGv1Unit: public EGUnit<EGADSR> {
109          public:          public:
110              EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack) { }              int depth;
111                EGv1Unit(SfzSignalUnitRack* rack): EGUnit<EGADSR>(rack), depth(0) { }
112              virtual void Trigger();              virtual void Trigger();
113      };      };
114            
# Line 113  namespace LinuxSampler { namespace sfz { Line 118  namespace LinuxSampler { namespace sfz {
118              virtual void Trigger();              virtual void Trigger();
119      };      };
120            
121        class PitchEGUnit: public EGv1Unit {
122            public:
123                PitchEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
124                virtual void Trigger();
125        };
126        
127        class FilEGUnit: public EGv1Unit {
128            public:
129                FilEGUnit(SfzSignalUnitRack* rack): EGv1Unit(rack) { }
130                virtual void Trigger();
131        };
132        
133        class AbstractLfo {
134            public:
135                virtual float Render() = 0;
136                virtual void Update(const uint16_t& ExtControlValue) = 0;
137                virtual void Trigger(float Frequency, start_level_t StartLevel, uint16_t InternalDepth, uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate) = 0;
138        };
139        
140        template <class T>
141        class LfoBase: public AbstractLfo, public T {
142            public:
143                LfoBase(float Max): T(Max) { }
144                virtual float Render() { return T::render(); }
145                
146                virtual void Update(const uint16_t& ExtControlValue) { T::update(ExtControlValue); }
147                
148                virtual void Trigger (
149                    float Frequency, start_level_t StartLevel, uint16_t InternalDepth,
150                    uint16_t ExtControlDepth, bool FlipPhase, unsigned int SampleRate
151                ) {
152                    T::trigger(Frequency, StartLevel, InternalDepth, ExtControlDepth, FlipPhase, SampleRate);
153                }
154        };
155        
156        class LFOUnit: public SfzSignalUnit {
157            public:
158                ::sfz::LFO* pLfoInfo;
159                AbstractLfo* pLFO;
160                
161                LFOUnit(SfzSignalUnitRack* rack): SfzSignalUnit(rack), pLfoInfo(NULL), pLFO(NULL) { }
162                LFOUnit(const LFOUnit& Unit): SfzSignalUnit(Unit) { Copy(Unit); }
163                void operator=(const LFOUnit& Unit) { Copy(Unit); }
164                
165                void Copy(const LFOUnit& Unit) {
166                    pLfoInfo = Unit.pLfoInfo;
167                    
168                    SfzSignalUnit::Copy(Unit);
169                }
170                
171                virtual bool  Active() { return true; }
172                virtual void  Trigger();
173                virtual void  Increment();
174                virtual float GetLevel() { return Level; }
175        };
176        
177        class LFOv1Unit: public LFOUnit {
178            public:
179                ::sfz::LFO lfoInfo;
180                LfoBase<LFOSigned> lfo;
181                
182                LFOv1Unit(SfzSignalUnitRack* rack): LFOUnit(rack), lfo(1200.0f) {
183                    pLfoInfo = &lfoInfo; pLFO = &lfo;
184                }
185                
186                virtual void Trigger();
187        };
188        
189        class LFOv2Unit: public LFOUnit {
190            protected:
191                FixedArray<AbstractLfo*> lfos;
192                LfoBase<LFOSigned>                       lfo0; // triangle
193                LfoBase<SineLFO<range_signed> >          lfo1; // sine
194                LfoBase<PulseLFO<range_unsigned, 750> >  lfo2; // pulse 75%
195                LfoBase<SquareLFO<range_signed> >        lfo3; // square
196                LfoBase<PulseLFO<range_unsigned, 250> >  lfo4; // pulse 25%
197                LfoBase<PulseLFO<range_unsigned, 125> >  lfo5; // pulse 12,5%
198                LfoBase<SawLFO<range_unsigned, true> >   lfo6; // saw up
199                LfoBase<SawLFO<range_unsigned, false> >  lfo7; // saw down
200                
201                
202            public:
203                LFOv2Unit(SfzSignalUnitRack* rack);
204                
205                virtual void Trigger();
206        };
207        
208        class AmpLFOUnit: public LFOv1Unit {
209            public:
210                AmpLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
211                
212                virtual void Trigger();
213        };
214        
215        class PitchLFOUnit: public LFOv1Unit {
216            public:
217                PitchLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
218                
219                virtual void Trigger();
220        };
221        
222        class FilLFOUnit: public LFOv1Unit {
223            public:
224                FilLFOUnit(SfzSignalUnitRack* rack): LFOv1Unit(rack) { }
225                
226                virtual void Trigger();
227        };
228        
229            
230            
231      class EndpointUnit : public EndpointSignalUnit {      class EndpointUnit : public EndpointSignalUnit {
# Line 130  namespace LinuxSampler { namespace sfz { Line 243  namespace LinuxSampler { namespace sfz {
243              virtual float GetFilterCutoff();              virtual float GetFilterCutoff();
244              virtual float GetPitch();              virtual float GetPitch();
245              virtual float GetResonance();              virtual float GetResonance();
246                virtual float GetPan();
247                            
248              SfzSignalUnitRack* const GetRack();              SfzSignalUnitRack* const GetRack();
249                
250                virtual float CalculateResonance(float res) {
251                    return GetResonance() + res;
252                }
253      };      };
254            
255            
# Line 139  namespace LinuxSampler { namespace sfz { Line 257  namespace LinuxSampler { namespace sfz {
257          private:          private:
258              EndpointUnit  suEndpoint;              EndpointUnit  suEndpoint;
259              EGv1Unit      suVolEG;              EGv1Unit      suVolEG;
260                FilEGUnit     suFilEG;
261                PitchEGUnit   suPitchEG;
262                
263                AmpLFOUnit   suAmpLFO;
264                PitchLFOUnit suPitchLFO;
265                FilLFOUnit   suFilLFO;
266                            
267              FixedArray<EGv2Unit*> EGs;              FixedArray<EGv2Unit*> EGs;
268                            
# Line 148  namespace LinuxSampler { namespace sfz { Line 272  namespace LinuxSampler { namespace sfz {
272              // used for optimization - contains only the ones that are modulating pitch              // used for optimization - contains only the ones that are modulating pitch
273              FixedArray<EGv2Unit*> pitchEGs;              FixedArray<EGv2Unit*> pitchEGs;
274                            
275                
276                FixedArray<LFOv2Unit*> LFOs;
277                
278                // used for optimization - contains only the ones that are modulating filter cutoff
279                FixedArray<LFOv2Unit*> filLFOs;
280                
281                // used for optimization - contains only the ones that are modulating resonance
282                FixedArray<LFOv2Unit*> resLFOs;
283                
284                // used for optimization - contains only the ones that are modulating pan
285                FixedArray<LFOv2Unit*> panLFOs;
286                
287    
288          public:          public:
289              Voice* const pVoice;              Voice* const pVoice;

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

  ViewVC Help
Powered by ViewVC