• Stars
    star
    2,152
  • Rank 21,437 (Top 0.5 %)
  • Language
    C++
  • License
    Apache License 2.0
  • Created over 10 years ago
  • Updated 3 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

The most complete DDS - Proven: Plenty of success cases. Looking for commercial support? Contact [email protected]

eProsima Fast DDS

FIWARE Robotics License Releases Issues Forks Stars Twitter Follow
Documentation badge Status Linux ci Linux arm64 ci Windows ci Mac ci Coverage

eprosima Fast DDS (formerly Fast RTPS) is a C++ implementation of the DDS (Data Distribution Service) standard of the OMG (Object Management Group). eProsima Fast DDS implements the RTPS (Real Time Publish Subscribe) protocol, which provides publisher-subscriber communications over unreliable transports such as UDP, as defined and maintained by the Object Management Group (OMG) consortium. RTPS is also the wire interoperability protocol defined for the Data Distribution Service (DDS) standard. eProsima Fast DDS expose an API to access directly the RTPS protocol, giving the user full access to the protocol internals.

Some of the main features of this library are:

  • Configurable best-effort and reliable publish-subscribe communication policies for real-time applications.
  • Plug and play connectivity so that any new applications are automatically discovered by any other members of the network.
  • Modularity and scalability to allow continuous growth with complex and simple devices in the network.
  • Configurable network behavior and interchangeable transport layer: Choose the best protocol and system input/output channel combination for each deployment.
  • Two API Layers: a high-level Publisher-Subscriber one focused on usability (DDS) and a lower-level Writer-Reader one that provides finer access to the inner workings of the RTPS protocol.

eProsima Fast DDS has been adopted by multiple organizations in many sectors including these important cases:

  • Robotics: ROS (Robotic Operating System) as their default middleware for every ROS 2 long term (LTS) releases and most of the non-LTS releases.
  • EU R&D: FIWARE Incubated GE.

This project is part of FIWARE. For more information check the FIWARE Catalogue entry for Robotics.

Want us to share your project with the community?

Write to [email protected] or mention @EProsima on Twitter. We are curious to get to know your use case!

Supported platforms

More information about the official support can be found here

  • Linux Linux ci
  • Linux-aarch64 Linux arm64 ci
  • Windows Windows ci
  • Mac Mac ci

Installation Guide

You can get either a binary distribution of eprosima Fast DDS or compile the library yourself from source. Please, refer to Fast DDS documentation for the complete installation guide.

Installation from binaries

The latest, up to date binary release of eprosima Fast DDS can be obtained from the company website.

Documentation

You can access the documentation online, which is hosted on Read the Docs.

Quality Declaration

eprosima Fast DDS claims to be in the Quality Level 1 category based on the guidelines provided by ROS 2. See the Quality Declaration for more details.

Quick Demo

eProsima provides the eProsima Fast DDS Suite Docker image for those who want a quick demonstration of Fast-DDS running on an Ubuntu platform. It can be downloaded from eProsima's downloads page.

This Docker image was built for Ubuntu 20.04 (Focal Fossa).

To run this container you need Docker installed. From a terminal run the following command

$ sudo apt-get install docker.io

Load the docker image:

$ docker load -i ubuntu-fastdds-suite:<FastDDS-Version>.tar
$ docker tag ubuntu-fastdds-suite:<FastDDS-Version> ubuntu-fastdds-suite:latest

Run the eProsima Fast DDS Suite Docker container:

$ xhost local:root
$ docker run -it --privileged -e DISPLAY=$DISPLAY -v /tmp/.X11-unix:/tmp/.X11-unix \
ubuntu-fastdds-suite:<FastDDS-Version>

This Docker Image comes bundled with the following:

Shapes Demo

eProsima Shapes Demo is an application in which Publishers and Subscribers are shapes of different colors and sizes moving on a board. Each shape refers to its own topic: Square, Triangle or Circle. A single instance of the eProsima Shapes Demo can publish on or subscribe to several topics at a time.

You can read more about this application on the Shapes Demo documentation page.

To run this application once inside the Docker container run:

$ ShapesDemo

eProsima Shapes Demo usage information can be found on the Shapes Demo First Steps page.

Fast DDS Monitor

eProsima Fast DDS Monitor is a graphical desktop application aimed at monitoring DDS environments deployed using the eProsima Fast DDS library. Thus, the user can monitor in real time the status of publication/subscription communications between DDS entities. They can also choose from a wide variety of communication parameters to be measured (latency, throughput,packet loss, etc.), as well as record and compute in real time statistical measurements on these parameters (mean, variance, standard deviation, etc.).

You can read more about this application on the Fast DDS Monitor documentation page.

To run this application once inside the Docker container run:

$ fastdds_monitor

eProsima Fast DDS Monitor usage information can be found on the Fast DDS Monitor User Manual.

Fast DDS libraries and Examples

Included in this Docker container is a set of binary examples that showcase several functionalities of the Fast DDS libraries. These examples' path can be accessed from a terminal by typing

$ goToExamples

From this folder you can access all examples, both for DDS and RTPS. We detail the steps to launch two such examples below.

To launch the Hello World example (a minimal example that will perform a Publisher/Subscriber match and start sending samples) you could run:

$ goToExamples
$ cd dds/HelloWorldExample/bin
$ tmux new-session "./HelloWorldExample publisher 0 1000" \; \
split-window "./HelloWorldExample subscriber" \; \
select-layout even-vertical

This example is not constrained to the current instance. It's possible to run several instances of this container to check the communication between them by running the following from each container.

$ goToExamples
$ cd dds/HelloWorldExample/bin
$ ./HelloWorldExample publisher

or

$ goToExamples
$ cd dds/HelloWorldExample/bin
$ ./HelloWorldExample subscriber

Another example you could launch is the Benchmark example. This example creates either a Publisher or a Subscriber and on a successful match starts sending samples. After a few seconds the process that launched the Publisher will show a report with the number of samples transmitted.

On the subscriber side, run:

$ goToExamples
$ cd dds/Benchmark/bin
$ ./Benchmark subscriber udp

On the publisher side, run:

$ goToExamples
$ cd dds/Benchmark/bin
$ ./Benchmark publisher udp

Getting Help

If you need support you can reach us by mail at [email protected] or by phone at +34 91 804 34 48.


rosin_logo

Supported by ROSIN - ROS-Industrial Quality-Assured Robot Software Components. More information: rosin-project.eu

eu_flag

This project has received funding from the European Union’s Horizon 2020 research and innovation programme under grant agreement no. 732287.

More Repositories

1

Micro-XRCE-DDS

An XRCE DDS implementation. Looking for commercial support? Contact [email protected]
C++
158
star
2

Fast-CDR

eProsima FastCDR library provides two serialization mechanisms. One is the standard CDR serialization mechanism, while the other is a faster implementation of it. Looking for commercial support? Contact [email protected]
C++
142
star
3

Micro-XRCE-DDS-Client

Micro XRCE-DDS Client repository. Looking for commercial support? Contact [email protected]
C
131
star
4

Micro-XRCE-DDS-Agent

Micro XRCE-DDS Agent respository. Looking for commercial support? Contact [email protected]
C++
109
star
5

Fast-DDS-docs

Documentation of Fast RTPS (MarkDown Files). Looking for commercial support? Contact [email protected]
C++
84
star
6

Fast-DDS-Gen

Fast-DDS IDL code generator tool. Looking for commercial support? Contact [email protected]
Java
80
star
7

Integration-Service

C++
65
star
8

RPC

RPC over TCP/DDS/REST
C++
60
star
9

DDS-Router

The DDS Router is an application developed by eProsima that allows, using Fast DDS, to communicate by DDS protocol different networks. Looking for commercial support? Contact [email protected]
C++
57
star
10

Fast-DDS-python

Python bindings for Fast DDS. Looking for commercial support? Contact [email protected]
C++
56
star
11

Micro-CDR

C++
41
star
12

Fast-DDS-monitor

eProsima Fast DDS Monitor is a graphical desktop application aimed at monitoring DDS environments deployed using the eProsima Fast DDS library. Looking for commercial support? Contact [email protected]
C++
40
star
13

IDL-Parser

IDL Parser library for Fast DDS-Gen and RPC over TCP/DDS/REST. Looking for commercial support? Contact [email protected]
Java
30
star
14

px4_to_ros

ROS2/ROS packages for communicate PX4 with ROS
C++
27
star
15

vulcanexus

eProsima extended ROS 2 distribution. Looking for commercial support? Contact [email protected]
C++
25
star
16

foonathan_memory_vendor

foonathan/memory vendor package for Fast DDS. Looking for commercial support? Contact [email protected]
CMake
24
star
17

Discovery-Server

Tests for Fast DDS Discovery Server. Looking for commercial support? Contact [email protected]
C++
24
star
18

ShapesDemo

This application demostrates the capabilities of eProsima Fast RTPS. Looking for commercial support? Contact [email protected]
C++
23
star
19

xtypes

Implementation based on DDS-XTYPES standard (https://www.omg.org/spec/DDS-XTypes)
C++
20
star
20

Fast-Buffers

C
19
star
21

DDS-Record-Replay

eProsima DDS Record & Replay is an end-user software application that efficiently saves DDS data published into a DDS environment in a MCAP format database. Thus, the exact playback of the recorded network events is possible. Looking for commercial support? Contact [email protected]
C++
19
star
22

Fast-DDS-statistics-backend

eProsima Fast DDS Statistics Backend is a C++ library that provides collection and procession the statistics measurements reported by Fast DDS Statistics Module. Looking for commercial support? Contact [email protected]
C++
17
star
23

FastDDS-SH

eProsima's Integration Service System Handle for Fast DDS.
C++
13
star
24

dev-utils

C++
12
star
25

ROS2-SH

eProsima's Integration Service System Handle for ROS 2.
C++
12
star
26

ROS2-Integration-Service

ROS2 Integration and Routing: Provide a complete tool to integrate other technologies with ROS2 easily and enable ROS2 on WAN/Internet.
12
star
27

Micro-XRCE-DDS-docs

Micro XRCE-DDS documentation. Looking for commercial support? Contact [email protected]
Makefile
11
star
28

Micro-XRCE-DDS-Gen

Micro XRCE-DDS IDL code generator tool. Looking for commercial support? Contact [email protected]
Java
10
star
29

Micro-XRCE-DDS-Apps

Looking for commercial support? Contact [email protected]
C
10
star
30

Non-Intrusive-DDS-Recorder

Non-intrusive DDS Recorder is a tool to record all the DDS traffic in your network, using a non-intrusive mechanism allowing you to test, analyze or log your DDS distributed system without adding any new DDS participant or service, ensuring you are recording the real behavior and timing.
C
10
star
31

benchmarking

Python
9
star
32

FIROS2

eProsima FIROS2 is a ROS2 integrable tool focused in the intercommunication between ROS2 and FIWARE
C++
8
star
33

Fast-DDS-spy

eProsima Fast DDS Spy is a CLI interactive tool that allows to introspect a DDS network in human readable format. Looking for commercial support? Contact [email protected]
C++
7
star
34

Integration-Service-Deprecated

Fast-RTPS Integration Service: A set of services to integrate other protocols with Fast RTPS and connect different domains, LANs, and WANs.
C++
6
star
35

fastdds-visualizer-plugin

PlotJuggler plugin for Fast DDS
C++
6
star
36

DDS-Suite

Meta information to build eProsima DDS Suite. Looking for commercial support? Contact [email protected]
6
star
37

PX4-FastRTPS-PoC

PoC of Fast RTPS & PX4 data sharing
C
5
star
38

Dynamic-Fast-Buffers

eProsima Dynamic Fast Buffers is a high-performance dynamic serialization library, which allows users to describe and serialize or deserialize data at run-time.
C++
5
star
39

AML-IP

C++
4
star
40

Integration-Service-docs

Documentation related to Integration-Service
Makefile
4
star
41

FIWARE-SH

eProsima's Integration Service System Handle for FIWARE.
C++
3
star
42

Shapes-Demo-Docs

Docs for Fast RTPS Shapes Demo. Looking for commercial support? Contact [email protected]
Makefile
3
star
43

SustainML-Library

Application Aware, Life-Cycle Oriented Model-Hardware Co-Design Framework for Sustainable, Energy Efficient ML Systems
C++
3
star
44

Discovery-Server-docs

Discovery Server's documentation
Makefile
3
star
45

WebSocket-SH

eProsima's Integration Service System Handle for WebSocket.
C++
3
star
46

SustainML-Framework

QML
3
star
47

ROS1-SH

eProsima's Integration Service System Handle for ROS 1.
C++
2
star
48

PX4-FastRTPS-PoC-Snapdragon-UDP

C++
2
star
49

Micro-XRCE-DDS-Integration-Tests

Looking for commercial support? Contact [email protected]
C++
2
star
50

all-docs

Index of all eProsima documentation.
HTML
2
star
51

eProsima-CI

Python
2
star
52

DDS-Pipe

Core communication module for DDS Router, DDS Recorder and some other eProsima products. Looking for commercial support? Contact [email protected]
C++
2
star
53

t3chfest-ros2

C++
1
star
54

Micro-XRCE-DDS-Vendors

Specific tools and code to use Micro XRCE-DDS Client in different platforms.
1
star
55

Fast-DDS-QoS-Profiles-Manager

C++
1
star
56

flaky_test_infra_poc

Python
1
star
57

dds-types-test

1
star