audio-drain/audio/drain/Algo.cpp

128 lines
3.3 KiB
C++
Raw Normal View History

/** @file
* @author Edouard DUPIN
* @copyright 2011, Edouard DUPIN, all right reserved
* @license MPL v2.0 (see license file)
*/
2016-10-02 21:41:55 +02:00
#include <audio/drain/Algo.hpp>
#include <functional>
2016-10-02 21:41:55 +02:00
#include "debug.hpp"
2015-04-10 23:00:13 +02:00
audio::drain::Algo::Algo() :
2015-02-01 22:22:42 +01:00
m_temporary(false),
m_outputData(),
m_formatSize(0),
m_needProcess(false) {
2015-02-09 21:44:32 +01:00
2015-01-29 21:46:01 +01:00
}
2015-04-10 23:00:13 +02:00
void audio::drain::Algo::init() {
// set notification callback :
m_input.setCallback(std::bind(&audio::drain::Algo::configurationChangeLocal, this));
m_output.setCallback(std::bind(&audio::drain::Algo::configurationChangeLocal, this));
// first configure ==> update the internal parameters
configurationChange();
}
2015-04-10 23:00:13 +02:00
void audio::drain::Algo::configurationChange() {
m_needProcess = false;
if (m_input.getFormat() != m_output.getFormat()) {
m_needProcess = true;
}
if (m_input.getMap() != m_output.getMap()) {
m_needProcess = true;
}
if (m_input.getFrequency() != m_output.getFrequency()) {
m_needProcess = true;
}
switch (m_output.getFormat()) {
case audio::format_int8:
m_formatSize = sizeof(int8_t);
break;
case audio::format_int16:
m_formatSize = sizeof(int16_t);
break;
case audio::format_int24:
case audio::format_int16_on_int32:
case audio::format_int32:
m_formatSize = sizeof(int32_t);
break;
case audio::format_float:
m_formatSize = sizeof(float);
break;
case audio::format_double:
m_formatSize = sizeof(double);
break;
case audio::format_unknow:
DRAIN_VERBOSE("format not configured...");
2015-02-01 22:22:42 +01:00
m_formatSize = 8;
break;
}
}
2017-08-28 00:08:17 +02:00
etk::String audio::drain::Algo::getDotDesc() {
etk::String out;
if (m_input.getFormat() != m_output.getFormat()) {
2017-08-28 00:08:17 +02:00
out += "\\nformat: " + etk::toString(m_input.getFormat()) + "->" + etk::to_string(m_output.getFormat());
}
if (m_input.getMap() != m_output.getMap()) {
2017-08-28 00:08:17 +02:00
out += "\\nmap: " + etk::toString(m_input.getMap()) + "->" + etk::to_string(m_output.getMap());
}
if (m_input.getFrequency() != m_output.getFrequency()) {
2017-08-28 00:08:17 +02:00
out += "\\nsamplerate: " + etk::toString(m_input.getFrequency()) + "->" + etk::to_string(m_output.getFrequency());
}
return out;
}
2015-04-10 23:00:13 +02:00
size_t audio::drain::Algo::needInputData(size_t _output) {
size_t input = _output;
2015-01-28 22:07:11 +01:00
/* NOT good at all ...
if (m_input.getFormat() != m_output.getFormat()) {
int32_t inputSize = 3;
switch (m_input.getFormat()) {
case format_int16:
inputSize = sizeof(int16_t);
break;
case format_int16_on_int32:
case format_int32:
inputSize = sizeof(int32_t);
break;
case format_float:
inputSize = sizeof(float);
break;
}
if (inputSize != m_formatSize) {
input *= inputSize;
input /= m_formatSize;
}
}
2015-01-28 22:07:11 +01:00
*/
/*
if (m_input.getMap().size() != m_output.getMap().size()) {
input *= m_input.getMap().size();
input /= m_output.getMap().size();
}
2015-01-28 22:07:11 +01:00
*/
if (m_input.getFrequency() != m_output.getFrequency()) {
input *= m_input.getFrequency();
input /= m_output.getFrequency();
// to prevent missing data in the resampler
input += 2;
}
return input;
}
2015-04-10 23:00:13 +02:00
void audio::drain::Algo::setStatusFunction(algoStatusFunction _newFunction) {
m_statusFunction = _newFunction;
}
2017-08-28 00:08:17 +02:00
void audio::drain::Algo::generateStatus(const etk::String& _status) {
if (m_statusFunction != nullptr) {
if (m_name.size() == 0) {
m_statusFunction(m_type, _status);
} else {
m_statusFunction(m_name, _status);
}
}
2016-05-02 22:01:55 +02:00
}