2015-01-25 22:10:49 +01:00
|
|
|
/** @file
|
|
|
|
* @author Edouard DUPIN
|
|
|
|
* @copyright 2011, Edouard DUPIN, all right reserved
|
2017-01-05 21:28:23 +01:00
|
|
|
* @license MPL v2.0 (see license file)
|
2015-01-25 22:10:49 +01:00
|
|
|
*/
|
2016-10-02 21:41:55 +02:00
|
|
|
#include <audio/drain/Algo.hpp>
|
2015-01-25 22:10:49 +01:00
|
|
|
#include <functional>
|
2016-10-02 21:41:55 +02:00
|
|
|
#include "debug.hpp"
|
2015-01-25 22:10:49 +01:00
|
|
|
|
2015-04-10 23:00:13 +02:00
|
|
|
audio::drain::Algo::Algo() :
|
2015-02-01 22:22:42 +01:00
|
|
|
m_temporary(false),
|
2015-01-25 22:10:49 +01:00
|
|
|
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() {
|
2015-01-25 22:10:49 +01:00
|
|
|
// set notification callback :
|
2016-03-08 21:29:34 +01:00
|
|
|
m_input.setCallback(std::bind(&audio::drain::Algo::configurationChangeLocal, this));
|
|
|
|
m_output.setCallback(std::bind(&audio::drain::Algo::configurationChangeLocal, this));
|
2015-01-25 22:10:49 +01:00
|
|
|
// first configure ==> update the internal parameters
|
|
|
|
configurationChange();
|
|
|
|
}
|
|
|
|
|
2015-04-10 23:00:13 +02:00
|
|
|
void audio::drain::Algo::configurationChange() {
|
2015-01-25 22:10:49 +01:00
|
|
|
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()) {
|
2015-02-04 22:39:05 +01:00
|
|
|
case audio::format_int8:
|
|
|
|
m_formatSize = sizeof(int8_t);
|
|
|
|
break;
|
|
|
|
case audio::format_int16:
|
2015-01-25 22:10:49 +01:00
|
|
|
m_formatSize = sizeof(int16_t);
|
|
|
|
break;
|
2015-02-04 22:39:05 +01:00
|
|
|
case audio::format_int24:
|
|
|
|
case audio::format_int16_on_int32:
|
|
|
|
case audio::format_int32:
|
2015-01-25 22:10:49 +01:00
|
|
|
m_formatSize = sizeof(int32_t);
|
|
|
|
break;
|
2015-02-04 22:39:05 +01:00
|
|
|
case audio::format_float:
|
2015-01-25 22:10:49 +01:00
|
|
|
m_formatSize = sizeof(float);
|
|
|
|
break;
|
2015-02-04 22:39:05 +01:00
|
|
|
case audio::format_double:
|
|
|
|
m_formatSize = sizeof(double);
|
|
|
|
break;
|
|
|
|
case audio::format_unknow:
|
2015-03-03 21:28:07 +01:00
|
|
|
DRAIN_VERBOSE("format not configured...");
|
2015-02-01 22:22:42 +01:00
|
|
|
m_formatSize = 8;
|
|
|
|
break;
|
2015-01-25 22:10:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-28 00:08:17 +02:00
|
|
|
etk::String audio::drain::Algo::getDotDesc() {
|
|
|
|
etk::String out;
|
2016-11-17 00:18:49 +01:00
|
|
|
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());
|
2016-11-17 00:18:49 +01:00
|
|
|
}
|
|
|
|
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());
|
2016-11-17 00:18:49 +01:00
|
|
|
}
|
|
|
|
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());
|
2016-11-17 00:18:49 +01:00
|
|
|
}
|
|
|
|
return out;
|
|
|
|
}
|
|
|
|
|
2015-04-10 23:00:13 +02:00
|
|
|
size_t audio::drain::Algo::needInputData(size_t _output) {
|
2015-01-25 22:10:49 +01:00
|
|
|
size_t input = _output;
|
2015-01-28 22:07:11 +01:00
|
|
|
/* NOT good at all ...
|
2015-01-25 22:10:49 +01:00
|
|
|
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
|
|
|
*/
|
|
|
|
/*
|
2015-01-25 22:10:49 +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
|
|
|
*/
|
2015-01-25 22:10:49 +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-03-18 21:47:27 +01:00
|
|
|
|
2015-04-10 23:00:13 +02:00
|
|
|
void audio::drain::Algo::setStatusFunction(algoStatusFunction _newFunction) {
|
2015-03-18 21:47:27 +01:00
|
|
|
m_statusFunction = _newFunction;
|
|
|
|
}
|
|
|
|
|
2017-08-28 00:08:17 +02:00
|
|
|
void audio::drain::Algo::generateStatus(const etk::String& _status) {
|
2015-03-18 21:47:27 +01:00
|
|
|
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
|
|
|
}
|