This is a repository with example code to try out the various features of the HAROS framework.
This repository contains ROS packages that serve no particular purpose, other than to try out HAROS.
The minimal_example
package is a minimal ROS package composed of two nodes with a ROS publisher, a ROS subscriber, a ROS service server, a ROS service client and a ROS parameter.
The remaining four packages, fictibot_drivers
, fictibot_controller
, fictibot_multiplex
and fictibot_msgs
make up a fictitious mobile robot system, called Fictibot.
The packages provide software drivers for the mobile base, a random walker controller, a multiplexer to filter commands by priority and message definitions, respectively.
Despite being a fictitious robot, the system can be executed normally, using rosrun
, or roslaunch
with the various launch files contained in the packages.
In addition to the ROS packages, this repository also contains example project files for HAROS and scripts to help execute HAROS.
You can automate much of the installation of HAROS and this repository with make-haros-easy.
For a manual installation, the first step is to ensure that you have a working catkin workspace.
Depending on your setup, you might want to work with multiple workspaces, and create a new workspace for this tutorial.
Let us call it haros_ws
.
Clone this repository into the source space of this workspace, by default src
.
cd haros_ws/src
git clone https://github.com/git-afsantos/haros_tutorials.git
Simply build the packages with catkin_make
, and you are ready to use the packages in a ROS environment.
cd ..
catkin_make
source devel/setup.bash
To use these packages with HAROS and Clang, an additional step is required.
You have to create a compile_commands.json
file in the build
directory of the workspace.
You can do it either with catkin
or with cmake
.
cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1 -DCMAKE_CXX_COMPILER=/usr/bin/clang++-6.0 src
Or
catkin_make -DCMAKE_EXPORT_COMPILE_COMMANDS=1 -DCMAKE_CXX_COMPILER=/usr/bin/clang++-6.0
Replace src
in the first command with the source space of your workspace, if it is named differently.
Replace /usr/bin/clang++-6.0
with the correct path to your clang++
version.
Note: it might be useful to turn this into a script and place it at the root of the workspace, so that you do not forget to update compile_commands.json
when you build your ROS workspace.
#!/usr/bin/env bash
catkin_make --force-cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1 -DCMAKE_CXX_COMPILER=/usr/bin/clang++-6.0
To try out the ROS packages on their own, use any of the provided launch files. They set up different use scenarios, sometimes showcasing some ROS features and quirks that might not be well known.
A normal use case, using the three Fictibot nodes:
roslaunch fictibot_controller multiplexer.launch
Two Fictibot systems at the same time:
roslaunch fictibot_controller dual_bots.launch
Some quirks with rosparam
that might not be obvious from the documentation (read the launch file's comments as well):
roslaunch fictibot_controller test_rosparam.launch
You can try out HAROS manually with any of the provided project files. Alternatively, feel free to use some pre-made scripts that test out different features.
scripts/minimal.sh
runs model extraction onminimal_example
and any available plugins.scripts/fictibot.sh
runs model extraction on various configurations of Fictibot and any available plugins.scripts/queries.sh
defines architectural queries for some configurations of Fictibot and executesharos_plugin_pyflwor
.scripts/hpl.sh
defines HPL properties for the various Fictibot nodes and runs test generation withharos_plugin_pbt_gen
.scripts/perf.sh
defines the ground truth of themultiplex
computation graph and evaluates the model extractor's accuracy withharos_plugin_model_ged
.
Please use the issue tracker.
See CONTRIBUTING.
This work is financed by the ERDF – European Regional Development Fund through the Operational Programme for Competitiveness and Internationalisation - COMPETE 2020 Programme and by National Funds through the Portuguese funding agency, FCT - Fundação para a Ciência e a Tecnologia within project PTDC/CCI-INF/29583/2017 (POCI-01-0145-FEDER-029583).