CSL  6.0
csl::BinauralPanner Class Reference

forward declaration More...

#include <Binaural.h>

+ Inheritance diagram for csl::BinauralPanner:

Public Member Functions

 BinauralPanner (unsigned blockSize=HRTF_BLOCK_SIZE)
 
 ~BinauralPanner ()
 
void nextBuffer (Buffer &outputBuffer) throw (CException)
 work-horse method reads & transforms input, sums previous data, and takes the IFFT for each of multiple sources More...
 
void setSpeakerLayout (SpeakerLayout *aLayout)
 Set the speaker layout to be used by this panner. The panner will request the default layout if not set. More...
 
unsigned numSources ()
 
virtual void addSource (SpatialSource &s)
 number of active inputs. More...
 
virtual void removeSource (SpatialSource &s)
 Remove a Sound Source. More...
 
virtual void update (void *arg)
 Called when the speaker layout changes. More...
 
virtual void nextBuffer (Buffer &outputBuffer, unsigned outBufNum) throw (CException)
 really compute the next buffer given an offset base channel; this is called by nextBuffer, possibly multiple times More...
 
unsigned frameRate ()
 
void setFrameRate (unsigned rate)
 get/set the receiver's frame rate More...
 
virtual unsigned numChannels ()
 
void setNumChannels (unsigned ch)
 get/set the receiver's number of outputs More...
 
BufferCopyPolicy copyPolicy ()
 
void setCopyPolicy (BufferCopyPolicy ch)
 get/set the receiver's buffer copy policy More...
 
virtual bool isFixed ()
 query whether I'm fixed (StaticVariable overrides this) More...
 
virtual bool isActive ()
 query whether I'm currently active (Envelopes can go inactive) More...
 
void addOutput (UnitGenerator *ugen)
 add to or return the UGen vector of outputs More...
 
void removeOutput (UnitGenerator *ugen)
 
UGenVector outputs ()
 
virtual unsigned numOutputs ()
 
bool checkFanOut (Buffer &outputBuffer) throw (CException)
 check for fan-out and copy previous buffer; return true if fanning out More...
 
void handleFanOut (Buffer &outputBuffer) throw (CException)
 
virtual void setValue (sample theValue)
 set/get the value (not allowed in the abstract, useful for static values) More...
 
virtual sample value ()
 
virtual void dump ()
 pretty-print the receiver More...
 
virtual void trigger ()
 
void attachObserver (Observer *)
 (possibly notify obersvers on my death) More...
 
void detachObserver (Observer *)
 
void changed (void *argument)
 this is what I send to myself to notify my observers; It's not overridden in general. It results in the observers receiving update() calls < override evaluate to filter updates to the observer map More...
 
virtual int evaluate (void *argument)
 

Public Attributes

unsigned mNumBlocks
 

blocks per HRTF

More...
 
unsigned mNumBlocksToSum
 

blocks to include in sum per HRTF

More...
 
unsigned mFramesPerBlock
 

frames per block

More...
 
float mPeriod
 virtual destructor (don't notify or delete observers in this version) More...
 
int mKey
 key selector (e.g., MIDI chan) I receive update() mesages from my model; More...
 

Protected Member Functions

void * cache ()
 Returns an instance of its cache data per sound source. More...
 
virtual void speakerLayoutChanged ()
 
void zeroBuffer (Buffer &outputBuffer, unsigned outBufNum)
 utility method to zero out an outputBuffer More...
 

Protected Attributes

FFT_Wrapper mInFFT
 FFT Wrappers for in and out processing. More...
 
FFT_Wrapper mOutFFT
 
Buffer mInBuf
 
Buffer mTmpBuf
 
Buffer mOutBuf
 temp buffers for input and FFT wrappers More...
 
SampleComplexVector mHOutL
 
SampleComplexVector mHOutR
 buffers for the mixed HRTF & input data pre-IFFT More...
 
SampleBuffer mIFFTOutL
 
SampleBuffer mIFFTOutR
 outputs of the IFFT More...
 
unsigned mBlockInd
 block index More...
 
UGenVector mSources
 SpatialSource... refers to its input UGen, but with the knowledge of its position within a space. More...
 
vector< void * > mCache
 Vector of pointers to the prior I/O data. More...
 
SpeakerLayoutmSpeakerLayout
 If null, it will use the default layout by calling SpeakerLayout::defaultSpeakerLayout();. More...
 
Buffer mTempBuffer
 Buffer used to temporarily hold input source data. More...
 
unsigned mFrameRate
 trigger ignored here More...
 
unsigned mNumChannels
 my "expected" number of output channels More...
 
BufferCopyPolicy mCopyPolicy
 the policy I use if asked for more or fewer channels More...
 
UGenVector mOutputs
 the vector of my output UGens More...
 
unsigned mNumOutputs
 the number of outputs More...
 
BuffermOutputCache
 my past output ring buffer (only used in case of fan-out) More...
 
unsigned mSequence
 the highest-seen buffer seq number More...
 

Detailed Description

forward declaration

BinauralPanner: place sources in 3D using block-wise convolution with an HRTF. The HRIRs (Head Related Impulse Responses) are loaded by the HRTFDatabase. The binaural panner uses these HRTFs and processes the incoming audio by frequency domain convolution in blocks of 512 samples.

Definition at line 49 of file Binaural.h.

Constructor & Destructor Documentation

BinauralPanner::~BinauralPanner ( )

Definition at line 56 of file Binaural.cpp.

References mHOutL, mHOutR, mIFFTOutL, mIFFTOutR, and SAFE_FREE.

Member Function Documentation

void * BinauralPanner::cache ( )
protectedvirtual

Returns an instance of its cache data per sound source.

Reimplemented from csl::SpatialPanner.

Definition at line 65 of file Binaural.cpp.

void SpatialPanner::setSpeakerLayout ( SpeakerLayout aLayout)
inherited

Set the speaker layout to be used by this panner. The panner will request the default layout if not set.

Definition at line 25 of file SpatialPanner.cpp.

References csl::Model::attachObserver(), csl::Model::detachObserver(), csl::SpatialPanner::mSpeakerLayout, and csl::SpatialPanner::speakerLayoutChanged().

Referenced by csl::SpatialPanner::SpatialPanner(), and csl::SpatialPanner::update().

unsigned csl::SpatialPanner::numSources ( )
inlineinherited

Definition at line 32 of file SpatialPanner.h.

References csl::SpatialPanner::mSources.

Referenced by csl::Spatializer::numSources().

void SpatialPanner::addSource ( SpatialSource s)
virtualinherited

number of active inputs.

Add a souce to the list of inputs to be processed and create a cache object

Reimplemented in csl::AmbisonicPanner, csl::SimplePanner, and csl::SimplePanner.

Definition at line 41 of file SpatialPanner.cpp.

References csl::SpatialPanner::cache(), csl::SpatialPanner::mCache, and csl::SpatialPanner::mSources.

Referenced by csl::Spatializer::addSource(), main(), and csl::Spatializer::setPanningMode().

void SpatialPanner::removeSource ( SpatialSource s)
virtualinherited

Remove a Sound Source.

Reimplemented in csl::AmbisonicPanner, csl::SimplePanner, and csl::SimplePanner.

Definition at line 56 of file SpatialPanner.cpp.

References csl::logMsg(), csl::SpatialPanner::mCache, and csl::SpatialPanner::mSources.

Referenced by csl::Spatializer::removeSource().

void SpatialPanner::update ( void *  arg)
virtualinherited

Called when the speaker layout changes.

Called when the speaker layout changes, so panners update their data. This method is implemented only by the Panner class, and depending on the message sent, it calls the appropriate method implemented by subclasses. For example, when the speaker layout changes, the method calls "speakerLayoutChanged()", which should be implemented by subclasses interested to react to such change.

Implements csl::Observer.

Definition at line 83 of file SpatialPanner.cpp.

References csl::SpeakerLayout::defaultSpeakerLayout(), csl::SpatialPanner::mSpeakerLayout, csl::SpatialPanner::setSpeakerLayout(), and csl::SpatialPanner::speakerLayoutChanged().

virtual void csl::SpatialPanner::nextBuffer ( Buffer outputBuffer,
unsigned  outBufNum 
)
throw (CException
)
inlinevirtualinherited

really compute the next buffer given an offset base channel; this is called by nextBuffer, possibly multiple times

Reimplemented from csl::UnitGenerator.

Reimplemented in csl::VBAP.

Definition at line 42 of file SpatialPanner.h.

virtual void csl::SpatialPanner::speakerLayoutChanged ( )
inlineprotectedvirtualinherited

Reimplemented in csl::VBAP.

Definition at line 57 of file SpatialPanner.h.

Referenced by csl::SpatialPanner::setSpeakerLayout(), and csl::SpatialPanner::update().

unsigned csl::UnitGenerator::frameRate ( )
inlineinherited
void csl::UnitGenerator::setFrameRate ( unsigned  rate)
inlineinherited

get/set the receiver's frame rate

Definition at line 250 of file CSL_Core.h.

References csl::UnitGenerator::mFrameRate.

void csl::UnitGenerator::setNumChannels ( unsigned  ch)
inlineinherited

get/set the receiver's number of outputs

Definition at line 253 of file CSL_Core.h.

References csl::UnitGenerator::mNumChannels.

Referenced by BinauralPanner(), csl::Spatializer::Spatializer(), csl::VBAP::speakerLayoutChanged(), and csl::VBAP::VBAP().

BufferCopyPolicy csl::UnitGenerator::copyPolicy ( )
inlineinherited

Definition at line 255 of file CSL_Core.h.

References csl::UnitGenerator::mCopyPolicy.

void csl::UnitGenerator::setCopyPolicy ( BufferCopyPolicy  ch)
inlineinherited
virtual bool csl::UnitGenerator::isFixed ( )
inlinevirtualinherited

query whether I'm fixed (StaticVariable overrides this)

Reimplemented in csl::StaticVariable, and csl::BinaryOp.

Definition at line 271 of file CSL_Core.h.

virtual bool csl::UnitGenerator::isActive ( )
inlinevirtualinherited
UGenVector csl::UnitGenerator::outputs ( )
inlineinherited

Definition at line 277 of file CSL_Core.h.

References csl::UnitGenerator::mOutputs.

virtual unsigned csl::UnitGenerator::numOutputs ( )
inlinevirtualinherited

Definition at line 278 of file CSL_Core.h.

References csl::UnitGenerator::mNumOutputs.

bool UnitGenerator::checkFanOut ( Buffer outputBuffer)
throw (CException
)
inherited

check for fan-out and copy previous buffer; return true if fanning out

Definition at line 699 of file CSL_Core.cpp.

void UnitGenerator::handleFanOut ( Buffer outputBuffer)
throw (CException
)
inherited

Definition at line 713 of file CSL_Core.cpp.

References csl_max.

virtual void csl::UnitGenerator::setValue ( sample  theValue)
inlinevirtualinherited

set/get the value (not allowed in the abstract, useful for static values)

Reimplemented in csl::DynamicVariable, and csl::StaticVariable.

Definition at line 284 of file CSL_Core.h.

virtual sample csl::UnitGenerator::value ( )
inlinevirtualinherited

Reimplemented in csl::StaticVariable.

Definition at line 285 of file CSL_Core.h.

virtual void csl::UnitGenerator::trigger ( void  )
inlinevirtualinherited
void UnitGenerator::zeroBuffer ( Buffer outputBuffer,
unsigned  outBufNum 
)
protectedinherited

utility method to zero out an outputBuffer

Definition at line 663 of file CSL_Core.cpp.

References csl::Buffer::buffer(), and csl::Buffer::mMonoBufferByteSize.

void Model::attachObserver ( Observer o)
inherited

(possibly notify obersvers on my death)

register/remove observers

Definition at line 502 of file CGestalt.cpp.

References csl::logMsg(), csl::Observer::mKey, and csl::Observer::mPeriod.

Referenced by CSLMIDIComponent::CSLMIDIComponent(), and csl::SpatialPanner::setSpeakerLayout().

void Model::detachObserver ( Observer o)
inherited
void Model::changed ( void *  argument)
inherited

this is what I send to myself to notify my observers; It's not overridden in general. It results in the observers receiving update() calls < override evaluate to filter updates to the observer map

Definition at line 540 of file CGestalt.cpp.

References csl::logMsg().

Referenced by csl::SpeakerLayout::addSpeaker(), csl::MIDIIn::handleIncomingMidiMessage(), and csl::SpeakerLayout::setDefaultSpeakerLayout().

virtual int csl::Model::evaluate ( void *  argument)
inlinevirtualinherited

Reimplemented in csl::MIDIIn.

Definition at line 270 of file CGestalt.h.

Member Data Documentation

unsigned csl::BinauralPanner::mNumBlocks

blocks per HRTF

Definition at line 59 of file Binaural.h.

Referenced by BinauralPanner(), and csl::BinauralSourceCache::BinauralSourceCache().

unsigned csl::BinauralPanner::mNumBlocksToSum

blocks to include in sum per HRTF

Definition at line 60 of file Binaural.h.

Referenced by BinauralPanner().

unsigned csl::BinauralPanner::mFramesPerBlock

frames per block

Definition at line 61 of file Binaural.h.

Referenced by BinauralPanner(), and csl::BinauralSourceCache::BinauralSourceCache().

FFT_Wrapper csl::BinauralPanner::mInFFT
protected

FFT Wrappers for in and out processing.

Definition at line 64 of file Binaural.h.

FFT_Wrapper csl::BinauralPanner::mOutFFT
protected

Definition at line 65 of file Binaural.h.

Buffer csl::BinauralPanner::mInBuf
protected

Definition at line 67 of file Binaural.h.

Referenced by BinauralPanner().

Buffer csl::BinauralPanner::mTmpBuf
protected

Definition at line 67 of file Binaural.h.

Referenced by BinauralPanner().

Buffer csl::BinauralPanner::mOutBuf
protected

temp buffers for input and FFT wrappers

Definition at line 67 of file Binaural.h.

SampleComplexVector csl::BinauralPanner::mHOutL
protected

Definition at line 69 of file Binaural.h.

Referenced by BinauralPanner(), and ~BinauralPanner().

SampleComplexVector csl::BinauralPanner::mHOutR
protected

buffers for the mixed HRTF & input data pre-IFFT

Definition at line 69 of file Binaural.h.

Referenced by BinauralPanner(), and ~BinauralPanner().

SampleBuffer csl::BinauralPanner::mIFFTOutL
protected

Definition at line 70 of file Binaural.h.

Referenced by BinauralPanner(), and ~BinauralPanner().

SampleBuffer csl::BinauralPanner::mIFFTOutR
protected

outputs of the IFFT

Definition at line 70 of file Binaural.h.

Referenced by BinauralPanner(), and ~BinauralPanner().

unsigned csl::BinauralPanner::mBlockInd
protected

block index

Definition at line 72 of file Binaural.h.

UGenVector csl::SpatialPanner::mSources
protectedinherited

SpatialSource... refers to its input UGen, but with the knowledge of its position within a space.

Vector of pointers to the inputs

Definition at line 49 of file SpatialPanner.h.

Referenced by csl::SimplePanner::addSource(), csl::SpatialPanner::addSource(), csl::SpatialPanner::numSources(), csl::SimplePanner::removeSource(), and csl::SpatialPanner::removeSource().

vector<void *> csl::SpatialPanner::mCache
protectedinherited

Vector of pointers to the prior I/O data.

Definition at line 50 of file SpatialPanner.h.

Referenced by csl::SpatialPanner::addSource(), and csl::SpatialPanner::removeSource().

Buffer csl::SpatialPanner::mTempBuffer
protectedinherited

Buffer used to temporarily hold input source data.

Definition at line 54 of file SpatialPanner.h.

Referenced by csl::SpatialPanner::SpatialPanner(), and csl::SpatialPanner::~SpatialPanner().

BufferCopyPolicy csl::UnitGenerator::mCopyPolicy
protectedinherited

the policy I use if asked for more or fewer channels

Definition at line 293 of file CSL_Core.h.

Referenced by csl::UnitGenerator::copyPolicy(), and csl::UnitGenerator::setCopyPolicy().

UGenVector csl::UnitGenerator::mOutputs
protectedinherited
unsigned csl::UnitGenerator::mNumOutputs
protectedinherited

the number of outputs

Definition at line 295 of file CSL_Core.h.

Referenced by csl::UnitGenerator::addOutput(), csl::UnitGenerator::numOutputs(), and csl::UnitGenerator::removeOutput().

Buffer* csl::UnitGenerator::mOutputCache
protectedinherited

my past output ring buffer (only used in case of fan-out)

Definition at line 296 of file CSL_Core.h.

Referenced by csl::UnitGenerator::addOutput().

unsigned csl::UnitGenerator::mSequence
protectedinherited

the highest-seen buffer seq number

Definition at line 297 of file CSL_Core.h.

float csl::Observer::mPeriod
inherited

virtual destructor (don't notify or delete observers in this version)

max update rate

Definition at line 299 of file CGestalt.h.

Referenced by csl::Model::attachObserver(), and csl::Observer::Observer().

int csl::Observer::mKey
inherited

key selector (e.g., MIDI chan) I receive update() mesages from my model;

Definition at line 302 of file CGestalt.h.

Referenced by csl::Model::attachObserver(), and csl::Observer::Observer().


The documentation for this class was generated from the following files: