

- 임용성 2019310649
- 홍승범 2019314131
- 손정빈 2019312227
- 전우승 2019314431



# What is Sobel Edge Detection?



Matrix Operation



**RGB** 

**SOBEL** 

#### **CORE**

$$\mathbf{G}_x = egin{bmatrix} +1 & 0 & -1 \ +2 & 0 & -2 \ +1 & 0 & -1 \end{bmatrix} * \mathbf{A} \quad ext{and} \quad \mathbf{G}_y = egin{bmatrix} +1 & +2 & +1 \ 0 & 0 & 0 \ -1 & -2 & -1 \end{bmatrix} * \mathbf{A}$$

## How we Challenging this Problem?

SW



540 x 360 x 3(RGB) x 8bit = 4,665,600 bits

540 x 360 x 1(mono) x 8bit = 1,555,200 bits



540 x 360 x 8bit = 1,555,200 bits

■ SW

SW 전처리를 통해 RGB → MONO로 바꿈으로써 연산량을 3배 줄임 → Speed UP! HW

FPGA를 사용하여 행렬 연산을 가속

HW

$$\mathbf{G}_x = egin{bmatrix} +1 & 0 & -1 \ +2 & 0 & -2 \ +1 & 0 & -1 \end{bmatrix} * \mathbf{A} \quad ext{and} \quad \mathbf{G}_y = egin{bmatrix} +1 & +2 & +1 \ 0 & 0 & 0 \ -1 & -2 & -1 \end{bmatrix} * \mathbf{A}$$

### **Brief Summary**

- Hardware Using (Mandatory)
  - LED
  - 7-Segment
  - Push Switch & DIP SW
  - Reset SW
  - Piezo Buzzer

#### (Additional)

- VGA
- BRAM
- Clock Wizard

#### RTL & IP

- ∴ TOP\_SOC (TOP\_SOC.sv) (12)
- > 👎 U\_CLK : clk\_wiz\_0 (clk\_wiz\_0.xci)
- U\_SEGMENT : segment (segment.sv)
- U\_BUZZER : buzzer\_module (buzzer.sv)
- > 🖓 🔳 U\_BRAM0 : blk\_mem\_gen\_0 (blk\_mem\_gen\_0.xci)
- U\_MEM\_CTR: memory\_controller (memory\_controller.sv)
- U\_CONTROLLER: controller\_module (controller.sv)
- U\_pre: preprocess\_module (preprocess.sv)
- U CORE: core module (core.sv)
- U\_DPBRAM\_CTR\_A : mem\_ctr\_A (mem\_ctr\_A.sv)
- > 🖓 🔳 U\_BRAM1 : blk\_mem\_gen\_1 (blk\_mem\_gen\_1.xci)
- U\_DPBRAM\_CTR\_B : mem\_ctr\_B (mem\_ctr\_B.sv)
- U\_VGA\_PORT : vga\_port (vga.sv)
- Coefficient Files (1)
  - test\_MONO\_img\_540x360.coe

- ∨ Util
- ≡ master.xdc
- mono2coe\_oneFETCH.py
- mono2coe.py
- mono2sobel.py

coe2mono.py

reconstructed\_MONO\_image.png

SW

- rgb2mono.py
- sobel\_output.png
- **≡** SOBEL TOP.sv
- test\_MONO\_img\_540x360.coe
- test\_MONO\_img\_540x360.png
- test\_MONO\_img\_540x540.png
- test\_MONO\_img\_v2.PNG
- test\_MONO\_img\_vz.Fiv
- test\_RGB\_img.png





# Key Point & Dataflow



# **Brief Summary - Function**



### Function

- 1. Switch 1(DIP) → Mode1 ( Raw )
- 2. Switch 2(DIP) → Mode2 ( Sobel )
- 3. Switch 3(DIP) → Buzzer Mode
- 4. Button (MID) → Start Signal
- 5. Reset SW
  - → System Reset
- 6. DONE LED
- → At Done State
- 7. 7-Segment
- → # of Row which is processed

8. Buzzer

→ Up Tone at row up



### Result – Area

Board Name

- xc7a75tfgg484-1

**♦** Board Resource Limit

- Logic Cell : 75.520

- BRAM : 105KB

Utilization

- BRAM : 90%

- LUT : 25.28%

- FF : 14.33%

### **♦** Resource

| Resource | Utilization | Available | Utilization % |
|----------|-------------|-----------|---------------|
| LUT      | 11934       | 47200     | 25.28         |
| LUTRAM   | 3           | 19000     | 0.02          |
| FF       | 13532       | 94400     | 14.33         |
| BRAM     | 95          | 105       | 90.48         |
| DSP      | 7           | 180       | 3.89          |
| IO       | 35          | 285       | 12.28         |
| BUFG     | 5           | 32        | 15.63         |
| MMCM     | 1           | 6         | 16.67         |





#### **♦** Area



# Result – Power & Timing

### Power







### **♦** Timing

#### **Design Timing Summary**

#### There is no Slack!

| Setup                                | Hold                         |          | Pulse Width                              |          |
|--------------------------------------|------------------------------|----------|------------------------------------------|----------|
| Worst Negative Slack (WNS): 5.066 ns | Worst Hold Slack (WHS):      | 0.112 ns | Worst Pulse Width Slack (WPWS):          | 3.000 ns |
| Total Negative Slack (TNS): 0.000 ns | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |
| Number of Failing Endpoints: 0       | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |
| Total Number of Endpoints: 1057      | Total Number of Endpoints:   | 1057     | Total Number of Endpoints:               | 251      |

#### All user specified timing constraints are met.

### Result





Mode 1 Mode 2

### Comment

저희 팀의 주 목표는 Sobel Edge Operator 가속기를 설계하는 것이었습니다.

<u>가시성을 위해서 Mode1을 후반부에 추가하였고</u>, 5월 27일 이전까지 Mode1의 동작이 성공적으로 동작함을 확인하였으나, Version Update를 하면서, mode1이 오동작하는 문제가 발생했습니다. 하지만, 본래 목적인 Sobel 가속기 설계를 성공적으로 하였으므로, 이번 TermProject를 성공적으로 수행완료했습니다.

# Thank you ©

Q & A

### ◆ 역할 및 참여 내용

- 임용성
  - 1. Mem Ctr & Mem Ctr A & BRAM
  - 2. Preprocess
  - 3. TOP (Mode 1, Mode 2)
- 홍승범
  - 1. 7-Segment
  - 2. Preprocess
  - 3. CORE
- 손정빈 :
  - 1. VGA Controller
  - 2. CORE
  - 3. Mem Ctr B
- 전우승:
  - 1. Buzzer Controller
  - 2. Mem Ctr