2011-08-20 14:40:44 +00:00
|
|
|
#ifdef NALL_DSP_INTERNAL_HPP
|
|
|
|
|
|
|
|
struct Buffer {
|
2013-05-02 11:25:45 +00:00
|
|
|
double** sample = nullptr;
|
2013-03-15 13:11:33 +00:00
|
|
|
uint16_t rdoffset = 0;
|
|
|
|
uint16_t wroffset = 0;
|
|
|
|
unsigned channels = 0;
|
2011-08-20 14:40:44 +00:00
|
|
|
|
2011-09-16 11:44:07 +00:00
|
|
|
void setChannels(unsigned channels) {
|
2013-03-15 13:11:33 +00:00
|
|
|
if(sample) {
|
|
|
|
for(unsigned c = 0; c < this->channels; c++) {
|
|
|
|
if(sample[c]) delete[] sample[c];
|
|
|
|
}
|
|
|
|
delete[] sample;
|
2011-09-16 11:44:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
this->channels = channels;
|
|
|
|
if(channels == 0) return;
|
|
|
|
|
|
|
|
sample = new double*[channels];
|
|
|
|
for(unsigned c = 0; c < channels; c++) {
|
|
|
|
sample[c] = new double[65536]();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
inline double& read(unsigned channel, signed offset = 0) {
|
2011-08-20 14:40:44 +00:00
|
|
|
return sample[channel][(uint16_t)(rdoffset + offset)];
|
|
|
|
}
|
|
|
|
|
2011-09-16 11:44:07 +00:00
|
|
|
inline double& write(unsigned channel, signed offset = 0) {
|
2011-08-20 14:40:44 +00:00
|
|
|
return sample[channel][(uint16_t)(wroffset + offset)];
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void clear() {
|
2011-09-16 11:44:07 +00:00
|
|
|
for(unsigned c = 0; c < channels; c++) {
|
|
|
|
for(unsigned n = 0; n < 65536; n++) {
|
|
|
|
sample[c][n] = 0;
|
|
|
|
}
|
2011-08-20 14:40:44 +00:00
|
|
|
}
|
|
|
|
rdoffset = 0;
|
|
|
|
wroffset = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
Buffer() {
|
|
|
|
}
|
|
|
|
|
|
|
|
~Buffer() {
|
2011-09-16 11:44:07 +00:00
|
|
|
setChannels(0);
|
2011-08-20 14:40:44 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|