21 #ifndef OSMOSDR_SOURCE_IFACE_H 22 #define OSMOSDR_SOURCE_IFACE_H 25 #include <gnuradio/basic_block.h> 47 virtual bool seek(
long seek_point,
int whence,
size_t chan = 0 ) {
return false; }
99 virtual double set_freq_corr(
double ppm,
size_t chan = 0 ) = 0;
113 virtual std::vector<std::string>
get_gain_names(
size_t chan = 0 ) = 0;
129 size_t chan = 0 ) = 0;
138 virtual bool set_gain_mode(
bool automatic,
size_t chan = 0 ) {
return false; }
155 virtual double set_gain(
double gain,
size_t chan = 0 ) = 0;
164 virtual double set_gain(
double gain,
165 const std::string & name,
166 size_t chan = 0 ) = 0;
173 virtual double get_gain(
size_t chan = 0 ) = 0;
181 virtual double get_gain(
const std::string & name,
size_t chan = 0 ) = 0;
191 virtual double set_if_gain(
double gain,
size_t chan = 0 ) {
return 0; }
201 virtual double set_bb_gain(
double gain,
size_t chan = 0 ) {
return 0; }
208 virtual std::vector< std::string >
get_antennas(
size_t chan = 0 ) = 0;
215 virtual std::string
set_antenna(
const std::string & antenna,
216 size_t chan = 0 ) = 0;
223 virtual std::string
get_antenna(
size_t chan = 0 ) = 0;
247 virtual void set_dc_offset(
const std::complex<double> &offset,
size_t chan = 0 ) { }
264 virtual void set_iq_balance(
const std::complex<double> &balance,
size_t chan = 0 ) { }
272 virtual double set_bandwidth(
double bandwidth,
size_t chan = 0 ) {
return 0; }
290 #endif // OSMOSDR_SOURCE_IFACE_H virtual double set_bb_gain(double gain, size_t chan=0)
Definition: source_iface.h:201
Definition: source_iface.h:31
virtual double get_gain(size_t chan=0)=0
meta_range_t freq_range_t
Definition: ranges.h:119
virtual std::vector< std::string > get_antennas(size_t chan=0)=0
virtual bool seek(long seek_point, int whence, size_t chan=0)
seek file to seek_point relative to whence
Definition: source_iface.h:47
virtual bool get_gain_mode(size_t chan=0)
Definition: source_iface.h:145
virtual osmosdr::freq_range_t get_freq_range(size_t chan=0)=0
virtual void set_dc_offset(const std::complex< double > &offset, size_t chan=0)
Definition: source_iface.h:247
virtual osmosdr::gain_range_t get_gain_range(size_t chan=0)=0
virtual osmosdr::meta_range_t get_sample_rates(void)=0
virtual void set_iq_balance_mode(int mode, size_t chan=0)
Definition: source_iface.h:255
virtual std::string get_antenna(size_t chan=0)=0
virtual double get_freq_corr(size_t chan=0)=0
virtual double get_sample_rate(void)=0
virtual double set_sample_rate(double rate)=0
virtual void set_iq_balance(const std::complex< double > &balance, size_t chan=0)
Definition: source_iface.h:264
virtual double set_if_gain(double gain, size_t chan=0)
Definition: source_iface.h:191
virtual std::vector< std::string > get_gain_names(size_t chan=0)=0
virtual std::string set_antenna(const std::string &antenna, size_t chan=0)=0
virtual bool set_gain_mode(bool automatic, size_t chan=0)
Definition: source_iface.h:138
virtual double set_freq_corr(double ppm, size_t chan=0)=0
virtual size_t get_num_channels(void)=0
virtual double get_center_freq(size_t chan=0)=0
virtual double set_center_freq(double freq, size_t chan=0)=0
virtual double set_bandwidth(double bandwidth, size_t chan=0)
Definition: source_iface.h:272
virtual double set_gain(double gain, size_t chan=0)=0
virtual void set_dc_offset_mode(int mode, size_t chan=0)
Definition: source_iface.h:237
virtual double get_bandwidth(size_t chan=0)
Definition: source_iface.h:279
virtual osmosdr::freq_range_t get_bandwidth_range(size_t chan=0)
Definition: source_iface.h:286