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

Gpio command controller #1251

Merged
merged 68 commits into from
Nov 18, 2024
Merged
Changes from 1 commit
Commits
Show all changes
68 commits
Select commit Hold shift + click to select a range
5fecf27
added gpio_command_controller
mcbed Nov 2, 2022
6ffda9d
added doc to gpio controllers
mcbed Nov 2, 2022
f88fc7d
changed parameter interface_names to command_interfaces
mcbed Nov 2, 2022
56fc1e5
added test
mcbed Nov 2, 2022
9e73ab7
code formating
mcbed Nov 2, 2022
1cbd3a6
added gpio state publisher
Nov 2, 2022
7228e06
fixed broken node_state
Nov 2, 2022
880aeea
added DynamicJointState message for Gpio state
Nov 2, 2022
94befb0
fixed tests and added gpio state tests
Nov 2, 2022
882c936
fixed format
Nov 16, 2022
efce87a
Apply pre-commit fix
Wiktor-99 Jul 31, 2024
b53bff6
Fix compilation on ros rolling
Wiktor-99 Aug 1, 2024
67b6069
Add parameters file, use generated gpio_command_controller_parameters…
Wiktor-99 Aug 3, 2024
30d2604
Remove unnecessary members: interface_names_, gpios_names_ and use pa…
Wiktor-99 Aug 4, 2024
4c824e8
Refactor of storing interface types
Wiktor-99 Aug 4, 2024
dd86d9e
Remove unnecessary includes
Wiktor-99 Aug 4, 2024
4ac938d
Refacotr on_activate method. Add validate_configured_interfaces and i…
Wiktor-99 Aug 4, 2024
aa59297
Refactor update method, split update of state if and command if
Wiktor-99 Aug 4, 2024
6276617
Move test fixture form hpp to cpp
Wiktor-99 Aug 4, 2024
66bd971
Update docks and package.xml
Wiktor-99 Aug 4, 2024
7b70159
Add state validation
Wiktor-99 Aug 4, 2024
58c1afc
Store command and state ifs in the map
Wiktor-99 Aug 5, 2024
e5c65db
Use interface maps for command and state update. Use DynamicJointStat…
Wiktor-99 Aug 5, 2024
0dc5c87
Use ordered state if vector instead of map
Wiktor-99 Aug 6, 2024
765a3cb
Restore state if validation
Wiktor-99 Aug 6, 2024
a1c8fa3
Align logging
Wiktor-99 Aug 6, 2024
de8acba
Update code layout
Wiktor-99 Aug 7, 2024
aebbf0b
Simplifie test fixture
Wiktor-99 Aug 7, 2024
0deb417
Update tests. Stop using pointer, set members as public
Wiktor-99 Aug 7, 2024
3e7a12a
Add set of test for init
Wiktor-99 Aug 9, 2024
373053e
Add setup_command_and_state_interfaces as refactor UTs
Wiktor-99 Aug 13, 2024
1dc481f
Add two UTs to check wrong ifs assing
Wiktor-99 Aug 15, 2024
2bad07b
Add create node option function and remove redundant test
Wiktor-99 Aug 15, 2024
f78158e
Extract redundant code to methods
Wiktor-99 Aug 15, 2024
815f85e
Reafactor command UTs
Wiktor-99 Aug 16, 2024
0265503
Add two UTs for different commands
Wiktor-99 Aug 16, 2024
28db5aa
Add one more test with command with different ports order
Wiktor-99 Aug 16, 2024
4be8fac
Add UT for the wrong gpio/port name in the command
Wiktor-99 Aug 17, 2024
fc10ad5
Update package.xml
Wiktor-99 Aug 17, 2024
1ac37e4
Merge branch 'master' into gpio_controllers
Wiktor-99 Aug 17, 2024
e89d814
Update pkg version
Wiktor-99 Aug 22, 2024
9c90fb2
Fix includes
Wiktor-99 Aug 22, 2024
c165c1d
Fix linters
Wiktor-99 Aug 24, 2024
dd19879
Update toctree, add gpio controller info
Wiktor-99 Aug 24, 2024
b3d9ef4
Merge branch 'master' into gpio_controllers
Wiktor-99 Aug 26, 2024
4b60038
Merge branch 'master' into gpio_controllers
Wiktor-99 Sep 9, 2024
9fb380a
Merge branch 'master' into gpio_controllers
Wiktor-99 Sep 22, 2024
a2b1f4f
Merge branch 'master' into gpio_controllers
bmagyar Sep 26, 2024
b2eab6a
Merge branch 'master' into gpio_controllers
christophfroehlich Nov 3, 2024
510d847
Rename parameter and update docs
christophfroehlich Nov 3, 2024
4518b58
Set parameter read-only
christophfroehlich Nov 3, 2024
071e190
Update docs and improve error message
christophfroehlich Nov 3, 2024
fdfe17b
Fix tests
christophfroehlich Nov 3, 2024
8a8cd04
Merge pull request #2 from ros-controls/gpio_controllers
Wiktor-99 Nov 4, 2024
1e61111
Parametrize state interfaces
Wiktor-99 Nov 4, 2024
9929eb1
Parse URDF to get gpio state interfaces, add test and docs
Wiktor-99 Nov 4, 2024
13ba72b
Remove urdf model from controller
Wiktor-99 Nov 5, 2024
a8228af
Update docs after review
Wiktor-99 Nov 7, 2024
7bf2d4e
Create command subscriber only when any command interface is present.…
Wiktor-99 Nov 7, 2024
a8bc556
Merge branch 'master' into gpio_controllers
christophfroehlich Nov 11, 2024
9c30814
Update pkg xmls
Wiktor-99 Nov 16, 2024
39d885a
Add control_msgs to CMakeLists
Wiktor-99 Nov 16, 2024
305ab61
Use DynamicInterfaceGroupValues instead of DynamicInterfaceValues
Wiktor-99 Nov 16, 2024
2f49765
Merge branch 'master' into gpio_controllers
christophfroehlich Nov 17, 2024
5c32a72
Add gpio_controllers to the release_notes and add minor fixes to the …
Wiktor-99 Nov 18, 2024
4cd5772
Update compile flags
christophfroehlich Nov 18, 2024
6ef4023
Fix format
christophfroehlich Nov 18, 2024
bc3eb30
Merge branch 'master' into gpio_controllers
christophfroehlich Nov 18, 2024
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
Next Next commit
added gpio_command_controller
  • Loading branch information
mcbed authored and christophfroehlich committed Jul 26, 2024
commit 5fecf27c5494fd516f0fcfb1b00c493503a817f8
106 changes: 106 additions & 0 deletions gpio_controllers/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
cmake_minimum_required(VERSION 3.8)
project(gpio_controllers)

# Default to C++14
if(NOT CMAKE_CXX_STANDARD)
set(CMAKE_CXX_STANDARD 14)
endif()

if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang")
add_compile_options(-Wall -Wextra -Wpedantic)
christophfroehlich marked this conversation as resolved.
Show resolved Hide resolved
endif()

# find dependencies
find_package(ament_cmake REQUIRED)
find_package(controller_interface REQUIRED)
find_package(hardware_interface REQUIRED)
find_package(pluginlib REQUIRED)
find_package(rclcpp REQUIRED)
find_package(rclcpp_lifecycle REQUIRED)
find_package(realtime_tools REQUIRED)
find_package(std_msgs REQUIRED)

add_library(gpio_controllers
SHARED
src/gpio_command_controller.cpp
)
target_include_directories(gpio_controllers PRIVATE include)
ament_target_dependencies(gpio_controllers
builtin_interfaces
controller_interface
hardware_interface
pluginlib
rclcpp_lifecycle
rcutils
realtime_tools
std_msgs
)
# Causes the visibility macros to use dllexport rather than dllimport,
# which is appropriate when building the dll but not consuming it.
target_compile_definitions(gpio_controllers PRIVATE "GPIO_COMMAND_CONTROLLER_BUILDING_DLL")
pluginlib_export_plugin_description_file(controller_interface gpio_controllers_plugin.xml)

install(
DIRECTORY include/
DESTINATION include
)

install(
TARGETS
gpio_controllers
RUNTIME DESTINATION bin
ARCHIVE DESTINATION lib
LIBRARY DESTINATION lib
)

if(BUILD_TESTING)
find_package(ament_cmake_gmock REQUIRED)
find_package(controller_manager REQUIRED)
find_package(hardware_interface REQUIRED)
find_package(ros2_control_test_assets REQUIRED)

ament_add_gmock(
test_load_gpio_command_controller
test/test_load_gpio_command_controller.cpp
)

target_include_directories(test_load_gpio_command_controller PRIVATE include)
ament_target_dependencies(test_load_gpio_command_controller
controller_manager
hardware_interface
ros2_control_test_assets
)

ament_add_gmock(
test_gpio_command_controller
test/test_gpio_command_controller.cpp
)
target_include_directories(test_gpio_command_controller PRIVATE include)
target_link_libraries(test_gpio_command_controller
gpio_controllers
)
ament_target_dependencies(test_gpio_command_controller
controller_interface
hardware_interface
rclcpp
rclcpp_lifecycle
realtime_tools
std_msgs
)
endif()

ament_export_dependencies(
controller_interface
hardware_interface
rclcpp
rclcpp_lifecycle
realtime_tools
std_msgs
)
ament_export_include_directories(
include
)
ament_export_libraries(
gpio_controllers
)
ament_package()
7 changes: 7 additions & 0 deletions gpio_controllers/gpio_controllers_plugin.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
<library path="gpio_controllers">
<class name="gpio_controllers/GpioCommandController" type="gpio_controllers::GpioCommandController" base_class_type="controller_interface::ControllerInterface">
<description>
The gpio command controller commands a group of gpios using multiple interfaces.
</description>
</class>
</library>
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
// Copyright 2022 ICUBE Laboratory, University of Strasbourg
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef GPIO_COMMAND_CONTROLLER__GPIO_COMMAND_CONTROLLER_HPP_
#define GPIO_COMMAND_CONTROLLER__GPIO_COMMAND_CONTROLLER_HPP_

#include <memory>
#include <string>
#include <vector>

#include "controller_interface/controller_interface.hpp"
#include "gpio_controllers/visibility_control.h"
#include "rclcpp/subscription.hpp"
#include "rclcpp_lifecycle/node_interfaces/lifecycle_node_interface.hpp"
#include "rclcpp_lifecycle/state.hpp"
#include "realtime_tools/realtime_buffer.h"
#include "std_msgs/msg/float64_multi_array.hpp"

namespace gpio_controllers
{
using CmdType = std_msgs::msg::Float64MultiArray;
using CallbackReturn = rclcpp_lifecycle::node_interfaces::LifecycleNodeInterface::CallbackReturn;

class GpioCommandController : public controller_interface::ControllerInterface
{
public:
GPIO_COMMAND_CONTROLLER_PUBLIC
GpioCommandController();

GPIO_COMMAND_CONTROLLER_PUBLIC
controller_interface::InterfaceConfiguration command_interface_configuration() const override;

GPIO_COMMAND_CONTROLLER_PUBLIC
controller_interface::InterfaceConfiguration state_interface_configuration() const override;

GPIO_COMMAND_CONTROLLER_PUBLIC
CallbackReturn on_init() override;

GPIO_COMMAND_CONTROLLER_PUBLIC
CallbackReturn on_configure(const rclcpp_lifecycle::State & previous_state) override;

GPIO_COMMAND_CONTROLLER_PUBLIC
CallbackReturn on_activate(const rclcpp_lifecycle::State & previous_state) override;

GPIO_COMMAND_CONTROLLER_PUBLIC
CallbackReturn on_deactivate(const rclcpp_lifecycle::State & previous_state) override;

GPIO_COMMAND_CONTROLLER_PUBLIC
controller_interface::return_type update(
const rclcpp::Time & time, const rclcpp::Duration & period) override;

protected:
std::vector<std::string> gpio_names_;
std::unordered_map<std::string,std::vector<std::string>> interface_names_;
std::vector<std::string> command_interface_types_;

realtime_tools::RealtimeBuffer<std::shared_ptr<CmdType>> rt_command_ptr_;
rclcpp::Subscription<CmdType>::SharedPtr gpios_command_subscriber_;

std::string logger_name_;
};

} // namespace gpio_controllers

#endif // GPIO_COMMAND_CONTROLLER__GPIO_COMMAND_CONTROLLER_HPP_
35 changes: 35 additions & 0 deletions gpio_controllers/include/gpio_controllers/visibility_control.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
#ifndef GPIO_COMMAND_CONTROLLER__VISIBILITY_CONTROL_H_
#define GPIO_COMMAND_CONTROLLER__VISIBILITY_CONTROL_H_

// This logic was borrowed (then namespaced) from the examples on the gcc wiki:
// https://gcc.gnu.org/wiki/Visibility

#if defined _WIN32 || defined __CYGWIN__
#ifdef __GNUC__
#define GPIO_COMMAND_CONTROLLER_EXPORT __attribute__ ((dllexport))
#define GPIO_COMMAND_CONTROLLER_IMPORT __attribute__ ((dllimport))
#else
#define GPIO_COMMAND_CONTROLLER_EXPORT __declspec(dllexport)
#define GPIO_COMMAND_CONTROLLER_IMPORT __declspec(dllimport)
#endif
#ifdef GPIO_COMMAND_CONTROLLER_BUILDING_LIBRARY
#define GPIO_COMMAND_CONTROLLER_PUBLIC GPIO_COMMAND_CONTROLLER_EXPORT
#else
#define GPIO_COMMAND_CONTROLLER_PUBLIC GPIO_COMMAND_CONTROLLER_IMPORT
#endif
#define GPIO_COMMAND_CONTROLLER_PUBLIC_TYPE GPIO_COMMAND_CONTROLLER_PUBLIC
#define GPIO_COMMAND_CONTROLLER_LOCAL
#else
#define GPIO_COMMAND_CONTROLLER_EXPORT __attribute__ ((visibility("default")))
#define GPIO_COMMAND_CONTROLLER_IMPORT
#if __GNUC__ >= 4
#define GPIO_COMMAND_CONTROLLER_PUBLIC __attribute__ ((visibility("default")))
#define GPIO_COMMAND_CONTROLLER_LOCAL __attribute__ ((visibility("hidden")))
#else
#define GPIO_COMMAND_CONTROLLER_PUBLIC
#define GPIO_COMMAND_CONTROLLER_LOCAL
#endif
#define GPIO_COMMAND_CONTROLLER_PUBLIC_TYPE
#endif

#endif // GPIO_COMMAND_CONTROLLER__VISIBILITY_CONTROL_H_
28 changes: 28 additions & 0 deletions gpio_controllers/package.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
<?xml version="1.0"?>
<?xml-model href="http://download.ros.org/schema/package_format3.xsd" schematypens="http://www.w3.org/2001/XMLSchema"?>
<package format="3">
<name>gpio_controllers</name>
<version>0.0.0</version>
<description>Controllers to interact with gpios.</description>
<maintainer email="macbednarczyk@gmail.com">Maciej Bednarczyk</maintainer>
<license>Apache License 2.0</license>

<buildtool_depend>ament_cmake</buildtool_depend>

<depend>controller_interface</depend>
<depend>hardware_interface</depend>
<depend>rclcpp</depend>
<depend>rclcpp_lifecycle</depend>
<depend>realtime_tools</depend>
<depend>std_msgs</depend>

<build_depend>pluginlib</build_depend>

<test_depend>ament_cmake_gmock</test_depend>
<test_depend>controller_manager</test_depend>
<test_depend>ros2_control_test_assets</test_depend>

<export>
<build_type>ament_cmake</build_type>
</export>
</package>
Loading