/[svn]/linuxsampler/trunk/src/engines/gig/Engine.h
ViewVC logotype

Diff of /linuxsampler/trunk/src/engines/gig/Engine.h

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

revision 285 by schoenebeck, Thu Oct 14 21:31:26 2004 UTC revision 460 by schoenebeck, Mon Mar 14 22:35:44 2005 UTC
# Line 3  Line 3 
3   *   LinuxSampler - modular, streaming capable sampler                     *   *   LinuxSampler - modular, streaming capable sampler                     *
4   *                                                                         *   *                                                                         *
5   *   Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck   *   *   Copyright (C) 2003, 2004 by Benno Senoner and Christian Schoenebeck   *
6     *   Copyright (C) 2005 Christian Schoenebeck                              *
7   *                                                                         *   *                                                                         *
8   *   This program is free software; you can redistribute it and/or modify  *   *   This program is free software; you can redistribute it and/or modify  *
9   *   it under the terms of the GNU General Public License as published by  *   *   it under the terms of the GNU General Public License as published by  *
# Line 31  Line 32 
32    
33  #include <map>  #include <map>
34    
35    #include "EngineGlobals.h"
36  #include "../../common/RingBuffer.h"  #include "../../common/RingBuffer.h"
37  #include "../../common/Pool.h"  #include "../../common/Pool.h"
38    #include "../../common/ArrayList.h"
39  #include "../../common/ConditionServer.h"  #include "../../common/ConditionServer.h"
40  #include "../common/Engine.h"  #include "../common/Engine.h"
41  #include "../common/Event.h"  #include "../common/Event.h"
42  #include "../common/BiquadFilter.h"  #include "../common/BiquadFilter.h"
43  #include "../../lib/fileloader/libgig/gig.h"  #include "../../lib/fileloader/libgig/gig.h"
 #include "InstrumentResourceManager.h"  
44  #include "../../network/lscp.h"  #include "../../network/lscp.h"
45    #include "EngineChannel.h"
 #define PITCHBEND_SEMITONES             12  
 #define MAX_AUDIO_VOICES                128  
 #define SYSEX_BUFFER_SIZE               2048  // 2kB  
 #define VOICE_STEAL_ALGORITHM           voice_steal_algo_oldestkey  ///< @see voice_steal_algo_t for available voice stealing algorithms  
46    
47  namespace LinuxSampler { namespace gig {  namespace LinuxSampler { namespace gig {
48    
     using std::map;  
   
49      // just symbol prototyping      // just symbol prototyping
50      class Voice;      class Voice;
51      class DiskThread;      class DiskThread;
52      class InstrumentResourceManager;      class InstrumentResourceManager;
53        class midi_key_info_t;
54        class EngineChannel;
55    
56      /**      /**
57       * Sampler engine for the Gigasampler format.       * Sampler engine for the Gigasampler format.
58       */       */
59      class Engine : public LinuxSampler::Engine, public InstrumentConsumer {      class Engine : public LinuxSampler::Engine {
60          public:          public:
             // types  
             enum voice_steal_algo_t {  
                 voice_steal_algo_none,  
                 voice_steal_algo_keymask,  
                 voice_steal_algo_oldestkey  
             };  
   
61              // methods              // methods
62              Engine();              Engine();
63             ~Engine();             ~Engine();
64                void Connect(AudioOutputDevice* pAudioOut);
65    
66              // abstract methods derived from class 'LinuxSampler::Engine'              // implementation of abstract methods derived from class 'LinuxSampler::Engine'
67              virtual void   LoadInstrument(const char* FileName, uint Instrument);              virtual int    RenderAudio(uint Samples);
68                virtual void   SendSysex(void* pData, uint Size);
69              virtual void   Reset();              virtual void   Reset();
70              virtual void   Enable();              virtual void   Enable();
71              virtual void   Disable();              virtual void   Disable();
             virtual void   SendNoteOn(uint8_t Key, uint8_t Velocity);  
             virtual void   SendNoteOff(uint8_t Key, uint8_t Velocity);  
             virtual void   SendPitchbend(int Pitch);  
             virtual void   SendControlChange(uint8_t Controller, uint8_t Value);  
             virtual void   SendSysex(void* pData, uint Size);  
             virtual float  Volume();  
             virtual void   Volume(float f);  
             virtual uint   Channels();  
             virtual void   Connect(AudioOutputDevice* pAudioOut);  
             virtual void   DisconnectAudioOutputDevice();  
             virtual void   SetOutputChannel(uint EngineAudioChannel, uint AudioDeviceChannel);  
             virtual int    OutputChannel(uint EngineAudioChannel);  
             virtual int    RenderAudio(uint Samples);  
72              virtual uint   VoiceCount();              virtual uint   VoiceCount();
73              virtual uint   VoiceCountMax();              virtual uint   VoiceCountMax();
74              virtual bool   DiskStreamSupported();              virtual bool   DiskStreamSupported();
# Line 99  namespace LinuxSampler { namespace gig { Line 79  namespace LinuxSampler { namespace gig {
79              virtual String Description();              virtual String Description();
80              virtual String Version();              virtual String Version();
81              virtual String EngineName();              virtual String EngineName();
             virtual String InstrumentFileName();  
             virtual int    InstrumentIndex();  
             virtual int    InstrumentStatus();  
   
             // abstract methods derived from interface class 'InstrumentConsumer'  
             virtual void ResourceToBeUpdated(::gig::Instrument* pResource, void*& pUpdateArg);  
             virtual void ResourceUpdated(::gig::Instrument* pOldResource, ::gig::Instrument* pNewResource, void* pUpdateArg);  
         protected:  
             struct midi_key_info_t {  
                 RTList<Voice>*  pActiveVoices;  ///< Contains the active voices associated with the MIDI key.  
                 bool            KeyPressed;     ///< Is true if the respective MIDI key is currently pressed.  
                 bool            Active;         ///< If the key contains active voices.  
                 bool            ReleaseTrigger; ///< If we have to launch release triggered voice(s) when the key is released  
                 Pool<uint>::Iterator itSelf;         ///< hack to allow fast deallocation of the key from the list of active keys  
                 RTList<Event>*  pEvents;        ///< Key specific events (only Note-on, Note-off and sustain pedal currently)  
             };  
82    
83              static InstrumentResourceManager Instruments;          //protected:
84                static InstrumentResourceManager instruments;
85    
86              AudioOutputDevice*      pAudioOutputDevice;              AudioOutputDevice*      pAudioOutputDevice;
             float*                  pOutputLeft;           ///< Audio output channel buffer (left)  
             float*                  pOutputRight;          ///< Audio output channel buffer (right)  
             int                     AudioDeviceChannelLeft;  ///< audio device channel number to which the left channel is connected to  
             int                     AudioDeviceChannelRight; ///< audio device channel number to which the right channel is connected to  
87              uint                    SampleRate;            ///< Sample rate of the engines output audio signal (in Hz)              uint                    SampleRate;            ///< Sample rate of the engines output audio signal (in Hz)
88              uint                    MaxSamplesPerCycle;    ///< Size of each audio output buffer              uint                    MaxSamplesPerCycle;    ///< Size of each audio output buffer
89              DiskThread*             pDiskThread;              DiskThread*             pDiskThread;
90              uint8_t                 ControllerTable[128];  ///< Reflects the current values (0-127) of all MIDI controllers for this engine / sampler channel.              RingBuffer<Event>*      pEventQueue;           ///< Input event queue for engine global events (e.g. SysEx messages).
             RingBuffer<Event>*      pEventQueue;           ///< Input event queue.  
             RingBuffer<uint8_t>*    pSysexBuffer;          ///< Input buffer for MIDI system exclusive messages.  
             midi_key_info_t         pMIDIKeyInfo[128];     ///< Contains all active voices sorted by MIDI key number and other informations to the respective MIDI key  
91              Pool<Voice>*            pVoicePool;            ///< Contains all voices that can be activated.              Pool<Voice>*            pVoicePool;            ///< Contains all voices that can be activated.
             Pool<uint>*             pActiveKeys;           ///< Holds all keys in it's allocation list with active voices.  
             Pool<Event>*            pEventPool;            ///< Contains all Event objects that can be used.  
92              EventGenerator*         pEventGenerator;              EventGenerator*         pEventGenerator;
93              RTList<Event>*          pVoiceStealingQueue;   ///< All voice-launching events which had to be postponed due to free voice shortage.              RTList<Event>*          pVoiceStealingQueue;   ///< All voice-launching events which had to be postponed due to free voice shortage.
94              RTList<Event>*          pEvents;               ///< All events for the current audio fragment.              RTList<Event>*          pGlobalEvents;         ///< All engine global events for the current audio fragment (usually only SysEx messages).
95              RTList<Event>*          pCCEvents;             ///< All control change events for the current audio fragment.              Pool<Event>*            pEventPool;            ///< Contains all Event objects that can be used.
96              RTList<Event>*          pSynthesisEvents[Event::destination_count];     ///< Events directly affecting synthesis parameter (like pitch, volume and filter).              RingBuffer<uint8_t>*    pSysexBuffer;          ///< Input buffer for MIDI system exclusive messages.
97              float*                  pSynthesisParameters[Event::destination_count]; ///< Matrix with final synthesis parameters for the current audio fragment which will be used in the main synthesis loop.              float*                  pSynthesisParameters[Event::destination_count]; ///< Matrix with final synthesis parameters for the current audio fragment which will be used in the main synthesis loop.
98              biquad_param_t*         pBasicFilterParameters; ///< Biquad parameters of the basic bandpass filter.              biquad_param_t*         pBasicFilterParameters; ///< Biquad parameters of the basic bandpass filter.
99              biquad_param_t*         pMainFilterParameters;  ///< Main biquad parameters of the individual filter (lowpass / bandpass / highpass).              biquad_param_t*         pMainFilterParameters;  ///< Main biquad parameters of the individual filter (lowpass / bandpass / highpass).
100              map<uint,uint*>         ActiveKeyGroups;        ///< Contains active keys (in case they belong to a key group) ordered by key group ID.              int                     ActiveVoiceCount;      ///< number of currently active voices (this value will be returned for public calls)
101              RIFF::File*             pRIFF;              int                     ActiveVoiceCountTemp;  ///< number of currently active voices (for internal usage, will be used for incrementation)
             ::gig::File*            pGig;  
             ::gig::Instrument*      pInstrument;  
             bool                    SustainPedal;          ///< true if sustain pedal is down  
             double                  GlobalVolume;          ///< overall volume (a value < 1.0 means attenuation, a value > 1.0 means amplification)  
             int                     Pitch;                 ///< Current (absolute) MIDI pitch value.  
             int                     ActiveVoiceCount;      ///< number of currently active voices  
102              int                     ActiveVoiceCountMax;   ///< the maximum voice usage since application start              int                     ActiveVoiceCountMax;   ///< the maximum voice usage since application start
103                int                     VoiceTheftsLeft;       ///< We only allow MAX_AUDIO_VOICES voices to be stolen per audio fragment, we use this variable to ensure this limit.
104                RTList<Voice>::Iterator itLastStolenVoice;     ///< Only for voice stealing: points to the last voice which was theft in current audio fragment, NULL otherwise.
105                RTList<uint>::Iterator  iuiLastStolenKey;      ///< Only for voice stealing: key number of last key on which the last voice was theft in current audio fragment, NULL otherwise.
106                EngineChannel*          pLastStolenChannel;    ///< Only for voice stealing: points to the engine channel on which the previous voice was stolen in this audio fragment.
107              bool                    SuspensionRequested;              bool                    SuspensionRequested;
108              ConditionServer         EngineDisabled;              ConditionServer         EngineDisabled;
             String                  InstrumentFile;  
             int                     InstrumentIdx;  
             int                     InstrumentStat;  
109              int8_t                  ScaleTuning[12];       ///< contains optional detune factors (-64..+63 cents) for all 12 semitones of an octave              int8_t                  ScaleTuning[12];       ///< contains optional detune factors (-64..+63 cents) for all 12 semitones of an octave
110              RTList<Voice>::Iterator itLastStolenVoice;      ///< Only for voice stealing: points to the last voice which was theft in current audio fragment, NULL otherwise.              int                     MaxFadeOutPos;         ///< The last position in an audio fragment to allow an instant fade out (e.g. for voice stealing) without leading to clicks.
111              RTList<uint>::Iterator  iuiLastStolenKey;      ///< Only for voice stealing: key number of last key on which the last voice was theft in current audio fragment, NULL otherwise.              uint32_t                RandomSeed;            ///< State of the random number generator used by the random dimension.
             int                     MaxFadeOutPos;         ///< The last position in an audio fragment to allow a instant fade out (e.g. for voice stealing) without leading to clicks.  
112    
113              void ProcessNoteOn(Pool<Event>::Iterator& itNoteOnEvent);              void ProcessEvents(EngineChannel* pEngineChannel, uint Samples);
114              void ProcessNoteOff(Pool<Event>::Iterator& itNoteOffEvent);              void RenderActiveVoices(EngineChannel* pEngineChannel, uint Samples);
115              void ProcessPitchbend(Pool<Event>::Iterator& itPitchbendEvent);              void RenderStolenVoices(uint Samples);
116              void ProcessControlChange(Pool<Event>::Iterator& itControlChangeEvent);              void PostProcess(EngineChannel* pEngineChannel);
117                void ClearEventLists();
118                void ImportEvents(uint Samples);
119                void ProcessNoteOn(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent);
120                void ProcessNoteOff(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOffEvent);
121                void ProcessPitchbend(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itPitchbendEvent);
122                void ProcessControlChange(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itControlChangeEvent);
123              void ProcessSysex(Pool<Event>::Iterator& itSysexEvent);              void ProcessSysex(Pool<Event>::Iterator& itSysexEvent);
124              Pool<Voice>::Iterator LaunchVoice(Pool<Event>::Iterator& itNoteOnEvent, int iLayer = 0, bool ReleaseTriggerVoice = false, bool VoiceStealing = true);              Pool<Voice>::Iterator LaunchVoice(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent, int iLayer, bool ReleaseTriggerVoice, bool VoiceStealing);
125              void StealVoice(Pool<Event>::Iterator& itNoteOnEvent);              void StealVoice(EngineChannel* pEngineChannel, Pool<Event>::Iterator& itNoteOnEvent);
126              void FreeVoice(Pool<Voice>::Iterator& itVoice);              void FreeVoice(EngineChannel* pEngineChannel, Pool<Voice>::Iterator& itVoice);
127                void FreeKey(EngineChannel* pEngineChannel, midi_key_info_t* pKey);
128              void ResetSynthesisParameters(Event::destination_t dst, float val);              void ResetSynthesisParameters(Event::destination_t dst, float val);
129              void ResetInternal();              void ResetInternal();
130    
131                static Engine* AcquireEngine(LinuxSampler::gig::EngineChannel* pChannel, AudioOutputDevice* pDevice);
132                static void    FreeEngine(LinuxSampler::gig::EngineChannel* pChannel, AudioOutputDevice* pDevice);
133    
134                void DisableAndLock(); // FIXME: should at least be protected
135    
136              friend class Voice;              friend class Voice;
137              friend class EGADSR;              friend class EGADSR;
138              friend class EGDecay;              friend class EGDecay;
139              friend class VCAManipulator;              friend class VCAManipulator;
140              friend class VCFCManipulator;              friend class VCFCManipulator;
141              friend class VCOManipulator;              friend class VCOManipulator;
             friend class InstrumentResourceManager;  
142          private:          private:
143              void    DisableAndLock();              ArrayList<EngineChannel*> engineChannels; ///< All engine channels of a gig::Engine instance.
144    
145                static std::map<AudioOutputDevice*,Engine*> engines; ///< All instances of gig::Engine.
146    
147              uint8_t GSCheckSum(const RingBuffer<uint8_t>::NonVolatileReader AddrReader, uint DataSize);              uint8_t GSCheckSum(const RingBuffer<uint8_t>::NonVolatileReader AddrReader, uint DataSize);
148              void    AdjustScale(int8_t ScaleTunes[12]);              void    AdjustScale(int8_t ScaleTunes[12]);
149      };      };

Legend:
Removed from v.285  
changed lines
  Added in v.460

  ViewVC Help
Powered by ViewVC