50 lines
1.4 KiB
C
Raw Normal View History

2020-06-10 18:52:07 +02:00
#pragma once
2020-06-22 16:45:57 +02:00
#include <dsp/filter.h>
#include <dsp/resampling.h>
#include <dsp/source.h>
#include <dsp/math.h>
#include <dsp/demodulator.h>
#include <dsp/routing.h>
#include <dsp/sink.h>
#include <dsp/correction.h>
#include <dsp/vfo.h>
2020-08-11 18:33:42 +02:00
#include <map>
#include <module.h>
2020-06-10 18:52:07 +02:00
class SignalPath {
public:
SignalPath();
2020-06-22 16:45:57 +02:00
void init(uint64_t sampleRate, int fftRate, int fftSize, dsp::stream<dsp::complex_t>* input, dsp::complex_t* fftBuffer, void fftHandler(dsp::complex_t*));
2020-06-10 18:52:07 +02:00
void start();
void setSampleRate(double sampleRate);
2020-06-10 18:52:07 +02:00
void setDCBiasCorrection(bool enabled);
void setFFTRate(double rate);
2020-10-22 12:53:46 +02:00
double getSampleRate();
dsp::VFO* addVFO(std::string name, double outSampleRate, double bandwidth, double offset);
2020-08-11 18:33:42 +02:00
void removeVFO(std::string name);
2020-10-01 01:21:15 +02:00
void setInput(dsp::stream<dsp::complex_t>* input);
2020-10-22 12:53:46 +02:00
void bindIQStream(dsp::stream<dsp::complex_t>* stream);
void unbindIQStream(dsp::stream<dsp::complex_t>* stream);
2020-06-10 18:52:07 +02:00
2020-08-11 18:33:42 +02:00
private:
struct VFO_t {
dsp::stream<dsp::complex_t>* inputStream;
dsp::VFO* vfo;
2020-06-15 15:53:45 +02:00
};
2020-06-22 16:45:57 +02:00
dsp::DCBiasRemover dcBiasRemover;
dsp::Splitter split;
2020-06-15 15:53:45 +02:00
// FFT
2020-06-22 16:45:57 +02:00
dsp::BlockDecimator fftBlockDec;
dsp::HandlerSink fftHandlerSink;
2020-06-15 15:53:45 +02:00
// VFO
2020-08-16 03:39:05 +02:00
dsp::DynamicSplitter<dsp::complex_t> dynSplit;
2020-08-11 18:33:42 +02:00
std::map<std::string, VFO_t> vfos;
2020-06-22 16:45:57 +02:00
double sampleRate;
double fftRate;
2020-06-10 18:52:07 +02:00
int fftSize;
2020-08-11 18:33:42 +02:00
int inputBlockSize;
2020-06-10 18:52:07 +02:00
};