21#ifndef OSMOSDR_SINK_IFACE_H
22#define OSMOSDR_SINK_IFACE_H
26#include <gnuradio/basic_block.h>
121 size_t chan = 0 ) = 0;
130 virtual bool set_gain_mode(
bool automatic,
size_t chan = 0 ) {
return false; }
147 virtual double set_gain(
double gain,
size_t chan = 0 ) = 0;
157 const std::string & name,
158 size_t chan = 0 ) = 0;
173 virtual double get_gain(
const std::string & name,
size_t chan = 0 ) = 0;
183 virtual double set_if_gain(
double gain,
size_t chan = 0 ) {
return 0; }
193 virtual double set_bb_gain(
double gain,
size_t chan = 0 ) {
return 0; }
200 virtual std::vector< std::string >
get_antennas(
size_t chan = 0 ) = 0;
209 size_t chan = 0 ) = 0;
225 virtual void set_dc_offset(
const std::complex<double> &offset,
size_t chan = 0 ) { }
234 virtual void set_iq_balance(
const std::complex<double> &balance,
size_t chan = 0 ) { }
242 virtual double set_bandwidth(
double bandwidth,
size_t chan = 0 ) {
return 0; }
268 const size_t mboard = 0) { }
284 return std::vector<std::string>();
295 const size_t mboard = 0) { }
311 return std::vector<std::string>();
335 return ::osmosdr::time_spec_t::get_system_time();
345 return ::osmosdr::time_spec_t::get_system_time();
354 size_t mboard = 0) { }
Definition: sink_iface.h:33
virtual osmosdr::gain_range_t get_gain_range(const std::string &name, size_t chan=0)=0
virtual double set_gain(double gain, const std::string &name, size_t chan=0)=0
virtual double get_freq_corr(size_t chan=0)=0
virtual void set_clock_source(const std::string &source, const size_t mboard=0)
Definition: sink_iface.h:294
virtual bool get_gain_mode(size_t chan=0)
Definition: sink_iface.h:137
virtual double get_clock_rate(size_t mboard=0)
Definition: sink_iface.h:319
virtual double set_freq_corr(double ppm, size_t chan=0)=0
virtual osmosdr::meta_range_t get_sample_rates(void)=0
virtual double set_gain(double gain, size_t chan=0)=0
virtual double get_gain(size_t chan=0)=0
virtual void set_dc_offset(const std::complex< double > &offset, size_t chan=0)
Definition: sink_iface.h:225
virtual std::string set_antenna(const std::string &antenna, size_t chan=0)=0
virtual ::osmosdr::time_spec_t get_time_last_pps(size_t mboard=0)
Definition: sink_iface.h:343
virtual std::string get_time_source(const size_t mboard)
Definition: sink_iface.h:275
virtual ::osmosdr::time_spec_t get_time_now(size_t mboard=0)
Definition: sink_iface.h:333
virtual void set_time_now(const ::osmosdr::time_spec_t &time_spec, size_t mboard=0)
Definition: sink_iface.h:353
virtual void set_time_unknown_pps(const ::osmosdr::time_spec_t &time_spec)
Definition: sink_iface.h:366
virtual void set_time_source(const std::string &source, const size_t mboard=0)
Definition: sink_iface.h:267
virtual std::vector< std::string > get_gain_names(size_t chan=0)=0
virtual void set_iq_balance(const std::complex< double > &balance, size_t chan=0)
Definition: sink_iface.h:234
virtual double set_center_freq(double freq, size_t chan=0)=0
virtual double set_bandwidth(double bandwidth, size_t chan=0)
Definition: sink_iface.h:242
virtual osmosdr::freq_range_t get_freq_range(size_t chan=0)=0
virtual std::vector< std::string > get_time_sources(const size_t mboard)
Definition: sink_iface.h:282
virtual void set_clock_rate(double rate, size_t mboard=0)
Definition: sink_iface.h:326
virtual double get_center_freq(size_t chan=0)=0
virtual bool set_gain_mode(bool automatic, size_t chan=0)
Definition: sink_iface.h:130
virtual double set_if_gain(double gain, size_t chan=0)
Definition: sink_iface.h:183
virtual size_t get_num_channels(void)=0
virtual void set_time_next_pps(const ::osmosdr::time_spec_t &time_spec)
Definition: sink_iface.h:360
virtual double set_bb_gain(double gain, size_t chan=0)
Definition: sink_iface.h:193
virtual std::string get_clock_source(const size_t mboard)
Definition: sink_iface.h:302
virtual double get_gain(const std::string &name, size_t chan=0)=0
virtual std::vector< std::string > get_clock_sources(const size_t mboard)
Definition: sink_iface.h:309
virtual osmosdr::freq_range_t get_bandwidth_range(size_t chan=0)
Definition: sink_iface.h:256
virtual double set_sample_rate(double rate)=0
virtual std::string get_antenna(size_t chan=0)=0
virtual std::vector< std::string > get_antennas(size_t chan=0)=0
virtual double get_sample_rate(void)=0
virtual double get_bandwidth(size_t chan=0)
Definition: sink_iface.h:249
virtual osmosdr::gain_range_t get_gain_range(size_t chan=0)=0
meta_range_t freq_range_t
Definition: ranges.h:125