// Copyright (c) Charles J. Cliffe // SPDX-License-Identifier: GPL-2.0+ #pragma once #include "Modem.h" class ModemKitFMStereo: public ModemKit { public: ModemKitFMStereo() : audioResampler(nullptr), stereoResampler(nullptr), audioResampleRatio(0), firStereoLeft(nullptr), firStereoRight(nullptr), iirStereoPilot(nullptr) { } msresamp_rrrf audioResampler; msresamp_rrrf stereoResampler; double audioResampleRatio; firfilt_rrrf firStereoLeft; firfilt_rrrf firStereoRight; iirfilt_crcf iirStereoPilot; int demph; iirfilt_rrrf iirDemphR; iirfilt_rrrf iirDemphL; firhilbf firStereoR2C; firhilbf firStereoC2R; nco_crcf stereoPilot; }; class ModemFMStereo : public Modem { public: ModemFMStereo(); ~ModemFMStereo(); std::string getType(); std::string getName(); static ModemBase *factory(); int checkSampleRate(long long sampleRate, int audioSampleRate); int getDefaultSampleRate(); ModemArgInfoList getSettings(); void writeSetting(std::string setting, std::string value); std::string readSetting(std::string setting); ModemKit *buildKit(long long sampleRate, int audioSampleRate); void disposeKit(ModemKit *kit); void demodulate(ModemKit *kit, ModemIQData *input, AudioThreadInput *audioOut); private: std::vector demodOutputData; std::vector demodStereoData; std::vector resampledOutputData; std::vector resampledStereoData; freqdem demodFM; int _demph; };