



# HW-SW management using a lightweight Yocto-based OS on a ZCU102

Raffaele Meloni<sup>1</sup>, Giuseppe Meloni<sup>2</sup>, Daniel Madroñal<sup>1</sup>

<sup>1</sup> Università degli Studi di Sassari

<sup>2</sup> Abinsula S.R.L.



# Introduction

# Proposed methodology

#### Assessment



# Introduction

# Proposed methodology

Assessment



























#### Introduction

# Proposed methodology

#### Assessment





















# **Multi-Dataflow Composer**

UNISS + UNICA https://github.com/mdc-suite



#### **Multi-Dataflow Composer**



UNISS + UNICA https://github.com/mdc-suite



**UNISS + UNICA** 





#### Multi-Dataflow Composer











**Multi-Dataflow Composer** 

- Dataflow-based design
- Multi-Dataflow accelerator

UNISS + UNICA https://github.com/mdc-suite



**Multi-Dataflow Composer** 

- Dataflow-based design
- Multi-Dataflow accelerator
- ✓ Co-Processor infrastructure
- ✓ Vivado scripts

UNISS + UNICA

https://github.com/mdc-suite



**Multi-Dataflow Composer** 

- Dataflow-based design
- Multi-Dataflow accelerator
- ✓ Co-Processor infrastructure
- ✓ Vivado scripts
- ✓ SW APIs

UNISS + UNICA https://github.com/mdc-suite



- Yocto flow:
  - Select the target architecture
  - Select the layers to be included
  - Bitbake



- Yocto flow:
  - Select the target architecture
  - Select the layers to be included
  - Bitbake
- Create the HW accelerator with MDC



- Yocto flow:
  - Select the target architecture
  - Select the layers to be included
  - Bitbake
- Create the HW accelerator with MDC

- FPGA flow:
  - Include the accelerator in Vivado
  - Generate the bitstream and the binary file



- Yocto flow:
  - Select the target architecture
  - Select the layers to be included
  - Bitbake
- Create the HW accelerator with MDC

- FPGA flow:
  - Include the accelerator in Vivado
  - Generate the bitstream and the binary file
- Yocto flow:
  - Burn the SD card
  - Use it





#### Introduction

# Proposed methodology

#### Assessment













- Comp4Drones ECSEL JU Project: Precision Agriculture
  - $\circ~$  FPGA-Based on-board real-time processing
  - $\circ$  ZCU102 FPGA





- Comp4Drones ECSEL JU Project: Precision Agriculture
  - FPGA-Based on-board real-time processing
  - $\circ$  ZCU102 FPGA







- Comp4Drones ECSEL JU Project: Precision Agriculture
  - FPGA-Based on-board real-time processing
  - ZCU102 FPGA
  - Soil Segmentation











Median filter – Box-based filtering









#### Median filter – Box-based filtering



































![](_page_46_Picture_1.jpeg)

![](_page_46_Picture_2.jpeg)

![](_page_46_Picture_3.jpeg)

![](_page_46_Figure_4.jpeg)

![](_page_47_Picture_1.jpeg)

![](_page_47_Picture_2.jpeg)

![](_page_47_Picture_3.jpeg)

![](_page_47_Picture_4.jpeg)

![](_page_48_Picture_1.jpeg)

16x16

![](_page_48_Picture_2.jpeg)

32x32

Comp4Drones ECSEL JU Project: Precision Agriculture
Artichoke field – Soil Segmentation

Artichoke field

![](_page_48_Picture_5.jpeg)

![](_page_48_Picture_6.jpeg)

![](_page_49_Picture_1.jpeg)

![](_page_49_Picture_2.jpeg)

- Comp4Drones ECSEL JU Project: Precision Agriculture
  - $\circ~$  Artichoke field Soil Segmentation
  - $\circ$  Speedup up to 1.55× (HW vs SW) with different box sizes

![](_page_49_Picture_6.jpeg)

![](_page_50_Picture_1.jpeg)

![](_page_50_Picture_2.jpeg)

- Comp4Drones ECSEL JU Project: Precision Agriculture
  - $\circ~$  Artichoke field Soil Segmentation
  - $\circ$  Speedup up to 1.55× (HW vs SW) with different box sizes
  - Same accuracy (HW vs SW)

![](_page_50_Picture_7.jpeg)

![](_page_51_Picture_0.jpeg)

#### Introduction

# Proposed methodology

Assessment

![](_page_52_Picture_1.jpeg)

- ✓ MDC: ease HW accelerator design
- ✓ MDC: generate HW-SW system and SW APIs
- ✓ YOCTO: customizable OS
- ✓ System validated in precision agriculture (Comp4Drones)
- ✓ Acceleration of 1.55×

- ✓ MDC: ease HW accelerator design
- ✓ MDC: generate HW-SW system and SW APIs
- ✓ YOCTO: customizable OS
- ✓ System validated in precision agriculture (Comp4Drones)
- ✓ Acceleration of  $1.55 \times$
- Precision agriculture: implement the whole Comp4Drones Use-Case
- OS connection with drone autopilot

- ✓ MDC: ease HW accelerator design
- ✓ MDC: generate HW-SW system and SW APIs
- ✓ YOCTO: customizable OS
- ✓ System validated in precision agriculture (Comp4Drones)
- ✓ Acceleration of  $1.55 \times$
- Precision agriculture: implement the whole Comp4Drones Use-Case
- OS connection with drone autopilot
- Testing in other fields (e.g. Automotive)
- Multithreading support

![](_page_56_Picture_0.jpeg)

![](_page_56_Picture_1.jpeg)

# **Questions?**

r.meloni10@studenti.uniss.it giuseppe.meloni@abinsula.com dmadronalquin@uniss.it

#### Raffaele Meloni<sup>1</sup>, Giuseppe Meloni<sup>2</sup>, Daniel Madroñal<sup>1</sup>

<sup>1</sup> Università degli Studi di Sassari

<sup>2</sup> Abinsula S.R.L.