Skip to content

Commit

Permalink
feat: non-realtime parameter services
Browse files Browse the repository at this point in the history
  • Loading branch information
BarisYazici committed Aug 21, 2023
1 parent 57af611 commit eae138a
Show file tree
Hide file tree
Showing 19 changed files with 1,038 additions and 46 deletions.
21 changes: 20 additions & 1 deletion .clang-tidy
Original file line number Diff line number Diff line change
@@ -1,4 +1,23 @@
Checks: 'cppcoreguidelines-*,-cppcoreguidelines-pro-type-vararg,-cppcoreguidelines-pro-bounds-array-to-pointer-decay,clang-diagnostic-*,clang-analyzer-*,-clang-analyzer-optin.cplusplus.VirtualCall,-clang-analyzer-alpha*,google-*,misc-*,readability-*,-readability-function-cognitive-complexity,modernize-*,-modernize-use-trailing-return-type,performance-*,-clang-diagnostic-deprecated-declarations,-modernize-pass-by-value,-clang-diagnostic-reinterpret-base-class,-clang-diagnostic-return-type,-clang-diagnostic-switch,-bugprone-lambda-function-name,-cppcoreguidelines-avoid-magic-numbers, -readability-magic-numbers'
Checks: 'cppcoreguidelines-*,
-cppcoreguidelines-pro-type-vararg,
-cppcoreguidelines-pro-bounds-array-to-pointer-decay,
clang-diagnostic-*,
clang-analyzer-*,
-clang-analyzer-optin.cplusplus.VirtualCall,
-clang-analyzer-alpha*,
google-*,
misc-*,
-readability-*,
-readability-function-cognitive-complexity,modernize-*,
-modernize-use-trailing-return-type,performance-*,
-clang-diagnostic-deprecated-declarations,
-modernize-pass-by-value,
-clang-diagnostic-reinterpret-base-class,
-clang-diagnostic-return-type,
-clang-diagnostic-switch,
-bugprone-lambda-function-name,
-cppcoreguidelines-avoid-magic-numbers,
-readability-magic-numbers'
HeaderFilterRegex: '^franka_.*'
CheckOptions:
# Classes, structs, ...
Expand Down
12 changes: 9 additions & 3 deletions franka_hardware/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -19,17 +19,22 @@ find_package(franka_msgs REQUIRED)
find_package(hardware_interface REQUIRED)
find_package(pluginlib REQUIRED)
find_package(Franka 0.11.0 REQUIRED)

find_package(rclcpp_components REQUIRED)

add_library(franka_hardware
SHARED
src/franka_hardware_interface.cpp
src/robot.cpp)
src/robot.cpp
src/franka_param_service_server.cpp
src/franka_executor.cpp
)

target_include_directories(
franka_hardware
PRIVATE
include
)

ament_target_dependencies(
franka_hardware
hardware_interface
Expand All @@ -38,6 +43,7 @@ ament_target_dependencies(
rclcpp
franka_msgs
)

pluginlib_export_plugin_description_file(hardware_interface franka_hardware.xml)


Expand All @@ -50,7 +56,6 @@ install(
DESTINATION include
)


if(BUILD_TESTING)
find_package(ament_cmake_clang_format REQUIRED)
find_package(ament_cmake_copyright REQUIRED)
Expand Down Expand Up @@ -81,6 +86,7 @@ endif()
ament_export_include_directories(
include
)

ament_export_libraries(
franka_hardware
)
Expand Down
43 changes: 43 additions & 0 deletions franka_hardware/include/franka_hardware/franka_executor.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
// Copyright (c) 2023 Franka Emika GmbH
//
// 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.

#pragma once

#include <rclcpp/rclcpp.hpp>

namespace franka_hardware {

class FrankaExecutor : public rclcpp::executors::MultiThreadedExecutor {
public:
// Create an instance and start the internal thread
FrankaExecutor();
FrankaExecutor(const FrankaExecutor&) = delete;
FrankaExecutor(FrankaExecutor&&) = delete;

FrankaExecutor& operator=(const FrankaExecutor&) = delete;
FrankaExecutor& operator=(FrankaExecutor&&) = delete;

// Stops the internal executor and joins with the internal thread
~FrankaExecutor() override;

private:
std::thread executor_spin_;

// Executor thread starts spining the multithreadedExecutor
void run();

// Cancel any spinning ROS executor
void shutdown();
};
} // namespace franka_hardware
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,6 @@
#include <vector>

#include <hardware_interface/visibility_control.h>
#include <franka_hardware/robot.hpp>

#include <hardware_interface/hardware_info.hpp>
#include <hardware_interface/system_interface.hpp>
#include <hardware_interface/types/hardware_interface_return_values.hpp>
Expand All @@ -29,13 +27,17 @@
#include <rclcpp/rclcpp.hpp>
#include <rclcpp_lifecycle/state.hpp>

#include "franka_hardware/franka_executor.hpp"
#include "franka_hardware/franka_param_service_server.hpp"
#include "franka_hardware/robot.hpp"

using CallbackReturn = rclcpp_lifecycle::node_interfaces::LifecycleNodeInterface::CallbackReturn;

namespace franka_hardware {

class FrankaHardwareInterface : public hardware_interface::SystemInterface {
public:
explicit FrankaHardwareInterface(std::unique_ptr<Robot> robot);
explicit FrankaHardwareInterface(std::shared_ptr<Robot> robot);
FrankaHardwareInterface() = default;

hardware_interface::return_type prepare_command_mode_switch(
Expand All @@ -56,7 +58,10 @@ class FrankaHardwareInterface : public hardware_interface::SystemInterface {
static const size_t kNumberOfJoints = 7;

private:
std::unique_ptr<Robot> robot_;
std::shared_ptr<Robot> robot_;
std::shared_ptr<FrankaParamServiceServer> node_;
std::shared_ptr<FrankaExecutor> executor_;

std::array<double, kNumberOfJoints> hw_commands_{0, 0, 0, 0, 0, 0, 0};
std::array<double, kNumberOfJoints> hw_positions_{0, 0, 0, 0, 0, 0, 0};
std::array<double, kNumberOfJoints> hw_velocities_{0, 0, 0, 0, 0, 0, 0};
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,151 @@
// Copyright (c) 2023 Franka Emika GmbH
//
// 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.

#pragma once

#include <memory>

#include "franka/exception.h"
#include "franka_hardware/robot.hpp"

#include <franka_msgs/srv/set_cartesian_stiffness.hpp>
#include <franka_msgs/srv/set_force_torque_collision_behavior.hpp>
#include <franka_msgs/srv/set_full_collision_behavior.hpp>
#include <franka_msgs/srv/set_joint_stiffness.hpp>
#include <franka_msgs/srv/set_load.hpp>
#include <franka_msgs/srv/set_stiffness_frame.hpp>
#include <franka_msgs/srv/set_tcp_frame.hpp>

#include <rclcpp/rclcpp.hpp>

/**
* Node implementing the service server
*/
namespace franka_hardware {

class FrankaParamServiceServer : public rclcpp::Node {
public:
FrankaParamServiceServer(const rclcpp::NodeOptions& options, std::shared_ptr<Robot> robot);

private:
/**
* @brief generic templated param setter function
*
* @param param_setter_function: std::function<void(request_type)> makes the call to the robot
* class which take the request type
* @param request franka_msgs::srv set parameter request type
* @param response franka_msgs::srv set parameter response type
*/
template <typename request_type, typename response_type>
void setGenericRobotParam(const std::function<void(request_type)>& param_setter_function,
const request_type& request,
const response_type& response) {
try {
param_setter_function(request);
response->success = true;
} catch (const franka::CommandException& command_exception) {
RCLCPP_ERROR(this->get_logger(), "Command exception thrown during parameter setting %s",
command_exception.what());
response->success = false;
response->error = "command exception error";
} catch (const franka::NetworkException& network_exception) {
RCLCPP_ERROR(this->get_logger(), "Network exception thrown during parameter setting %s",
network_exception.what());
response->success = false;
response->error = "network exception error";
}
}

/**
* @brief Callback function for set_joint_stiffness service
*
* @param request shared_ptr to setJointStiffness service msgs request
* @param response shared_ptr to setJointStiffness service msgs response
*/
void setJointStiffnessCallback(
const franka_msgs::srv::SetJointStiffness::Request::SharedPtr& request,
const franka_msgs::srv::SetJointStiffness::Response::SharedPtr& response);

/**
* @brief Callback function for set_cartesian_stiffness service
*
* @param request shared_ptr to SetCartesianStiffness service msgs request
* @param response shared_ptr to SetCartesianStiffness service msgs response
*/
void setCartesianStiffnessCallback(
const franka_msgs::srv::SetCartesianStiffness::Request::SharedPtr& request,
const franka_msgs::srv::SetCartesianStiffness::Response::SharedPtr& response);

/**
* @brief Callback function for set_cartesian_stiffness service
*
* @param request shared_ptr to SetCartesianStiffness service msgs request
* @param response shared_ptr to SetCartesianStiffness service msgs response
*/
void setTCPFrameCallback(const franka_msgs::srv::SetTCPFrame::Request::SharedPtr& request,
const franka_msgs::srv::SetTCPFrame::Response::SharedPtr& response);

/**
* @brief Callback function for set_stiffness_frame service
*
* @param request shared_ptr to SetStiffnessFrame service msgs request
* @param response shared_ptr to SetStiffnessFrame service msgs response
*/
void setStiffnessFrameCallback(
const franka_msgs::srv::SetStiffnessFrame::Request::SharedPtr& request,
const franka_msgs::srv::SetStiffnessFrame::Response::SharedPtr& response);

/**
* @brief Callback function for set_force_torque_collision_behavior service
*
* @param request shared_ptr to SetForceTorqueCollisionBehavior service msgs request
* @param response shared_ptr to SetForceTorqueCollisionBehavior service msgs response
*/
void setForceTorqueCollisionBehaviorCallback(
const franka_msgs::srv::SetForceTorqueCollisionBehavior::Request::SharedPtr& request,
const franka_msgs::srv::SetForceTorqueCollisionBehavior::Response::SharedPtr& response);

/**
* @brief Callback function for set_full_collision_behavior service
*
* @param request shared_ptr to SetFullCollisionBehavior service msgs request
* @param response shared_ptr to SetFullCollisionBehavior service msgs response
*/
void setFullCollisionBehaviorCallback(
const franka_msgs::srv::SetFullCollisionBehavior::Request::SharedPtr& request,
const franka_msgs::srv::SetFullCollisionBehavior::Response::SharedPtr& response);

/**
* @brief Callback function for set_load_callback service
*
* @param request shared_ptr to SetLoad service msgs request
* @param response shared_ptr to SetLoad service msgs response
*/
void setLoadCallback(const franka_msgs::srv::SetLoad::Request::SharedPtr& request,
const franka_msgs::srv::SetLoad::Response::SharedPtr& response);

std::shared_ptr<Robot> robot_;

rclcpp::Service<franka_msgs::srv::SetJointStiffness>::SharedPtr set_joint_stiffness_service_;
rclcpp::Service<franka_msgs::srv::SetCartesianStiffness>::SharedPtr
set_cartesian_stiffness_service_;
rclcpp::Service<franka_msgs::srv::SetLoad>::SharedPtr set_load_service_;
rclcpp::Service<franka_msgs::srv::SetTCPFrame>::SharedPtr set_tcp_frame_service_;
rclcpp::Service<franka_msgs::srv::SetStiffnessFrame>::SharedPtr set_stiffness_frame_service_;
rclcpp::Service<franka_msgs::srv::SetForceTorqueCollisionBehavior>::SharedPtr
set_force_torque_collision_behavior_service_;
rclcpp::Service<franka_msgs::srv::SetFullCollisionBehavior>::SharedPtr
set_full_collision_behavior_service_;
};
} // namespace franka_hardware
Loading

0 comments on commit eae138a

Please sign in to comment.