mirror of
https://github.com/f4exb/sdrangel.git
synced 2024-11-23 00:18:37 -05:00
87 lines
3.5 KiB
C++
87 lines
3.5 KiB
C++
///////////////////////////////////////////////////////////////////////////////////
|
|
// Copyright (C) 2012 maintech GmbH, Otto-Hahn-Str. 15, 97204 Hoechberg, Germany //
|
|
// written by Christian Daniel //
|
|
// Copyright (C) 2015-2023 Edouard Griffiths, F4EXB <f4exb06@gmail.com> //
|
|
// Copyright (C) 2020 Kacper Michajłow <kasper93@gmail.com> //
|
|
// //
|
|
// Swagger server adapter interface //
|
|
// //
|
|
// 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 //
|
|
// (at your option) any later version. //
|
|
// //
|
|
// 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 <http://www.gnu.org/licenses/>. //
|
|
///////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef SDRBENCH_MAINBENCH_H_
|
|
#define SDRBENCH_MAINBENCH_H_
|
|
|
|
#include <QObject>
|
|
#include <random>
|
|
#include <functional>
|
|
|
|
#include "dsp/decimators.h"
|
|
#include "dsp/decimatorsif.h"
|
|
#include "dsp/decimatorsfi.h"
|
|
#include "dsp/decimatorsff.h"
|
|
#include "parserbench.h"
|
|
#include "export.h"
|
|
|
|
namespace qtwebapp {
|
|
class LoggerWithFile;
|
|
}
|
|
|
|
class SDRBENCH_API MainBench: public QObject {
|
|
Q_OBJECT
|
|
|
|
public:
|
|
explicit MainBench(qtwebapp::LoggerWithFile *logger, const ParserBench& parser, QObject *parent = 0);
|
|
~MainBench();
|
|
|
|
public slots:
|
|
void run();
|
|
|
|
signals:
|
|
void finished();
|
|
|
|
private:
|
|
void testDecimateII(ParserBench::TestType testType = ParserBench::TestDecimatorsII);
|
|
void testDecimateIF();
|
|
void testDecimateFI();
|
|
void testDecimateFF();
|
|
void testGolay2312();
|
|
void testFT8(const QString& wavFile, const QString& argsStr); //!< use with sdrbench/samples/ft8/230105_091630.wav in -f option
|
|
void decimateII(const qint16 *buf, int len);
|
|
void decimateInfII(const qint16 *buf, int len);
|
|
void decimateSupII(const qint16 *buf, int len);
|
|
void decimateIF(const qint16 *buf, int len);
|
|
void decimateFI(const float *buf, int len);
|
|
void decimateFF(const float *buf, int len);
|
|
void printResults(const QString& prefix, qint64 nsecs);
|
|
|
|
|
|
static MainBench *m_instance;
|
|
qtwebapp::LoggerWithFile *m_logger;
|
|
const ParserBench& m_parser;
|
|
std::mt19937 m_generator;
|
|
std::uniform_real_distribution<float> m_uniform_distribution_f;
|
|
std::uniform_int_distribution<qint16> m_uniform_distribution_s16;
|
|
|
|
Decimators<qint32, qint16, SDR_RX_SAMP_SZ, 12, true> m_decimatorsII;
|
|
DecimatorsIF<qint16, 12, true> m_decimatorsIF;
|
|
DecimatorsFI<true> m_decimatorsFI;
|
|
DecimatorsFF<true> m_decimatorsFF;
|
|
|
|
SampleVector m_convertBuffer;
|
|
FSampleVector m_convertBufferF;
|
|
};
|
|
|
|
#endif // SDRBENCH_MAINBENCH_H_
|