-
Notifications
You must be signed in to change notification settings - Fork 68
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #44 in SRR/franka_ros2 from feat/joint-velocity-in…
…terface to humble * commit '221229e1bb19ae881032456ce979c150c13cefd8': bump up version update velocity controller example collision thresholds test: write velocity command interface tests feat/joint-velocity-interface
- Loading branch information
Showing
22 changed files
with
493 additions
and
88 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
77 changes: 77 additions & 0 deletions
77
franka_bringup/launch/joint_velocity_example_controller.launch.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
# Copyright (c) 2021 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. | ||
|
||
|
||
from launch import LaunchDescription | ||
from launch.actions import DeclareLaunchArgument, IncludeLaunchDescription | ||
from launch.launch_description_sources import PythonLaunchDescriptionSource | ||
from launch.substitutions import LaunchConfiguration, PathJoinSubstitution | ||
from launch_ros.actions import Node | ||
from launch_ros.substitutions import FindPackageShare | ||
|
||
|
||
def generate_launch_description(): | ||
robot_ip_parameter_name = 'robot_ip' | ||
load_gripper_parameter_name = 'load_gripper' | ||
use_fake_hardware_parameter_name = 'use_fake_hardware' | ||
fake_sensor_commands_parameter_name = 'fake_sensor_commands' | ||
use_rviz_parameter_name = 'use_rviz' | ||
|
||
robot_ip = LaunchConfiguration(robot_ip_parameter_name) | ||
load_gripper = LaunchConfiguration(load_gripper_parameter_name) | ||
use_fake_hardware = LaunchConfiguration(use_fake_hardware_parameter_name) | ||
fake_sensor_commands = LaunchConfiguration(fake_sensor_commands_parameter_name) | ||
use_rviz = LaunchConfiguration(use_rviz_parameter_name) | ||
|
||
return LaunchDescription([ | ||
DeclareLaunchArgument( | ||
robot_ip_parameter_name, | ||
description='Hostname or IP address of the robot.'), | ||
DeclareLaunchArgument( | ||
use_rviz_parameter_name, | ||
default_value='false', | ||
description='Visualize the robot in Rviz'), | ||
DeclareLaunchArgument( | ||
use_fake_hardware_parameter_name, | ||
default_value='false', | ||
description='Use fake hardware'), | ||
DeclareLaunchArgument( | ||
fake_sensor_commands_parameter_name, | ||
default_value='false', | ||
description="Fake sensor commands. Only valid when '{}' is true".format( | ||
use_fake_hardware_parameter_name)), | ||
DeclareLaunchArgument( | ||
load_gripper_parameter_name, | ||
default_value='true', | ||
description='Use Franka Gripper as an end-effector, otherwise, the robot is loaded ' | ||
'without an end-effector.'), | ||
|
||
IncludeLaunchDescription( | ||
PythonLaunchDescriptionSource([PathJoinSubstitution( | ||
[FindPackageShare('franka_bringup'), 'launch', 'franka.launch.py'])]), | ||
launch_arguments={robot_ip_parameter_name: robot_ip, | ||
load_gripper_parameter_name: load_gripper, | ||
use_fake_hardware_parameter_name: use_fake_hardware, | ||
fake_sensor_commands_parameter_name: fake_sensor_commands, | ||
use_rviz_parameter_name: use_rviz | ||
}.items(), | ||
), | ||
|
||
Node( | ||
package='controller_manager', | ||
executable='spawner', | ||
arguments=['joint_velocity_example_controller'], | ||
output='screen', | ||
), | ||
]) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
47 changes: 47 additions & 0 deletions
47
...mple_controllers/include/franka_example_controllers/joint_velocity_example_controller.hpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
// Copyright (c) 2021 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 <string> | ||
|
||
#include <controller_interface/controller_interface.hpp> | ||
#include <rclcpp/rclcpp.hpp> | ||
|
||
using CallbackReturn = rclcpp_lifecycle::node_interfaces::LifecycleNodeInterface::CallbackReturn; | ||
|
||
namespace franka_example_controllers { | ||
|
||
/** | ||
* The joint velocity example controller | ||
*/ | ||
class JointVelocityExampleController : public controller_interface::ControllerInterface { | ||
public: | ||
[[nodiscard]] controller_interface::InterfaceConfiguration command_interface_configuration() | ||
const override; | ||
[[nodiscard]] controller_interface::InterfaceConfiguration state_interface_configuration() | ||
const override; | ||
controller_interface::return_type update(const rclcpp::Time& time, | ||
const rclcpp::Duration& period) override; | ||
CallbackReturn on_init() override; | ||
CallbackReturn on_configure(const rclcpp_lifecycle::State& previous_state) override; | ||
CallbackReturn on_activate(const rclcpp_lifecycle::State& previous_state) override; | ||
|
||
private: | ||
std::string arm_id_; | ||
const int num_joints = 7; | ||
rclcpp::Duration elapsed_time_ = rclcpp::Duration(0, 0); | ||
}; | ||
|
||
} // namespace franka_example_controllers |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
120 changes: 120 additions & 0 deletions
120
franka_example_controllers/src/joint_velocity_example_controller.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,120 @@ | ||
// Copyright (c) 2021 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. | ||
|
||
#include <franka_example_controllers/joint_velocity_example_controller.hpp> | ||
#include <franka_msgs/srv/set_full_collision_behavior.hpp> | ||
|
||
#include <cassert> | ||
#include <cmath> | ||
#include <exception> | ||
#include <string> | ||
|
||
#include <Eigen/Eigen> | ||
|
||
using namespace std::chrono_literals; | ||
|
||
namespace franka_example_controllers { | ||
|
||
controller_interface::InterfaceConfiguration | ||
JointVelocityExampleController::command_interface_configuration() const { | ||
controller_interface::InterfaceConfiguration config; | ||
config.type = controller_interface::interface_configuration_type::INDIVIDUAL; | ||
|
||
for (int i = 1; i <= num_joints; ++i) { | ||
config.names.push_back(arm_id_ + "_joint" + std::to_string(i) + "/velocity"); | ||
} | ||
return config; | ||
} | ||
|
||
controller_interface::InterfaceConfiguration | ||
JointVelocityExampleController::state_interface_configuration() const { | ||
controller_interface::InterfaceConfiguration config; | ||
config.type = controller_interface::interface_configuration_type::INDIVIDUAL; | ||
for (int i = 1; i <= num_joints; ++i) { | ||
config.names.push_back(arm_id_ + "_joint" + std::to_string(i) + "/position"); | ||
config.names.push_back(arm_id_ + "_joint" + std::to_string(i) + "/velocity"); | ||
} | ||
return config; | ||
} | ||
|
||
controller_interface::return_type JointVelocityExampleController::update( | ||
const rclcpp::Time& /*time*/, | ||
const rclcpp::Duration& period) { | ||
elapsed_time_ = elapsed_time_ + period; | ||
rclcpp::Duration time_max(8.0, 0.0); | ||
double omega_max = 0.1; | ||
double cycle = std::floor(std::pow( | ||
-1.0, (elapsed_time_.seconds() - std::fmod(elapsed_time_.seconds(), time_max.seconds())) / | ||
time_max.seconds())); | ||
double omega = cycle * omega_max / 2.0 * | ||
(1.0 - std::cos(2.0 * M_PI / time_max.seconds() * elapsed_time_.seconds())); | ||
|
||
for (int i = 0; i < num_joints; i++) { | ||
if (i == 3 || i == 4) { | ||
command_interfaces_[i].set_value(omega); | ||
} else { | ||
command_interfaces_[i].set_value(0.0); | ||
} | ||
} | ||
return controller_interface::return_type::OK; | ||
} | ||
|
||
CallbackReturn JointVelocityExampleController::on_init() { | ||
try { | ||
auto_declare<std::string>("arm_id", "panda"); | ||
|
||
} catch (const std::exception& e) { | ||
fprintf(stderr, "Exception thrown during init stage with message: %s \n", e.what()); | ||
return CallbackReturn::ERROR; | ||
} | ||
return CallbackReturn::SUCCESS; | ||
} | ||
|
||
CallbackReturn JointVelocityExampleController::on_configure( | ||
const rclcpp_lifecycle::State& /*previous_state*/) { | ||
arm_id_ = get_node()->get_parameter("arm_id").as_string(); | ||
|
||
auto client = get_node()->create_client<franka_msgs::srv::SetFullCollisionBehavior>( | ||
"service_server/set_full_collision_behavior"); | ||
auto request = std::make_shared<franka_msgs::srv::SetFullCollisionBehavior::Request>(); | ||
|
||
request->lower_torque_thresholds_acceleration = {20.0, 20.0, 18.0, 18.0, 16.0, 14.0, 12.0}; | ||
request->upper_torque_thresholds_acceleration = {20.0, 20.0, 18.0, 18.0, 16.0, 14.0, 12.0}; | ||
request->lower_torque_thresholds_nominal = {20.0, 20.0, 18.0, 18.0, 16.0, 14.0, 12.0}; | ||
request->upper_torque_thresholds_nominal = {20.0, 20.0, 18.0, 18.0, 16.0, 14.0, 12.0}; | ||
request->lower_force_thresholds_acceleration = {20.0, 20.0, 20.0, 25.0, 25.0, 25.0}; | ||
request->upper_force_thresholds_acceleration = {20.0, 20.0, 20.0, 25.0, 25.0, 25.0}; | ||
request->lower_force_thresholds_nominal = {20.0, 20.0, 20.0, 25.0, 25.0, 25.0}; | ||
request->upper_force_thresholds_nominal = {20.0, 20.0, 20.0, 25.0, 25.0, 25.0}; | ||
|
||
if (!client->wait_for_service(20s)) { | ||
RCLCPP_FATAL(get_node()->get_logger(), "service server can't be found."); | ||
return CallbackReturn::FAILURE; | ||
} | ||
|
||
client->async_send_request(request); | ||
|
||
return CallbackReturn::SUCCESS; | ||
} | ||
|
||
CallbackReturn JointVelocityExampleController::on_activate( | ||
const rclcpp_lifecycle::State& /*previous_state*/) { | ||
return CallbackReturn::SUCCESS; | ||
} | ||
|
||
} // namespace franka_example_controllers | ||
#include "pluginlib/class_list_macros.hpp" | ||
// NOLINTNEXTLINE | ||
PLUGINLIB_EXPORT_CLASS(franka_example_controllers::JointVelocityExampleController, | ||
controller_interface::ControllerInterface) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.