/////////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2016 Edouard Griffiths, F4EXB. // // // // This program is free software; you can redistribute it and/or modify // // it under the terms of the GNU General Public License as published by // // the Free Software Foundation as version 3 of the License, or // // // // This program is distributed in the hope that it will be useful, // // but WITHOUT ANY WARRANTY; without even the implied warranty of // // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // // GNU General Public License V3 for more details. // // // // You should have received a copy of the GNU General Public License // // along with this program. If not, see . // /////////////////////////////////////////////////////////////////////////////////// #ifndef DSDPLUS_DSD_FILTERS_H_ #define DSDPLUS_DSD_FILTERS_H_ #define NZEROS 60 #define NXZEROS 134 namespace DSDplus { class DSDFilters { public: DSDFilters(); ~DSDFilters(); static const float ngain = 7.423339364f; static const float xcoeffs[]; static const float nxgain = 15.95930463f; static const float nxcoeffs[]; short dsd_input_filter(short sample, int mode); short dmr_filter(short sample); short nxdn_filter(short sample); private: float xv[NZEROS+1]; float nxv[NXZEROS+1]; }; } #endif /* DSDPLUS_DSD_FILTERS_H_ */