52 std::shared_ptr<IReader> m_reader;
57 std::shared_ptr<ImpulseResponse> m_ir;
77 std::vector<std::unique_ptr<Convolver>> m_convolvers;
87 std::vector<sample_t*> m_vecInOut;
127 int m_nChannelThreads;
137 std::shared_ptr<ThreadPool> m_threadPool;
142 std::vector<std::future<int>> m_futures;
157 ConvolverReader(std::shared_ptr<IReader> reader, std::shared_ptr<ImpulseResponse> ir, std::shared_ptr<ThreadPool> threadPool, std::shared_ptr<FFTPlan> plan);
161 virtual void seek(
int position);
165 virtual void read(
int& length,
bool& eos,
sample_t* buffer);
173 void divideByChannel(
const sample_t* buffer,
int len);
180 void joinByChannel(
int start,
int len);
195 int threadFunction(
int id,
bool input);
virtual int getLength() const =0
Returns an approximated length of the source in samples.
#define AUD_NAMESPACE_BEGIN
Opens the audaspace namespace aud.
Definition: Audaspace.h:116
This class represents a sound source as stream or as buffer which can be read for example by another ...
Definition: IReader.h:34
virtual void seek(int position)=0
Seeks to a specific position in the source.
This class represents a reader for a sound that can be modified depending on a given impulse response...
Definition: ConvolverReader.h:41
#define AUD_API
Used for exporting symbols in the shared library.
Definition: Audaspace.h:93
virtual void read(int &length, bool &eos, sample_t *buffer)=0
Request to read the next length samples out of the source.
Specification of a sound source.
Definition: Specification.h:118
virtual Specs getSpecs() const =0
Returns the specification of the reader.
The ImpulseResponse class.
float sample_t
Sample type.(float samples)
Definition: Audaspace.h:126
#define AUD_NAMESPACE_END
Closes the audaspace namespace aud.
Definition: Audaspace.h:119
virtual int getPosition() const =0
Returns the position of the source as a sample count value.
virtual bool isSeekable() const =0
Tells whether the source provides seeking functionality or not.