ALFA is a tool designed for the development and evaluation of LiDAR data processing algorithms in various setups, with a special focus on embedded platforms with acceleration capabilities. ALFA enables seamless interfacing with a wide range of devices and sensors, facilitating the creation and deployment of hardware accelerators for processing point cloud data in diverse applications, such as weather denoising and ground segmentation.
ALFA can be roughly split into two different domains: (1) Desktop, and the (2) Embedded System, divided between the Software and Hardware Layers. In the Software layer, all code runs on top of a Linux distribution with Robot Operating System 2 (ROS2) support. The ALFA components follow a ROS2 configuration, which allows for an easy integration with other ROS-based software and 3rd-party Libraries, e.g., the Point Cloud Library (PCL). The main software components of the framework are called ALFA Extensions, which is where developers can deploy point cloud processing algorithms, and are a built on top of the ALFA Node.
ALFA Node is a ROS-based node that supports the ALFA Extensions to facilitate the development of point cloud processing algorithms. The ALFA Node receives configurations through the ROS2 set parameters command (ros2 param set <node_name> <parameter_name> <value>), outputs real-time metrics (/NODE_NAME_metrics) and publishes the processed point cloud data into a new PointCloud2 ROS2 topic (NODE_NAME_pointcloud). The point cloud data can be retrieved from a real LiDAR sensor connected to the platform or from a public dataset thtough a ROS2 Bag (rosbag tool). Additionally, the Desktop version of the framework supports the ALFA Monitor, a GUI tool specially designed to configure the ALFA Extension, visualize point cloud data, and read real-time metrics from every ALFA Node running both in the Desktop and the Embedded System.
ALFA targets embedded hardware platforms with acceleration capabilities, enabling the deployment of custom accelerators in FPGA. For developing a hardware-based extension, it is necessary to deploy the ALFA-Unit. This component includes different hardware blocks, such as the (1) Extension Management Unit (ExMU), (2) the Monitor Unit (MonU), and the (3) Memory Management Unit (MemMU). Everytime a new Extension is instantiated in the hardware, a new ALFA-Unit is required. Other hardware blocks available in the FPGA are the the Sensor Interface Unit (SIU), several hardware-based Libraries used for point cloud processing, and a Coordinate System Converter (CSC) block used for fast conversion between spherical and cartesian coordinates systems. The communication between the Processing System (PS) and the Programmable Logic (PL) is done through standard AMBA communication buses, e.g., AXI, and through the DDR memory present in the platform.
The hardware blocks present in the ALFA Core are described as follows:
-
ExMU: Connects the Hardware Extension blocks and the ALFA-Unit. It provides a dedicate point cloud interface and a cache memory to store point cloud data.
-
MonU: Regists data of several monitoring points, used to trace the behavior of the hardware blocks, including Extensions. Such data can be visualized in the ALFA Monitor tool.
-
MemMU: This block is responsible to manage any memory-related operations between the ALFA-Unit and the PS. the MemMU supports the management and storage of point clouds following different organizations and formats. It can interface both the on-chip DDR RAM and the available BRAM.
-
SIU: Connects in hardware with the LiDAR to receive, decode, and reconstruct the point cloud data retrieved from the Ethernet Interface. Since it performs fast, it can support several and distinct sensors, at the same time. This module can deploy a custom point cloud data representation format, which can be used to represent any sensor data following the same structure.
-
Libs: A set of generic algorithms and libs deployed in hardware, which have a corresponding version in software, that can be resorted by the Extensions according to their application. These libraries can include: range images conversion, data compression-related blocks, data structures (e.g., octrees), etc.
-
CSC: This block provides a fast conversion between the spherical and the cartesian coordinate systems.
This configuration provides the basic installation of ALFA, which consists of the ALFA Monitor, at least one ALFA Node, and at least one point cloud data. This simple setup does not require any hardware platform and can be used to test or deploy any point cloud processing algorithm. Thsi is also useful to test ALFA before aquiring a hardware platform.
This configuration provides the basic installation of ALFA on an embedded hardware platform. It can also interface a LiDAR sensor or retrieve the point cloud from a ROS Bag. However, the visualization can only be performed through the ALFA Monitor running on a Desktop system. This setup is usefull to test the deployment of algorithms and extensions on a real hardware plaform and retrieve performance metrics, before offloading the desired software modules to hardware.
This setup provides the best trade-off between performance and hardware resources since it allows, in an embedded system, the deployment of hardware blocks to execute the most time-consuming tasks, usually performed by high performance processing systems. With this setup, the interface to the LiDAR sensor can be done through the onboard Ethernet port, where data can flow from the software driver to the Hardware Extensions, or by directly to a hardware-based Ethernet port, which allows for the SIU module to interface, read, decode, and process the received point cloud data. Such approach allows for extremelly high performance gains since all the processing is performed in hardware.
The repository of the ALFA Framework includes the following modules:
- extensions - Supported ALFA Extensions (sw-only, or both sw/hw).
- node - The source files of the ALFA Node.
- drivers - Contains the source files of the ALFA Drivers.
- unit - Contains all hardware (verilog sources) of the ALFA Unit components.
- platforms - Contains the files of supported hardware platforms.
- msgs - ROS messages used by the ALFA framework.
- libs - Compilation of hardware and software libraries to be used by Extensions
- monitor - The source files of the ALFA Monitor Tool.
- meta-alfa - The ALFA layer for Yocto/Petalinux with the currently supported packages.
ALFA is composed of different components according to different features and functionalities. Currently supported installations:
- To Install ALFA on a Linux-based Desktop system:
- Ubuntu 22.04.1 LTS with ROS 2 Humble Hawksbill (Setup guide)
- To install ALFA on an Embedded platform:
- Xilinx Zynq UltraScale+ MPSoC ZCU104 (Petaliunx and Vivado) (Setup guide)
- More tools are going to be supported - TBA
There are also several user guides available to help you get started with ALFA:
- Monitor Tool User Guide (User guide)
- Extensions User Guide (User guide)
[1] R. Roriz, J. Cabral and T. Gomes, "Automotive LiDAR Technology: A Survey," in IEEE Transactions on Intelligent Transportation Systems, vol. 23, no. 7, pp. 6282-6297, July 2022, DOI: https://doi.org/10.1109/TITS.2021.3086804.
[2] R. Roriz, A. Campos, S. Pinto and T. Gomes, "DIOR: A Hardware-Assisted Weather Denoising Solution for LiDAR Point Clouds," in IEEE Sensors Journal, vol. 22, no. 2, pp. 1621-1628, 15 Jan.15, 2022, DOI: https://doi.org/10.1109/JSEN.2021.3133873.
[3] L. Cunha, R. Roriz, S. Pinto and T. Gomes, "Hardware-Accelerated Data Decoding and Reconstruction for Automotive LiDAR Sensors," in IEEE Transactions on Vehicular Technology, 2022, DOI: https://doi.org/10.1109/TVT.2022.3223231.
[4] Gomes, T.; Matias, D.; Campos, A.; Cunha, L.; Roriz, R. "A Survey on Ground Segmentation Methods for Automotive LiDAR Sensors". Sensors 2023, 23, 601. https://doi.org/10.3390/s23020601
[5] Roriz, R.; Gomes, T. "An Embedded Framework for Automotive LiDAR Sensors". embedded world Exhibition&Conference 2023.
[6] Gomes, T.; Roriz, R.; Cunha, L.; Ganal, A.; Soares, N.; Araújo, T.; Monteiro, J. "Evaluation and testing system for automotive LiDAR sensors". Applied Sciences 12 (24), 13003. https://doi.org/10.3390/app122413003