Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[binary filter] change boolean ros params documentation #460

Draft
wants to merge 6 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
69 changes: 67 additions & 2 deletions configuration/packages/costmap-plugins/binary_filter.rst
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
Binary Filter Parameters
========================

Binary Filter - is a Costmap Filter that publishes a boolean topic, flipping binary state when the encoded filter space value (corresponding to the filter mask point where the robot is) is higher than given threshold. It then flips back when lower or equal.
Binary Filter - is a Costmap Filter that publishes a boolean topic, flipping binary state when the encoded filter space value (corresponding to the filter mask point where the robot is) is higher than given threshold. It then flips back when lower or equal. Along with publishing the state, the filter can change boolean ros parameters of other ros nodes. The parameters to be changed can be configured as ros parameters themselves.

Filter space value is being calculated as: ``Fv = base + multiplier * mask_value``, where ``base`` and ``multiplier`` are being published in a filter info by Costmap Filter Info Server. The example of usage are include: camera operating on/off to turn off cameras in sensitive areas, headlights switch on/off for moving indoors to outdoors, smart house light triggering, etc.

Expand Down Expand Up @@ -75,9 +75,64 @@ Filter space value is being calculated as: ``Fv = base + multiplier * mask_value
double 50.0
====== =======

Descrioption
Description
Threshold for binary state flipping. Filter values higher than this threshold, will set binary state to non-default.

:``<filter name>``.change_parameter_timeout:

====== =======
Type Default
------ -------
int 10
====== =======

Description
Timeout for waiting `set_parameters` service in ms. Target ros parameter is not changed in case of timeout.

:``<filter name>``.binary_parameters:

============== =======
Type Default
-------------- -------
vector<string> {“”}
============== =======

Description
Namespaces of parameters to be changed.

:``<filter name>``.``binary_parameter``.node_name:

====== =======
Type Default
------ -------
string ""
====== =======

Description
Name of the node to which the ros parameter to be changed belong.

:``<filter name>``.``binary_parameter``.param_name:

====== =======
Type Default
------ -------
string ""
====== =======

Description
Name of the parameter to be changed. This name should include also parameter namespace.

:``<filter name>``.``binary_parameter``.default_state:

====== =======================================
Type Default
------ ---------------------------------------
bool Same as ``<filter name>``.default_state
====== =======================================

Description
Parameter default state. If not specified, filter default state is used.

Example
*******
.. code-block:: yaml
Expand All @@ -97,3 +152,13 @@ Example
default_state: False
binary_state_topic: "/binary_state"
flip_threshold: 50.0
change_parameter_timeout: 10
binary_parameters: ["param1", "param2"]
param1:
node_name: "node0"
param_name: "name.of.param1"
default_state: True
param2:
node_name: "node1"
param_name: "param2"

7 changes: 6 additions & 1 deletion migration/Iron.rst
Original file line number Diff line number Diff line change
Expand Up @@ -117,4 +117,9 @@ The costmap activation fails when required transforms are not available
***********************************************************************

In this `PR #3866 <https://github.com/ros-planning/navigation2/pull/3866>`_ the parameter ``initial_transform_timeout`` is added to the costmap. The activation of the costmap now fails,
if the transformation from the robot base frame to the global frame does not become available during this timeout.
if the transformation from the robot base frame to the global frame does not become available during this timeout.

Binary Filter able to change boolean ros parameters
****************************************************

`PR #3796 <https://github.com/ros-planning/navigation2/pull/3796>`_ modifies the binary filter to make it able to change boolean ros parameters.