CubicSDR/src/modules/modem/digital/ModemOOK.cpp

40 lines
946 B
C++
Raw Normal View History

// Copyright (c) Charles J. Cliffe
// SPDX-License-Identifier: GPL-2.0+
#include "ModemOOK.h"
ModemOOK::ModemOOK() : ModemDigital() {
demodOOK = modem_create(LIQUID_MODEM_OOK);
}
ModemOOK::~ModemOOK() {
modem_destroy(demodOOK);
}
std::string ModemOOK::getName() {
return "OOK";
}
2015-11-18 22:57:31 -05:00
ModemBase *ModemOOK::factory() {
return new ModemOOK;
}
int ModemOOK::checkSampleRate(long long sampleRate, int audioSampleRate) {
if (sampleRate < 100) {
return 100;
}
return sampleRate;
}
void ModemOOK::demodulate(ModemKit *kit, ModemIQData *input, AudioThreadInput *audioOut) {
2015-11-18 22:57:31 -05:00
ModemKitDigital *dkit = (ModemKitDigital *)kit;
digitalStart(dkit, demodOOK, input);
for (size_t i = 0, bufSize=input->data.size(); i < bufSize; i++) {
modem_demodulate(demodOOK, input->data[i], &demodOutputDataDigital[i]);
}
updateDemodulatorLock(demodOOK, 0.005f);
2015-11-18 22:57:31 -05:00
digitalFinish(dkit, demodOOK);
}