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

ROS1 documentation updates and enhancements #316

Merged
merged 79 commits into from
Dec 11, 2022
Merged
Show file tree
Hide file tree
Changes from 78 commits
Commits
Show all changes
79 commits
Select commit Hold shift + click to select a range
22c4ef9
Added prerequisites section for common prerequisites across nodes
tsampazk Sep 15, 2022
5e9db80
Overhauled the dataset nodes section and added RGB nodes section
tsampazk Sep 15, 2022
c0684dc
Rearranged the listed node links
tsampazk Sep 16, 2022
9f23346
General rearrangement and input sections
tsampazk Sep 16, 2022
a18f4b5
Additional modifications and pose estimation section
tsampazk Sep 20, 2022
c5e403f
Section renaming for consistency
tsampazk Sep 20, 2022
b267be0
Some rearrangement in contents list to match the order
tsampazk Sep 20, 2022
6597ad8
Merge branch 'develop' into ros-nodes-docs
tsampazk Sep 20, 2022
c3bf14c
Fall detection doc and moved dataset nodes to bottom
tsampazk Sep 21, 2022
42d0f00
Face det, reco, 2d object detection overhaul and todo notes
tsampazk Sep 21, 2022
12ab09c
Added a class id table on sem segmentation doc
tsampazk Sep 22, 2022
a02f6ab
Panoptic and semantic segmentation overhaul
tsampazk Sep 22, 2022
61669df
Merge branch 'develop' into ros-nodes-docs
tsampazk Sep 22, 2022
6f35459
Fix long lines as per suggestions
tsampazk Sep 26, 2022
95b0ba6
Fix long lines as per suggestions
tsampazk Sep 26, 2022
fdd730c
Removed commented pose estimation usage suggestion
tsampazk Sep 26, 2022
032ef36
Update video HAR docs foro ROS node
LukasHedegaard Sep 29, 2022
d565ac5
Updated the video human activity recognition section and some other m…
tsampazk Sep 29, 2022
56221ec
Merge branch 'develop' into ros-nodes-docs
tsampazk Sep 29, 2022
9012c04
Fixed italics showing as block
tsampazk Oct 5, 2022
fec6031
Merge branch 'develop' into ros-nodes-docs
tsampazk Oct 12, 2022
d140125
Removed redundant line separators after headers
tsampazk Oct 12, 2022
08f9ada
Removed redundant horizontal line from RGBD header
tsampazk Oct 13, 2022
edc288b
Merge branch 'develop' into ros-nodes-docs
tsampazk Oct 13, 2022
3dfd108
Added notes for output visualization and updated pose estimation docs
tsampazk Oct 13, 2022
3af485d
Added missing space in pose estimation docs
tsampazk Oct 13, 2022
5d91c6a
Updates on formatting for all other applicable nodes' docs and minor …
tsampazk Oct 13, 2022
a72570c
Merge branch 'develop' into ros-nodes-docs
tsampazk Oct 14, 2022
cd66d50
More detailed ros setup instructions
tsampazk Oct 14, 2022
978e35a
Added skipping of workspace build step
tsampazk Oct 14, 2022
cb64d4a
Updated RGBD hand gesture recognition ros node doc
tsampazk Oct 14, 2022
f4c9de4
Updated speech command recognition ros node doc and some minor fixes
tsampazk Oct 14, 2022
ee198e0
Updated heart anomaly detection ros node doc
tsampazk Oct 17, 2022
a2e49d8
Reordered audio section and added RGB + Audio section
tsampazk Oct 17, 2022
c40f010
Added audiovisual emotion reco missing doc and reordered audio section
tsampazk Oct 17, 2022
641a14e
Merge branch 'develop' into ros-nodes-docs
ad-daniel Oct 18, 2022
f402030
Added link to csv file with classes-ids for activity recognition
tsampazk Oct 18, 2022
5096143
Added link to csv file with class-ids for activity recognition
tsampazk Oct 18, 2022
8939d1e
Merge branch 'develop' into ros-nodes-docs
tsampazk Oct 24, 2022
b5030a2
Merge branch 'develop' into ros-nodes-docs
tsampazk Oct 24, 2022
e24ce65
Merge branch 'develop' into ros-nodes-docs
ad-daniel Oct 25, 2022
f5670e1
Merge branch 'develop' into ros-nodes-docs
tsampazk Nov 8, 2022
0aca0cc
Minor improvements
tsampazk Nov 8, 2022
457eb7a
Several minor fixes and landmark-based facial expression recognition
tsampazk Nov 9, 2022
0ed9f80
Skeleton-based human action recognition and minor fixes
tsampazk Nov 10, 2022
2861e2d
Moved fair mot in rgb input section
tsampazk Nov 23, 2022
a76ef54
Merge branch 'develop' into ros-nodes-docs
tsampazk Nov 25, 2022
89d6630
Merge branch 'develop' into ros-nodes-docs
tsampazk Nov 28, 2022
9df6c02
Merge branch 'develop' into ros-nodes-docs
tsampazk Nov 29, 2022
441e1e0
Completed ROS1 docs
tsampazk Nov 29, 2022
5cf5f3e
Updates on default values for FairMOT ros node class ctor
tsampazk Nov 30, 2022
6f48675
Fixed duplicate shortcut on deepsort ros node argparse
tsampazk Nov 30, 2022
f4a4870
Fixed missing shortcut on rgbd hand gesture reco ros node argparse
tsampazk Nov 30, 2022
01bacac
Added "opendr_" to data gen package and "_node" to the node file name
tsampazk Nov 30, 2022
4fb9578
Merge branch 'develop' into ros1-renaming
tsampazk Nov 30, 2022
3a7a4aa
Renamed package to "opendr_perception" and added "_node" to scripts
tsampazk Nov 30, 2022
3599179
Applied fixes to yolov5
tsampazk Nov 30, 2022
ccacac0
Added "opendr_" to planning package
tsampazk Nov 30, 2022
5baa98b
Added "opendr_" to bridge package
tsampazk Nov 30, 2022
d009102
Added "opendr_" to simulation package
tsampazk Nov 30, 2022
aeeb333
Fixed old version of torch in pip_requirements.txt
tsampazk Nov 30, 2022
d11b710
Renamed ros bridge package doc
tsampazk Nov 30, 2022
0ee263f
Merge branch 'develop' into ros-nodes-docs
tsampazk Dec 1, 2022
67dc9a1
Merge branch 'ros1-renaming' into ros-nodes-docs
tsampazk Dec 1, 2022
18fc19c
Updated based on new names and some minor modifications
tsampazk Dec 1, 2022
e2abdaa
Fixed list numbers
tsampazk Dec 7, 2022
4895d22
Merge develop into ros-nodes-docs
tsampazk Dec 7, 2022
4df42a6
Merge clean-up
tsampazk Dec 7, 2022
7f94fc5
Added a new notes item with a node diagram and explanation
tsampazk Dec 7, 2022
6ef83b9
Minor formatting fixes in the diagram section
tsampazk Dec 7, 2022
ac7d1e8
Merge branch 'develop' into ros-nodes-docs
tsampazk Dec 8, 2022
3a02797
Merge branch 'develop' into ros-nodes-docs
tsampazk Dec 8, 2022
a75279e
Fixed step X dot consistency
tsampazk Dec 8, 2022
863e1a1
Fixed step X dot consistency
tsampazk Dec 8, 2022
d2cc449
Added detached & in instructions for running stuff
tsampazk Dec 8, 2022
366a758
Removed apt ros package installation instructions
tsampazk Dec 8, 2022
efcd727
Added some additional required ros packages and made ROS version a va…
tsampazk Dec 8, 2022
f88e2b3
Merge branch 'develop' into ros-nodes-docs
tsampazk Dec 8, 2022
ed90865
Merge branch 'develop' into ros-nodes-docs
ad-daniel Dec 8, 2022
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
2 changes: 1 addition & 1 deletion bin/install.sh
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ make install_compilation_dependencies
make install_runtime_dependencies

# Install additional ROS packages
sudo apt-get install ros-noetic-vision-msgs ros-noetic-audio-common-msgs
sudo apt-get install ros-$ROS_DISTRO-vision-msgs ros-$ROS_DISTRO-geometry-msgs ros-$ROS_DISTRO-sensor-msgs ros-$ROS_DISTRO-audio-common-msgss

# If working on GPU install GPU dependencies as needed
if [[ "${OPENDR_DEVICE}" == "gpu" ]]; then
Expand Down
1 change: 1 addition & 0 deletions docs/reference/activity-recognition.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

The *activity_recognition* module contains the *X3DLearner* and *CoX3DLearner* classes, which inherit from the abstract class *Learner*.

You can find the classes and the corresponding IDs regarding activity recognition [here](https://github.com/opendr-eu/opendr/blob/master/src/opendr/perception/activity_recognition/datasets/kinetics400_classes.csv).

### Class X3DLearner
Bases: `engine.learners.Learner`
Expand Down
5 changes: 5 additions & 0 deletions docs/reference/semantic-segmentation.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,11 @@

The *semantic segmentation* module contains the *BisenetLearner* class, which inherit from the abstract class *Learner*.

On the table below you can find the detectable classes and their corresponding IDs:

| Class | Bicyclist | Building | Car | Column Pole | Fence | Pedestrian | Road | Sidewalk | Sign Symbol | Sky | Tree | Unknown |
|--------|-----------|----------|-----|-------------|-------|------------|------|----------|-------------|-----|------|---------|
| **ID** | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |

### Class BisenetLearner
Bases: `engine.learners.Learner`
Expand Down
127 changes: 78 additions & 49 deletions projects/opendr_ws/README.md
Original file line number Diff line number Diff line change
@@ -1,66 +1,95 @@
# opendr_ws

## Description
This ROS workspace contains ROS nodes and tools developed by OpenDR project. Currently, ROS nodes are compatible with ROS Noetic.
This workspace contains the `ros_bridge` package, which provides message definitions for ROS-compatible OpenDR data types,
This ROS workspace contains ROS nodes and tools developed by OpenDR project.
Currently, ROS nodes are compatible with **ROS Melodic for Ubuntu 18.04** and **ROS Noetic for Ubuntu 20.04**.
The instructions that follow target ROS Noetic, but can easily be modified for ROS Melodic by swapping out the version name.
This workspace contains the `opendr_bridge` package, which provides message definitions for ROS-compatible OpenDR data types,
as well the `ROSBridge` class which provides an interface to convert OpenDR data types and targets into ROS-compatible
ones similar to CvBridge. You can find more information in the corresponding [documentation](../../docs/reference/rosbridge.md).
ones similar to CvBridge. You can find more information in the corresponding [documentation](../../docs/reference/opendr-ros-bridge.md).


## Setup
For running a minimal working example you can follow the instructions below:
## First time setup
For the initial setup you can follow the instructions below:

0. Source the necessary distribution tools:
0. Make sure ROS noetic is installed: http://wiki.ros.org/noetic/Installation/Ubuntu (desktop full install)

```source /opt/ros/noetic/setup.bash```
1. Open a new terminal window and source the necessary distribution tools:
```shell
source /opt/ros/noetic/setup.bash
```
_For convenience, you can add this line to your `.bashrc` so you don't have to source the tools each time you open a terminal window._
2. Navigate to your OpenDR home directory (`~/opendr`) and activate the OpenDR environment using:
```shell
source bin/activate.sh
```
You need to do this step every time before running an OpenDR node.
3. Navigate into the OpenDR ROS workspace::
```shell
cd projects/opendr_ws
```
4. (Optional) Most nodes with visual input are set up to run with a default USB camera. If you want to use it install the corresponding package and its dependencies:
```shell
cd src
git clone https://github.com/ros-drivers/usb_cam
cd ..
rosdep install --from-paths src/ --ignore-src
```
5. Build the packages inside the workspace:
```shell
catkin_make
```
6. Source the workspace:
```shell
source devel/setup.bash
```
You are now ready to run an OpenDR ROS node, in this terminal but first the ROS master node needs to be running

1. Make sure you are inside opendr_ws
2. If you are planning to use a usb camera for the demos, install the corresponding package and its dependencies:
7. Before continuing, you need to start the ROS master node by running:
```shell
roscore &
```
You can now run an OpenDR ROS node. More information below.

#### After first time setup
For running OpenDR nodes after you have completed the initial setup, you can skip steps 2 and 5 from the list above.
You can also skip building the workspace (step 6) granted it's been already built and no changes were made to the code inside the workspace, e.g. you modified the source code of a node.

#### More information
After completing the setup you can read more information on the [opendr perception package README](src/opendr_perception/README.md), where you can find a concise list of prerequisites and helpful notes to view the output of the nodes or optimize their performance.

#### Node documentation
You can also take a look at the list of tools [below](#structure) and click on the links to navigate directly to documentation for specific nodes with instructions on how to run and modify them.

**For first time users we suggest reading the introductory sections (prerequisites and notes) first.**

```shell
cd src
git clone https://github.com/ros-drivers/usb_cam
cd ..
rosdep install --from-paths src/ --ignore-src
```
3. Install the following dependencies, required in order to use the OpenDR ROS tools:
```shell
sudo apt-get install ros-noetic-vision-msgs ros-noetic-geometry-msgs ros-noetic-sensor-msgs ros-noetic-audio-common-msgs
```
4. Build the packages inside workspace
```shell
catkin_make
```
5. Source the workspace and you are ready to go!
```shell
source devel/setup.bash
```
## Structure

Currently, apart from tools, opendr_ws contains the following ROS nodes (categorized according to the input they receive):

### [Perception](src/perception/README.md)
### [Perception](src/opendr_perception/README.md)
## RGB input
1. [Pose Estimation](src/perception/README.md#pose-estimation-ros-node)
2. [Fall Detection](src/perception/README.md#fall-detection-ros-node)
3. [Face Recognition](src/perception/README.md#face-recognition-ros-node)
4. [2D Object Detection](src/perception/README.md#2d-object-detection-ros-nodes)
5. [Face Detection](src/perception/README.md#face-detection-ros-node)
6. [Panoptic Segmentation](src/perception/README.md#panoptic-segmentation-ros-node)
7. [Semantic Segmentation](src/perception/README.md#semantic-segmentation-ros-node)
8. [Video Human Activity Recognition](src/perception/README.md#human-action-recognition-ros-node)
9. [Landmark-based Facial Expression Recognition](src/perception/README.md#landmark-based-facial-expression-recognition-ros-node)
10. [FairMOT Object Tracking 2D](src/perception/README.md#fairmot-object-tracking-2d-ros-node)
11. [Deep Sort Object Tracking 2D](src/perception/README.md#deep-sort-object-tracking-2d-ros-node)
12. [Skeleton-based Human Action Recognition](src/perception/README.md#skeleton-based-human-action-recognition-ros-node)
## Point cloud input
1. [Voxel Object Detection 3D](src/perception/README.md#voxel-object-detection-3d-ros-node)
2. [AB3DMOT Object Tracking 3D](src/perception/README.md#ab3dmot-object-tracking-3d-ros-node)
1. [Pose Estimation](src/opendr_perception/README.md#pose-estimation-ros-node)
2. [Fall Detection](src/opendr_perception/README.md#fall-detection-ros-node)
3. [Face Detection](src/opendr_perception/README.md#face-detection-ros-node)
4. [Face Recognition](src/opendr_perception/README.md#face-recognition-ros-node)
5. [2D Object Detection](src/opendr_perception/README.md#2d-object-detection-ros-nodes)
6. [2D Object Tracking](src/opendr_perception/README.md#2d-object-tracking-ros-nodes)
7. [Panoptic Segmentation](src/opendr_perception/README.md#panoptic-segmentation-ros-node)
8. [Semantic Segmentation](src/opendr_perception/README.md#semantic-segmentation-ros-node)
9. [Landmark-based Facial Expression Recognition](src/opendr_perception/README.md#landmark-based-facial-expression-recognition-ros-node)
10. [Skeleton-based Human Action Recognition](src/opendr_perception/README.md#skeleton-based-human-action-recognition-ros-node)
11. [Video Human Activity Recognition](src/opendr_perception/README.md#video-human-activity-recognition-ros-node)
## RGB + Infrared input
1. [End-to-End Multi-Modal Object Detection (GEM)](src/perception/README.md#gem-ros-node)
## RGBD input nodes
1. [RGBD Hand Gesture Recognition](src/perception/README.md#rgbd-hand-gesture-recognition-ros-node)
## Biosignal input
1. [Heart Anomaly Detection](src/perception/README.md#heart-anomaly-detection-ros-node)
1. [End-to-End Multi-Modal Object Detection (GEM)](src/opendr_perception/README.md#2d-object-detection-gem-ros-node)
## RGBD input
1. [RGBD Hand Gesture Recognition](src/opendr_perception/README.md#rgbd-hand-gesture-recognition-ros-node)
## RGB + Audio input
1. [Audiovisual Emotion Recognition](src/opendr_perception/README.md#audiovisual-emotion-recognition-ros-node)
## Audio input
1. [Speech Command Recognition](src/perception/README.md#speech-command-recognition-ros-node)
1. [Speech Command Recognition](src/opendr_perception/README.md#speech-command-recognition-ros-node)
## Point cloud input
1. [3D Object Detection Voxel](src/opendr_perception/README.md#3d-object-detection-voxel-ros-node)
2. [3D Object Tracking AB3DMOT](src/opendr_perception/README.md#3d-object-tracking-ab3dmot-ros-node)
## Biosignal input
1. [Heart Anomaly Detection](src/opendr_perception/README.md#heart-anomaly-detection-ros-node)
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading