USRP Hardware Driver and USRP Manual  Version: 4.0.0.0-0-unknown
UHD and USRP Manual
siggen_block_control.hpp
Go to the documentation of this file.
1 //
2 // Copyright 2020 Ettus Research, a National Instruments Brand
3 //
4 // SPDX-License-Identifier: GPL-3.0-or-later
5 //
6 
7 #pragma once
8 
9 #include <uhd/config.hpp>
11 #include <uhd/utils/math.hpp>
12 #include <complex>
13 
14 namespace uhd { namespace rfnoc {
15 
25 enum class siggen_waveform { CONSTANT, SINE_WAVE, NOISE };
26 
28 {
29 public:
31 
32  static const uint32_t REG_BLOCK_SIZE;
33  static const uint32_t REG_ENABLE_OFFSET;
34  static const uint32_t REG_SPP_OFFSET;
35  static const uint32_t REG_WAVEFORM_OFFSET;
36  static const uint32_t REG_GAIN_OFFSET;
37  static const uint32_t REG_CONSTANT_OFFSET;
38  static const uint32_t REG_PHASE_INC_OFFSET;
39  static const uint32_t REG_CARTESIAN_OFFSET;
40 
49  virtual void set_enable(const bool enable, const size_t port) = 0;
50 
59  virtual bool get_enable(const size_t port) const = 0;
60 
69  virtual void set_waveform(const siggen_waveform type, const size_t port) = 0;
70 
78  virtual siggen_waveform get_waveform(const size_t port) const = 0;
79 
98  virtual void set_amplitude(const double amplitude, const size_t port) = 0;
99 
110  virtual double get_amplitude(const size_t port) const = 0;
111 
125  virtual void set_constant(const std::complex<double> constant, const size_t port) = 0;
126 
136  virtual std::complex<double> get_constant(const size_t port) const = 0;
137 
147  virtual void set_sine_phase_increment(const double phase_inc, const size_t port) = 0;
148 
158  virtual double get_sine_phase_increment(const size_t port) const = 0;
159 
169  virtual void set_samples_per_packet(const size_t spp, const size_t port) = 0;
170 
179  virtual size_t get_samples_per_packet(const size_t port) const = 0;
180 
191  inline void set_sine_frequency(
192  const double frequency, const double sample_rate, const size_t port)
193  {
194  if (sample_rate <= 0.0) {
195  throw uhd::value_error("sample_rate must be > 0.0");
196  }
197  const double phase_inc = (frequency / sample_rate) * 2.0 * uhd::math::PI;
198  if (phase_inc < -uhd::math::PI || phase_inc > uhd::math::PI) {
199  throw uhd::value_error("frequency must be in [-samp_rate/2, samp_rate/2]");
200  }
201  set_sine_phase_increment(phase_inc, port);
202  }
203 };
204 
205 }} // namespace uhd::rfnoc
206 
uhd::rfnoc::siggen_waveform::CONSTANT
@ CONSTANT
uhd::rfnoc::siggen_block_control::get_enable
virtual bool get_enable(const size_t port) const =0
config.hpp
uhd::rfnoc::noc_block_base
Definition: noc_block_base.hpp:42
uhd::value_error
Definition: exception.hpp:109
uhd::rfnoc::siggen_block_control
Definition: siggen_block_control.hpp:28
uhd::rfnoc::siggen_block_control::set_amplitude
virtual void set_amplitude(const double amplitude, const size_t port)=0
uhd::rfnoc::siggen_block_control::set_waveform
virtual void set_waveform(const siggen_waveform type, const size_t port)=0
uhd::rfnoc::siggen_block_control::get_sine_phase_increment
virtual double get_sine_phase_increment(const size_t port) const =0
UHD_API
#define UHD_API
Definition: config.h:67
uhd::rfnoc::siggen_block_control::REG_BLOCK_SIZE
static const uint32_t REG_BLOCK_SIZE
Definition: siggen_block_control.hpp:32
uhd::rfnoc::siggen_block_control::REG_CARTESIAN_OFFSET
static const uint32_t REG_CARTESIAN_OFFSET
Definition: siggen_block_control.hpp:39
uhd::rfnoc::siggen_block_control::REG_GAIN_OFFSET
static const uint32_t REG_GAIN_OFFSET
Definition: siggen_block_control.hpp:36
uhd::rfnoc::siggen_block_control::REG_SPP_OFFSET
static const uint32_t REG_SPP_OFFSET
Definition: siggen_block_control.hpp:34
uhd::rfnoc::siggen_block_control::get_constant
virtual std::complex< double > get_constant(const size_t port) const =0
uhd
Definition: build_info.hpp:12
uhd::rfnoc::siggen_block_control::set_samples_per_packet
virtual void set_samples_per_packet(const size_t spp, const size_t port)=0
uhd::rfnoc::siggen_block_control::set_sine_phase_increment
virtual void set_sine_phase_increment(const double phase_inc, const size_t port)=0
uhd::rfnoc::siggen_block_control::RFNOC_DECLARE_BLOCK
RFNOC_DECLARE_BLOCK(siggen_block_control)
uhd::rfnoc::siggen_block_control::set_enable
virtual void set_enable(const bool enable, const size_t port)=0
uhd::rfnoc::siggen_block_control::REG_ENABLE_OFFSET
static const uint32_t REG_ENABLE_OFFSET
Definition: siggen_block_control.hpp:33
noc_block_base.hpp
uhd::rfnoc::siggen_block_control::set_constant
virtual void set_constant(const std::complex< double > constant, const size_t port)=0
uhd::rfnoc::siggen_block_control::get_waveform
virtual siggen_waveform get_waveform(const size_t port) const =0
uhd::rfnoc::siggen_waveform
siggen_waveform
Definition: siggen_block_control.hpp:25
uhd::rfnoc::siggen_block_control::REG_PHASE_INC_OFFSET
static const uint32_t REG_PHASE_INC_OFFSET
Definition: siggen_block_control.hpp:38
uhd::rfnoc::siggen_block_control::get_amplitude
virtual double get_amplitude(const size_t port) const =0
uhd::rfnoc::siggen_block_control::REG_CONSTANT_OFFSET
static const uint32_t REG_CONSTANT_OFFSET
Definition: siggen_block_control.hpp:37
uhd::rfnoc::siggen_block_control::set_sine_frequency
void set_sine_frequency(const double frequency, const double sample_rate, const size_t port)
Definition: siggen_block_control.hpp:191
math.hpp
uhd::rfnoc::siggen_block_control::get_samples_per_packet
virtual size_t get_samples_per_packet(const size_t port) const =0
uhd::rfnoc::siggen_block_control::REG_WAVEFORM_OFFSET
static const uint32_t REG_WAVEFORM_OFFSET
Definition: siggen_block_control.hpp:35