Show EOL distros:
Stack Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters. This package is still relatively young. New features are expected in coming releases see the common stack roadmap for more information. However any change will have long term backwards compatability.
- Author: Tully Foote/[email protected]
- License: BSD
- External website: http://pr.willowgarage.com
- Repository: ros-pkg
- Source: svn https://code.ros.org/svn/ros-pkg/stacks/common/tags/common-1.4.3
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Author: Tully Foote/[email protected]
- License: BSD
- Source: hg https://kforge.ros.org/common/filters (branch: filters)
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Author: Tully Foote/[email protected]
- License: BSD
- Source: hg https://kforge.ros.org/common/filters (branch: filters)
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Author: Tully Foote/[email protected]
- License: BSD
- Source: hg https://kforge.ros.org/common/filters (branch: filters)
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Maintainer status: maintained
- Maintainer: Tully Foote <tfoote AT willowgarage DOT com>
- Author:
- License: BSD
- Source: git https://github.com/ros/filters.git (branch: hydro-devel)
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Maintainer status: maintained
- Maintainer: Tully Foote <tfoote AT willowgarage DOT com>
- Author:
- License: BSD
- Source: git https://github.com/ros/filters.git (branch: hydro-devel)
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Maintainer status: maintained
- Maintainer: Tully Foote <tfoote AT willowgarage DOT com>
- Author:
- License: BSD
- Source: git https://github.com/ros/filters.git (branch: hydro-devel)
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Maintainer status: maintained
- Maintainer: Tully Foote <tfoote AT willowgarage DOT com>
- Author:
- License: BSD
- Source: git https://github.com/ros/filters.git (branch: hydro-devel)
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Maintainer status: maintained
- Maintainer: Tully Foote <tfoote AT willowgarage DOT com>
- Author:
- License: BSD
- Source: git https://github.com/ros/filters.git (branch: lunar-devel)
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Maintainer status: maintained
- Maintainer: Tully Foote <tfoote AT willowgarage DOT com>
- Author:
- License: BSD
- Source: git https://github.com/ros/filters.git (branch: lunar-devel)
Package Summary
This library provides a standardized interface for processing data as a sequence of filters. This package contains a base class upon which to build specific implementations as well as an interface which dynamically loads filters based on runtime parameters.
- Maintainer status: maintained
- Maintainer: Tully Foote <tfoote AT willowgarage DOT com>
- Author:
- License: BSD
- Source: git https://github.com/ros/filters.git (branch: noetic-devel)
Contents
New in Electric: filters is now a separate stack. In previous releases, it was part of common.
Pre-requisite: Pluginlib
Filters are closely linked to pluginlib. Please make sure that you are familiar with the pluginlib documentation before continuing.
Using Filters
It is recommended to use a filters::FilterChain whenever using more than one instances of filters::Filter. However, you need to understand the base Filter C API first before using the Filter Chain API.
Filter
The core of the filters Package is a templated base class filters::FilterBase<TemplateType> which defines the external API to any filter. The methods are configure() and update(). It also provides helper methods for a Filter implementation. To use a Filter simply instantiate it in your code.
Filters are configured from parameters on the Parameter Server. The configure method passes in the parameter namespace to read from of the Parameter Server.
Currently Implemented Filters
Filter ROS Parameters
A Filter expects to find a map with three elements: name, type and params.
name (string)
- a unique name for debugging purposes within the chain being used.
type (string)
the Filter's typename as declared in it's pluginlib registration.
params (map)
- data to present to the Filter implementation.
Example configuration
parameter_namespace_passed_to_configure: name: unique_name type: FilterName params: { param1: a, param2: b}
Filter Chain
The filters::FilterChain class has been designed to facilitate dynamically loading a sequence of Filters based on runtime parameters. The Filter Chain is configured from the Parameter Server just like Filters. Based on the parameters the Filter Chain will dynamically load the Filters by their name.
The public API looks just like the Filter API with configure() and update() methods.
Filter Chain ROS Parameters
filter_chain (list(Filters))
Parameter containing properly formatted Filters. See Filter ROS Parameters.
Example configuration
param_namespace_passed_to_configure: filter_chain: - name: median_test_unique type: MultiChannelMedianFilterDouble params: {number_of_observations: 5} - name: median_test2 type: MultiChannelMedianFilterDouble params: {number_of_observations: 5}
Using a Filter Chain
Here's an example of a multi-channel filter chain for doubles. To do a non-vector style use a filters::FilterChain<double> and change in and out to type double.
Initialization:
filters::MultiChannelFilterChain<double> chain("double"); //Node template type and argument must match chain.configure("param_namespace_passed_to_configure"); std::vector<double> in, out;
Process data: assuming in is populated
chain.update(in, out);
Implementing a Filter
Implementing a Filter is simply a specific form of a dynamically loaded class for pluginlib.
Steps to create a filter
Create a class which inherits from FilterBase<T>
Implement configure() method
Implement update() method
- In the source for the class call
PLUGINLIB_REGISTER_PLUGIN(UniqueFullClassNameSoSpecialCharacters, my_package::ClassName, filters::FilterBase<Type>)
New in Groovy: A new simpler plugin macro is now recommended:
PLUGINLIB_EXPORT_PLUGIN(my_package::ClassName, filters::FilterBase<Type>)
Create a plugin description file, see pluginlib
Add an export to your manifest.xml pointing to the plugin description file, see pluginlib
Make sure you depend on the filters package in your manifest.xml.
MultiChannelFilterBase and MultiChannelFilterChain
This whole document refers simply to filters::FilterBase and filters::FilterChain. However there are MultiChannel versions of both. Instead of the templated data type, T, they expect std::vector<T> on the update calls. And the configure method has one extra argument which is the number of channels expected(aka how many elements are expected in the vector).