ros2_control - rolling
Loading...
Searching...
No Matches
Public Member Functions | List of all members
control_toolbox::LowPassFilter< T > Class Template Reference

A Low-pass filter class. More...

#include <low_pass_filter.hpp>

Public Member Functions

 LowPassFilter (double sampling_frequency, double damping_frequency, double damping_intensity)
 
 ~LowPassFilter ()
 Destructor of LowPassFilter class.
 
bool configure ()
 Configure the LowPassFilter (access and process params).
 
bool update (const T &data_in, T &data_out)
 Applies one iteration of the IIR filter.
 
bool is_configured () const
 
void set_params (double sampling_frequency, double damping_frequency, double damping_intensity)
 Internal computation of the feedforward and feedbackward coefficients according to the LowPassFilter parameters.
 
bool update (const geometry_msgs::msg::WrenchStamped &data_in, geometry_msgs::msg::WrenchStamped &data_out)
 

Detailed Description

template<typename T>
class control_toolbox::LowPassFilter< T >

A Low-pass filter class.

This class implements a low-pass filter for various data types based on an Infinite Impulse Response Filter. For vector elements, the filtering is applied separately on each element of the vector.

In particular, this class implements a simplified version of an IIR filter equation :

\(y(n) = b x(n-1) + a y(n-1)\)

where:

and the Low-Pass coefficient equation:

where:

Usage

For manual instantiation, you should first call configure() (in non-realtime) and then call update() at every update step.

Member Function Documentation

◆ update()

template<typename T >
bool control_toolbox::LowPassFilter< T >::update ( const T &  data_in,
T &  data_out 
)

Applies one iteration of the IIR filter.

Parameters
data_ininput to the filter
data_outfiltered output
Returns
false if filter is not configured, true otherwise

The documentation for this class was generated from the following file: