blob: d23340a8228966fa4b395d74e11add200b5232ce (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
//
// Copyright 2020 Ettus Research, a National Instruments Brand
//
// SPDX-License-Identifier: GPL-3.0-or-later
//
#pragma once
#include <uhd/config.hpp>
#include <uhd/rfnoc/noc_block_base.hpp>
namespace uhd { namespace rfnoc {
/*! Vector IIR Block Control Class
*
* The Vector IIR Block is an RFNoC block that implements an infinite
* impulse filter with a variable length delay line. The transfer
* function is defined as follows:
*
* beta
* H(z) = ------------------------
* 1 - alpha * z ^ -delay
*
* where
* - beta is the feedforward tap
* - alpha is the feedback tap
* - delay (a.k.a. vector length) is the feedback tap delay
*/
class UHD_API vector_iir_block_control : public noc_block_base
{
public:
RFNOC_DECLARE_BLOCK(vector_iir_block_control)
static const uint32_t REG_BLOCK_SIZE;
static const uint32_t REG_DELAY_OFFSET;
static const uint32_t REG_ALPHA_OFFSET;
static const uint32_t REG_BETA_OFFSET;
/*! Set the feedback tap value
*
* Sets the feedback tap value for channel \p chan of the IIR filter.
*
* \param alpha The feedback tap value for the filter
* \param chan The channel to apply the feedback tap value to
*/
virtual void set_alpha(const double alpha, const size_t chan) = 0;
/*! Return the feedback tap value
*
* Returns the feedback tap value for channel \p chan of the IIR filter.
*
* \param chan The channel to retrieve the feedback tap value from
* \returns The feedback tap value for the filter
*/
virtual double get_alpha(const size_t chan) const = 0;
/*! Set the feedforward tap value
*
* Sets the feedforward tap value for channel \p chan of the IIR filter.
*
* \param beta The feedforward tap value for the filter
* \param chan The channel to apply the feedforward tap value to
*/
virtual void set_beta(const double beta, const size_t chan) = 0;
/*! Return the feedforward tap value
*
* Returns the feedforward tap value for channel \p chan of the IIR filter.
*
* \param chan The channel to retrieve the feedforward tap value from
* \returns The feedforward tap value for the filter
*/
virtual double get_beta(const size_t chan) const = 0;
/*! Set the feedback tap delay
*
* Sets the feedback tap delay in samples for channel \p chan of the IIR
* filter. The delay value for the filter must be less than or equal to
* the maximum delay length supported by the filter.
*
* \param delay The feedback tap delay of the filter in samples
* \param chan The channel to apply the feedback tap delay to
*/
virtual void set_delay(const uint16_t delay, const size_t chan) = 0;
/*! Return the feedback tap delay
*
* Returns the feedback tap delay value in samples for channel \p chan
* of the IIR filter.
*
* \param chan The channel to retrieve the feedback tap delay value from
* \returns The feedback tap delay of the filter in samples
*/
virtual uint16_t get_delay(const size_t chan) const = 0;
/*! Return the maximum filter delay
*
* Returns the maximum allowable filter delay value, in samples, for
* channel \p chan.
*
* \param chan The channel to retrieve the maximum delay from
* \returns The maximum filter delay
*/
virtual uint16_t get_max_delay(const size_t chan) const = 0;
};
}} // namespace uhd::rfnoc
|