latest pushes
This commit is contained in:
parent
f047386e47
commit
e1bdebb248
@ -39,13 +39,22 @@ if($ENV{ROS_VERSION} EQUAL 1)
|
||||
)
|
||||
endif()
|
||||
|
||||
# Install Python scripts for both ROS 1
|
||||
if($ENV{ROS_VERSION} EQUAL 1)
|
||||
catkin_install_python(
|
||||
PROGRAMS
|
||||
src/bellande_controller.py
|
||||
DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
|
||||
)
|
||||
endif()
|
||||
|
||||
# Install Python scripts, configuration files, and launch files
|
||||
if($ENV{ROS_VERSION} EQUAL "1")
|
||||
install(PROGRAMS src/bellande_adaptive_continuious_controller_api_2d.py DESTINATION ${CATKIN_PACKAGE_LIB_DESTINATION})
|
||||
install(PROGRAMS src/bellande_controller.py DESTINATION ${CATKIN_PACKAGE_LIB_DESTINATION})
|
||||
install(DIRECTORY config/ DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}/config)
|
||||
install(DIRECTORY launch/ DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}/launch)
|
||||
elseif($ENV{ROS_VERSION} EQUAL "2")
|
||||
install(PROGRAMS src/bellande_adaptive_continuious_controller_api_2d.py DESTINATION lib/${PROJECT_NAME})
|
||||
install(PROGRAMS src/bellande_controller.py DESTINATION lib/${PROJECT_NAME})
|
||||
install(DIRECTORY config/ DESTINATION share/${PROJECT_NAME}/config)
|
||||
install(DIRECTORY launch/ DESTINATION share/${PROJECT_NAME}/launch)
|
||||
endif()
|
||||
|
@ -1,61 +0,0 @@
|
||||
import os
|
||||
import sys
|
||||
import subprocess
|
||||
from launch import LaunchDescription
|
||||
from launch_ros.actions import Node
|
||||
from launch.actions import DeclareLaunchArgument
|
||||
from launch.substitutions import LaunchConfiguration
|
||||
|
||||
|
||||
def ros1_launch_description():
|
||||
# Get command-line arguments
|
||||
args = sys.argv[1:]
|
||||
|
||||
# Construct the ROS 1 launch commandi
|
||||
roslaunch_command = ["roslaunch", "ros_web_api_bellande_step", "bellande_step_api_2d.launch"] + args
|
||||
|
||||
# Execute the launch command
|
||||
subprocess.call(roslaunch_command)
|
||||
|
||||
|
||||
def ros2_launch_description():
|
||||
# Declare launch arguments
|
||||
x1_arg = DeclareLaunchArgument('x1')
|
||||
y1_arg = DeclareLaunchArgument('y1')
|
||||
x2_arg = DeclareLaunchArgument('x2')
|
||||
y2_arg = DeclareLaunchArgument('y2')
|
||||
limit_arg = DeclareLaunchArgument('limit')
|
||||
|
||||
# Create a list to hold all nodes to be launched
|
||||
nodes_to_launch = []
|
||||
|
||||
# ROS2 specific configurations
|
||||
ros_launch_arguments = [
|
||||
x1_arg, y1_arg, x2_arg, y2_arg, limit_arg,
|
||||
]
|
||||
nodes_to_launch.append(Node(
|
||||
package='ros_web_api_bellande_step',
|
||||
executable='bellande_step_api_2d.py',
|
||||
name='bellande_step_api_2d_node',
|
||||
output='screen',
|
||||
parameters=[
|
||||
{'x1': LaunchConfiguration('x1')},
|
||||
{'y1': LaunchConfiguration('y1')},
|
||||
{'x2': LaunchConfiguration('x2')},
|
||||
{'y2': LaunchConfiguration('y2')},
|
||||
{'limit': LaunchConfiguration('limit')},
|
||||
],
|
||||
))
|
||||
|
||||
# Return the LaunchDescription containing all nodes and arguments
|
||||
return LaunchDescription(ros_launch_arguments + nodes_to_launch)
|
||||
|
||||
if __name__ == "__main__":
|
||||
ros_version = os.getenv("ROS_VERSION")
|
||||
if ros_version == "1":
|
||||
ros1_launch_description()
|
||||
elif ros_version == "2":
|
||||
ros2_launch_description()
|
||||
else:
|
||||
print("Unsupported ROS version. Please set the ROS_VERSION environment variable to '1' for ROS 1 or '2' for ROS 2.")
|
||||
sys.exit(1)
|
@ -0,0 +1,71 @@
|
||||
# Copyright (C) 2024 Bellande Robotics Sensors Research Innovation Center, Ronaldson Bellande
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
import os
|
||||
import sys
|
||||
import subprocess
|
||||
from launch import LaunchDescription
|
||||
from launch_ros.actions import Node
|
||||
from launch.actions import DeclareLaunchArgument
|
||||
from launch.substitutions import LaunchConfiguration
|
||||
|
||||
def ros1_launch_description():
|
||||
# Get command-line arguments
|
||||
args = sys.argv[1:]
|
||||
# Construct the ROS 1 launch command
|
||||
roslaunch_command = ["roslaunch", "ros_web_api_bellande_adaptive_continuious_controller", "bellande_controller.launch"] + args
|
||||
# Execute the launch command
|
||||
subprocess.call(roslaunch_command)
|
||||
|
||||
def ros2_launch_description():
|
||||
# Declare launch arguments
|
||||
setpoint_arg = DeclareLaunchArgument('setpoint')
|
||||
kp_arg = DeclareLaunchArgument('kp')
|
||||
ki_arg = DeclareLaunchArgument('ki')
|
||||
kd_arg = DeclareLaunchArgument('kd')
|
||||
|
||||
# Create a list to hold all nodes to be launched
|
||||
nodes_to_launch = []
|
||||
|
||||
# ROS2 specific configurations
|
||||
ros_launch_arguments = [
|
||||
setpoint_arg, kp_arg, ki_arg, kd_arg,
|
||||
]
|
||||
|
||||
nodes_to_launch.append(Node(
|
||||
package='ros_web_api_bellande_adaptive_continuious_controller',
|
||||
executable='bellande_controller.py',
|
||||
name='bellande_controller_node',
|
||||
output='screen',
|
||||
parameters=[
|
||||
{'setpoint': LaunchConfiguration('setpoint')},
|
||||
{'kp': LaunchConfiguration('kp')},
|
||||
{'ki': LaunchConfiguration('ki')},
|
||||
{'kd': LaunchConfiguration('kd')},
|
||||
],
|
||||
))
|
||||
|
||||
# Return the LaunchDescription containing all nodes and arguments
|
||||
return LaunchDescription(ros_launch_arguments + nodes_to_launch)
|
||||
|
||||
if __name__ == "__main__":
|
||||
ros_version = os.getenv("ROS_VERSION")
|
||||
if ros_version == "1":
|
||||
ros1_launch_description()
|
||||
elif ros_version == "2":
|
||||
ros2_launch_description()
|
||||
else:
|
||||
print("Unsupported ROS version. Please set the ROS_VERSION environment variable to '1' for ROS 1 or '2' for ROS 2.")
|
||||
sys.exit(1)
|
@ -15,18 +15,18 @@ License for the specific language governing permissions and limitations under
|
||||
the License.
|
||||
-->
|
||||
<launch>
|
||||
<arg name="x1" />
|
||||
<arg name="y1" />
|
||||
<arg name="x2" />
|
||||
<arg name="y2" />
|
||||
<arg name="limit" />
|
||||
<!-- Define arguments -->
|
||||
<arg name="setpoint" default="0" />
|
||||
<arg name="kp" default="1.0" />
|
||||
<arg name="ki" default="0.1" />
|
||||
<arg name="kd" default="0.05" />
|
||||
|
||||
<node pkg="ros_web_api_bellande_step" type="bellande_step_api_2d.py"
|
||||
name="bellande_step_api_2d_node" output="screen">
|
||||
<param name="x1" value="$(arg x1)" />
|
||||
<param name="y1" value="$(arg y1)" />
|
||||
<param name="x2" value="$(arg x2)" />
|
||||
<param name="y2" value="$(arg y2)" />
|
||||
<param name="limit" value="$(arg limit)" />
|
||||
<!-- Launch the BellandeController node -->
|
||||
<node name="bellande_controller_node" pkg="ros_web_api_bellande_adaptive_continuious_controller"
|
||||
type="bellande_controller.py" output="screen">
|
||||
<param name="setpoint" value="$(arg setpoint)" />
|
||||
<param name="kp" value="$(arg kp)" />
|
||||
<param name="ki" value="$(arg ki)" />
|
||||
<param name="kd" value="$(arg kd)" />
|
||||
</node>
|
||||
</launch>
|
@ -1,10 +1,25 @@
|
||||
# Copyright (C) 2024 Bellande Robotics Sensors Research Innovation Center, Ronaldson Bellande
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
from distutils.core import setup
|
||||
from catkin_pkg.python_setup import generate_distutils_setup
|
||||
|
||||
# fetch values from package.xml
|
||||
setup_args = generate_distutils_setup(
|
||||
scripts=['src/bellande_step_api_2d.py'],
|
||||
packages=['ros_web_api_bellande_step'],
|
||||
scripts=['src/bellande_controller.py'],
|
||||
packages=['ros_web_api_bellande_adaptive_continuious_controller'],
|
||||
package_dir={'': 'src'},
|
||||
)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user