CLAM-Development
1.4.0
|
Implementation of the IFFT using the Fastest Fourier in the West version 3. More...
#include <IFFT_fftw3.hxx>
Public Member Functions | |
IFFT_fftw3 (const IFFTConfig &c=IFFTConfig()) | |
~IFFT_fftw3 () | |
const char * | GetClassName () const |
Override it in every subclass and retur the name of that class. | |
bool | Do () |
Supervised-mode Do function. | |
bool | Do (const Spectrum &in, Audio &out) const |
Standard IFFT Do function, with storage class references as arguments. | |
bool | MayDisableExecution () const |
bool | SetPrototypes (const Spectrum &in, const Audio &out) |
IFFT non-supervised mode SetPrototypes function. | |
bool | SetPrototypes () |
Standard supervised-mode SetPrototypes function. | |
bool | UnsetPrototypes () |
Standard UnsetPrototypes function. | |
![]() | |
IFFT_base () | |
virtual | ~IFFT_base () |
virtual const ProcessingConfig & | GetConfig () const |
Config access: | |
![]() | |
bool | Configure (const ProcessingConfig &config) |
Configuration change method. | |
void | Start (void) |
Method to turn the object into running state. | |
void | Stop (void) |
Method to put the object out of running state When in execution mode, this method must be called before any further call to Configure() methods. | |
Processing () | |
virtual | ~Processing () |
virtual bool | CanProcessInplace () |
Override this method if your processing cannot process inplace. | |
bool | CanConsumeAndProduce () |
Check that Supervised Do() can be safely called. | |
void | ConsumeAndProduce () |
Acknoledges data tokens in published ports as read/writen by calling Produce() for all registered OutPorts and Consume() to all registered InPorts. | |
std::string | GetExecStateString () const |
bool | IsConfigured () const |
bool | IsRunning () const |
void | RegisterOutPort (OutPortBase *out) |
void | RegisterInPort (InPortBase *in) |
void | RegisterOutControl (OutControlBase *out) |
void | RegisterInControl (InControlBase *in) |
void | SetParent (Processing *p) |
void | SetNetworkBackLink (Network *network) |
virtual bool | ModifiesPortsAndControlsAtConfiguration () |
This method is used to determine if a given processing can change its interface of ports/controls after its construction (i.e. | |
bool | HasInPort (const std::string &name) |
bool | HasOutPort (const std::string &name) |
bool | HasInControl (const std::string &name) |
bool | HasOutControl (const std::string &name) |
InPortBase & | GetInPort (const std::string &name) |
OutPortBase & | GetOutPort (const std::string &name) |
InControlBase & | GetInControl (const std::string &name) |
OutControlBase & | GetOutControl (const std::string &name) |
InPortBase & | GetInPort (unsigned index) |
OutPortBase & | GetOutPort (unsigned index) |
InControlBase & | GetInControl (unsigned index) |
OutControlBase & | GetOutControl (unsigned index) |
unsigned | GetNInPorts () const |
unsigned | GetNOutPorts () const |
unsigned | GetNInControls () const |
unsigned | GetNOutControls () const |
const std::string & | GetConfigErrorMessage () const |
Returns a string describing configuration errors if any. | |
virtual bool | IsSyncSource () const |
Wether the processing is a sync source such as audio i/o device, or an audio callback hook (i.e. | |
virtual bool | SupportsVariableAudioSize () const |
This method reports whether the processing supports dynamic buffer-size host. |
Additional Inherited Members | |
![]() | |
enum | { CLAM_DEFAULT_IFFT_SIZE = 1024 } |
![]() | |
void | ChangeSize (int n) |
int | GetSize () |
![]() | |
virtual bool | ConcreteStart () |
Processing objects have to redefine this method when starting them implies some internal changes. | |
virtual bool | ConcreteStop () |
Processing objects have to redefine this method when stoping them implies some internal changes. | |
unsigned | BackendBufferSize () |
Given by the NetworkPlayer (backend) if exists. | |
unsigned | BackendSampleRate () |
Given by the NetworkPlayer (backend) if exists. | |
InControlRegistry & | GetInControls () |
Accessor to published Controls manager. | |
OutControlRegistry & | GetOutControls () |
Accessor to published Controls manager. | |
InPortRegistry & | GetInPorts () |
Accessor to published Ports manager. | |
OutPortRegistry & | GetOutPorts () |
Accessor to published Portss manager. | |
bool | AddConfigErrorMessage (const std::string &msg) |
Use this method to append a configuration errors to the processing when implementing ConcreteConfigure. | |
bool | AbleToExecute (void) const |
In debug-mode checks that the processing is configured and started. | |
template<typename ConcreteConfig > | |
void | CopyAsConcreteConfig (ConcreteConfig &concrete, const ProcessingConfig &abstract) const |
Helper template to convert a reference to a ProcessingConfig to the concrete ProcessingConfig specified on the first parameter. | |
void | SetExecState (ExecState state) |
![]() | |
IFFTConfig | mConfig |
IFFT Configuration. | |
int | mSize |
IFFT size. | |
InPort< Spectrum > | mInput |
AudioOutPort | mOutput |
![]() | |
ProcessingComposite * | mpParent |
Pointer to the parent (composite) processing object, or 0. | |
Network * | _network |
The parent network if any. |
Implementation of the IFFT using the Fastest Fourier in the West version 3.
Definition at line 35 of file IFFT_fftw3.hxx.
CLAM::IFFT_fftw3::IFFT_fftw3 | ( | const IFFTConfig & | c = IFFTConfig() | ) |
Definition at line 66 of file IFFT_fftw3.cxx.
References CLAM::Processing::Configure().
CLAM::IFFT_fftw3::~IFFT_fftw3 | ( | ) |
Definition at line 88 of file IFFT_fftw3.cxx.
|
virtual |
Supervised-mode Do function.
Implements CLAM::IFFT_base.
Definition at line 131 of file IFFT_fftw3.cxx.
References CLAM::InPort< Token >::Consume(), CLAM::AudioOutPort::GetAudio(), CLAM::InPort< Token >::GetData(), CLAM::IFFT_base::mInput, CLAM::IFFT_base::mOutput, and CLAM::OutPort< Token >::Produce().
Standard IFFT Do function, with storage class references as arguments.
This method implements the old conversor routines.
Implements CLAM::IFFT_base.
Definition at line 166 of file IFFT_fftw3.cxx.
References CLAM_ASSERT, CLAM::Audio::GetSize(), CLAM::Processing::IsRunning(), and CLAM::IFFT_base::mSize.
|
inlinevirtual |
Override it in every subclass and retur the name of that class.
Reimplemented from CLAM::IFFT_base.
Definition at line 77 of file IFFT_fftw3.hxx.
|
inlinevirtual |
Reimplemented from CLAM::IFFT_base.
Definition at line 81 of file IFFT_fftw3.hxx.
IFFT non-supervised mode SetPrototypes function.
Implements CLAM::IFFT_base.
Definition at line 140 of file IFFT_fftw3.cxx.
References CLAM::SpecTypeFlags::bComplex, CLAM::SpecTypeFlags::bMagPhase, CLAM::SpecTypeFlags::bMagPhaseBPF, CLAM::SpecTypeFlags::bPolar, CLAM_ASSERT, and CLAM::Spectrum::GetType().
|
virtual |
Standard supervised-mode SetPrototypes function.
Reimplemented from CLAM::IFFT_base.
Definition at line 188 of file IFFT_fftw3.cxx.
References CLAM_ASSERT.
|
virtual |
Standard UnsetPrototypes function.
Reimplemented from CLAM::IFFT_base.
Definition at line 159 of file IFFT_fftw3.cxx.