2015-11-16 23:49:54 -05:00
|
|
|
#include "ModemST.h"
|
|
|
|
|
2015-11-28 23:03:07 -05:00
|
|
|
ModemST::ModemST() : ModemDigital() {
|
2015-11-18 21:09:51 -05:00
|
|
|
demodST = modem_create(LIQUID_MODEM_V29);
|
|
|
|
}
|
|
|
|
|
|
|
|
Modem *ModemST::factory() {
|
|
|
|
return new ModemST;
|
|
|
|
}
|
|
|
|
|
2015-11-18 23:40:30 -05:00
|
|
|
std::string ModemST::getName() {
|
|
|
|
return "ST";
|
|
|
|
}
|
|
|
|
|
2015-11-18 21:09:51 -05:00
|
|
|
ModemST::~ModemST() {
|
|
|
|
modem_destroy(demodST);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ModemST::demodulate(ModemKit *kit, ModemIQData *input, AudioThreadInput *audioOut) {
|
2015-11-18 22:57:31 -05:00
|
|
|
ModemKitDigital *dkit = (ModemKitDigital *)kit;
|
|
|
|
digitalStart(dkit, demodST, input);
|
|
|
|
|
2015-11-18 21:31:59 -05:00
|
|
|
for (int i = 0, bufSize = input->data.size(); i < bufSize; i++) {
|
|
|
|
modem_demodulate(demodST, input->data[i], &demodOutputDataDigital[i]);
|
|
|
|
}
|
|
|
|
updateDemodulatorLock(demodST, 0.005f);
|
2015-11-18 22:57:31 -05:00
|
|
|
|
|
|
|
digitalFinish(dkit, demodST);
|
2015-11-18 21:09:51 -05:00
|
|
|
}
|