pl-nk v0.4.5
Plonk|Plink|Plank are a set of cross-platform C/C++ frameworks for audio software development
plonk_DelayBase.h
00001 /*
00002  -------------------------------------------------------------------------------
00003  This file is part of the Plink, Plonk, Plank libraries
00004   by Martin Robinson
00005  
00006  http://code.google.com/p/pl-nk/
00007  
00008  Copyright University of the West of England, Bristol 2011-14
00009  All rights reserved.
00010  
00011  Redistribution and use in source and binary forms, with or without
00012  modification, are permitted provided that the following conditions are met:
00013  
00014  * Redistributions of source code must retain the above copyright
00015    notice, this list of conditions and the following disclaimer.
00016  * Redistributions in binary form must reproduce the above copyright
00017    notice, this list of conditions and the following disclaimer in the
00018    documentation and/or other materials provided with the distribution.
00019  * Neither the name of University of the West of England, Bristol nor 
00020    the names of its contributors may be used to endorse or promote products
00021    derived from this software without specific prior written permission.
00022  
00023  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
00024  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00025  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00026  DISCLAIMED. IN NO EVENT SHALL UNIVERSITY OF THE WEST OF ENGLAND, BRISTOL BE 
00027  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 
00028  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE 
00029  GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 
00030  HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
00031  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT 
00032  OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00033  
00034  This software makes use of third party libraries. For more information see:
00035  doc/license.txt included in the distribution.
00036  -------------------------------------------------------------------------------
00037  */
00038 
00039 #ifndef PLONK_DELAYBASE_H
00040 #define PLONK_DELAYBASE_H
00041 
00042 #include "../channel/plonk_ChannelInternalCore.h"
00043 #include "plonk_DelayForwardDeclarations.h"
00044 
00045 
00046 template<class FormType>
00047 class DelayChannelInternalBase
00048 :   public ProxyOwnerChannelInternal<typename FormType::SampleDataType, 
00049                                      typename FormType::Data>
00050 {
00051 public:
00052     typedef typename FormType::SampleDataType                       SampleType;
00053     typedef typename FormType::Data                                 Data;
00054     typedef typename FormType::DelayState                           DelayState;
00055     typedef ObjectArray<DelayState>                                 DelayStateArray;
00056     
00057     typedef typename DelayFormData<SampleType,0,1,1>::DelayState    DelayStateBase;
00058     
00059     typedef ChannelBase<SampleType>                                 ChannelType;
00060     typedef ObjectArray<ChannelType>                                ChannelArrayType;
00061     typedef Delay1ParamChannelInternal<FormType>                    DelayInternal;
00062     typedef ProxyOwnerChannelInternal<SampleType,Data>              Internal;
00063     typedef ChannelInternalBase<SampleType>                         InternalBase;
00064     typedef UnitBase<SampleType>                                    UnitType;
00065     typedef InputDictionary                                         Inputs;
00066     typedef NumericalArray<SampleType>                              Buffer;
00067     typedef ObjectArray<Buffer>                                     BufferArray;
00068     
00069     typedef typename TypeUtility<SampleType>::IndexType             DurationType;
00070                     
00071     DelayChannelInternalBase (const int numOutputs, 
00072                               Inputs const& inputs, 
00073                               Data const& data, 
00074                               BlockSize const& blockSize,
00075                               SampleRate const& sampleRate,
00076                               ChannelArrayType& channels) throw()
00077     :   Internal (numOutputs, inputs, data, blockSize, sampleRate, channels)
00078     {
00079         delayStates = DelayStateArray::withSize (this->getNumChannels());
00080         circularBuffers = BufferArray::withSize (FormType::getNumCircularBuffers());
00081     }
00082     
00083     Text getName() const throw()
00084     {
00085         return FormType::getName();
00086     }       
00087     
00088     IntArray getInputKeys() const throw()
00089     {
00090         return FormType::getInputKeys();
00091     }    
00092         
00093     void initChannel (const int channel) throw()
00094     {        
00095         int i; 
00096         
00097         const UnitType& inputUnit = this->getInputAsUnit (IOKey::Generic);
00098         
00099         if ((channel % this->getNumChannels()) == 0)
00100         {
00101             this->setBlockSize (BlockSize::decide (inputUnit.getBlockSize (channel),
00102                                                    this->getBlockSize()));
00103             this->setSampleRate (SampleRate::decide (inputUnit.getSampleRate (channel),
00104                                                      this->getSampleRate()));
00105             
00106             this->setOverlap (inputUnit.getOverlap (channel));
00107             
00108             Data& data = this->getState();
00109             
00110             const int bufferLength (data.maximumDuration * data.base.sampleRate + 0.5);
00111             
00112             for (i = 0; i < FormType::getNumCircularBuffers(); ++i)
00113                 circularBuffers.put (i, Buffer::newClear (bufferLength * 3));
00114             
00115             for (i = 0; i < this->getNumChannels(); ++i)
00116             {
00117                 this->initProxyValue (i, SampleType (0));            
00118 
00119                 DelayState& delayState = delayStates.atUnchecked (i);
00120                 Buffer& circularBuffer = circularBuffers.wrapAt (i);
00121                 
00122                 Memory::zero (delayState);
00123                 
00124                 DelayStateBase& delayStateBase (reinterpret_cast<DelayStateBase&>(delayState));
00125                 delayStateBase.bufferSamples = circularBuffer.getArray();
00126                 delayStateBase.bufferLength = bufferLength,
00127                 delayStateBase.bufferLengthIndex = DurationType (bufferLength),
00128                 delayStateBase.buffer0 = DurationType (0);
00129             }
00130         }
00131     }    
00132     
00133     inline BufferArray& getCircularBuffers() { return circularBuffers; }
00134     inline DelayStateArray& getDelayStates() { return delayStates; }
00135     
00136 private:
00137     BufferArray circularBuffers;
00138     DelayStateArray delayStates;
00139 };
00140 
00141 
00142 
00143 #endif // PLONK_DELAYBASE_H
00144 
 All Classes Functions Typedefs Enumerations Enumerator Properties