biective Proiect și Resurse Acumularea datelor Procesarea datelor Implementare Verilog Analiză performanță Concluzie Întrebări

# Modul FPGA de generare a unei hărți de temperatură Project VSLI-SA - Sensor Fusion

Ciocîrlan Ştefan-Dan1

<sup>1</sup> Facultatea de Automatică și Calculatoare Master Securitatea Rețelelor Informatice Complexe

07.11.2018



 Ciocîrlan Ştefan-Dan
 UPB
 VSLI-SA
 07.11.2018
 1 / 13

### Cuprins

- 1 Obiective Proiect si Resurse
- 2 Acumularea datelor
- 3 Procesarea datelor
  - Poziția senzorilor
  - Metodă de interpolare a datelor
  - Imagine hartă temperatură
- 4 Implementare Verilog
  - UART
  - FSM
- 5 Analiză performantă
- 6 Concluzie
- 7 Întrebări



Ciocîrlan Ştefan-Dan UPB

### **Obiective Proiect**

Obiective Proiect si Resurse

- Acumularea datelor de la mai multi senzori si procesarea lor împreună
- Generarea hărții unei încăperi mari și poziționarea senzorilor
- Crearea unei hărți de tempertură care să se suprapună pesta harta inițială
- Analiza performanței acestui sistem și utilității lui



 Ciocîrlan Ştefan-Dan
 UPB
 VSLI-SA
 07.11.2018
 3 / 13

#### Resurse

Obiective Proiect și Resurse



- Senzor temperatură Z-Wave Fibaro FGMS-001
- Robotul Tiago (propriul senzor de temperatură)
- 4 Artix-7 FPGA











4/13

### Acumularea datelor

- Z-Wave (protocol de comunicare fă fir folosit în automatizarea caselor)
- Openhab 2 (soluție pentru automatizare în IOT)
- ROS (Robot Operating System)
  - Folosit pentru centralizarea tuturor informatiilor
  - Utilitarul gmapping (openSLAM) folosit pentru maparea unei încăperi
- MongoDB (bază de date)
  - Stocarea datelor
  - Procesarea şi verificarea datelor ulterior (mongoexport)



 Ciocîrlan Ştefan-Dan
 UPB
 VSLI-SA
 07.11.2018
 5 / 13

se Acumularea datelor Procesarea datelor Implementare Verilog Analiză performanță Concluzie Întrebări

# Poziția senzorilor pe harta virtuală

#### Am utilizat GIMP

Poziția senzorilor







6/13

Obiective Proiect si Resurse

Metodă de interpolare a datelor

Întrebări

# IDW(Interpolare prin parametrizare în funcție de distanță)

$$u(\mathbf{x}) = egin{cases} rac{\sum_{i=1}^N w_i(\mathbf{x}) u_i}{\sum_{i=1}^N w_i(\mathbf{x})}, & ext{if } d(\mathbf{x}, \mathbf{x}_i) 
eq 0 ext{ for all } i, \ u_i, & ext{if } d(\mathbf{x}, \mathbf{x}_i) = 0 ext{ for some } i, \end{cases}$$
 where  $w_i(\mathbf{x}) = rac{1}{d(\mathbf{x}, \mathbf{x}_i)^p}$ 

Am folosit p=2



7/13

Imagine hartă temperatură

# Generare hărții de temperatură sub formă de imagine



Am folosit modulele din python pillow și numpy



Ciocîrlan Stefan-Dan UPB 07.11.2018 8/13 Acumularea datelor Procesarea datelor Implementare Verilog Analiză performantă Întrebări •0

### Comunicare dintre Tiago și FPGA

DATA

BIT 0

(LSB)

DATA

BIT 1

START

BIT







DATA

BIT 7

(MSB)

STOP

BIT

DATA

BIT 2

DATA

BIT 3

DATA

BIT 4

DATA

BIT 5

DATA

BIT 6

rse Acumularea datelor Procesarea datelor Implementare Verilog Analiză performanță Concluzie Întrebări

### Modul de funcționare a modulului

FSM





Ciocîrlan Ştefan-Dan UPB VSLI-SA 07.11.2018 10 / 13

ective Proiect și Resurse Acumularea datelor Procesarea datelor Implementare Verilog Analiză performanță Concluzie Întrebări

### Python vs FPGA

| Durată etape(s) |                  |           |                   |
|-----------------|------------------|-----------|-------------------|
| Mod de          | Transmitere date | Procesare | Transmitere Harta |
| Funcționare     | senzori          |           |                   |
| Python-Total    | 0.0281219        | 0.3514511 | 0.6340050         |
| FPGA-Total      | 0.0671550        | 0.0008880 | 3.8272800         |
| Python-Medie    | 0.0002532        | 0.0031662 | 0.0057117         |
| FPGA-Medie      | 0.0006050        | 0.0000080 | 0.0344800         |



11 / 13

### Concluzii si muncă ulterioară

#### Concluzii

- Procesarea hărții pe FPGA este de 1000 de ori mai rapidă (alt ordin de mărime)
- Transmiterea datelor are cea mai mare durată din întreg procesul
- Acest procedeu poate fi folosit și cu alte tipuri de senzori
- Introducerea procesării pe FPGA în cadrul sistemului ROS
- Un mod de verificare a metodelor de interpolare prin intermediul deplasării robotului Tiago prin mediu

#### Muncă ulterioară

- Folosirea altor metode de interpolare
- Folosirea altor tipuri de senzori
- Localizarea în funtie de harta oferită de senzori



12 / 13

surse Acumularea datelor Procesarea datelor Implementare Verilog Analiză performanță Concluzie Întrebări

### Întrebări





13 / 13