#### **Intel FPGA VIP webinar series**

# Building Video Processing Pipelines

Francisco Perez Intel FPGA Field Applications Engineer v.1 – October 2020

# Video processing on FPGAs made easy

## Objectives

- What resources are available to develop Video Processing solutions?
- From the basics: step through an incremental series of example designs
- End2End flow demonstration: hardware architecture design, software development & debug
- Sessions will be recorded. Exercise manuals and project files will be available for on-demand consumption

# Resources for Video Processing Applications

### Plug & Play blocks for rapid design creation

- Video Processing building blocks (VIP Suite)
- Connectivity IPs (DisplayPort, HDMI, SDI, ...)
- Development kits and video I/O daughter cards
- Collection of reference designs and application notes

This webinar series ;)

# 8K-Ready Video and Image Processing Suite

- Collection of 20+ IP functions with support for all Intel FPGAs
- VIP Suite II provides a design philosophy for rapid new design creation and easy integration of custom value-add features
- Easy integration with video connectivity IP cores, such as: HDMI, DisplayPort, 12G-SDI, SMPTE 2110 and MIPI
- Supports a wide range of resolutions, fps, bits per color
  - 1080p/4K/8K, HDR ready, 120+ fps, 16 bpc
- Visually exceeds most of the ASSPs



https://www.intel.com/content/www/us/en/programmable/products/intellectual-property/ip/dsp/m-alt-vipsuite.html

# Video Connectivity IPs

#### DisplayPort

- Compliant with 1.4 -> 2.0 in dev
- Up to 4-ch MST Support, up to 8-ch audio
- Link Training quality analysis

#### HDMI

- Compliant with 2.0 and prev
- Supporting new 2.1 FRL
- Deep color mode, up to 8-ch audio

#### HDCP

Certified 1.4/2.3 with HDMI and DP

#### SDI

Multistandard up to 12G-SDI

4k30 **Ethernet** Ethernet ● 60 fps 60 fps ● 1080p60 1080p60 ● 50 fps 50 fps •-HD HD 1080p30 ● 30 fps 30 fps • 1080p30 **24** fps 1080i 24 fps • 1080i SDI SDI 720p 720p SD SD YCrCb 4:4:4 576p → YCrCb 4:4:4 LVDS LVDS 576p ● YCbCr 4:2:2 480p 480p YCrCb 4:2:0 ● YCbCr 4:2:0

Video IN

DisplayPort

HDMI

8k60

**UHD** 

4K120

4K60

4k30

**Video Processing** 

1080

480

**1**080

**480** 

Video OUT

DisplayPort

**HDMI** 

8k60

4K60

4K120

UHD

https://www.intel.com/content/www/us/en/broadcast/products/programmable/applications/connectivity-solutions.html

# Development kits and I/O cards

Build your PoC matching FPGA fabric and interfaces











DisplayPort







Cyclone10 GX SoM + carrier

### Hardware used in these webinars

- Cyclone10 GX devkit
  - https://www.intel.com/content/www/ us/en/programmable/products/board s\_and\_kits/dev-kits/altera/cyclone-10-gx-development-kit.html
- Bitec displayport daughter card rev.11
  - https://bitec-dsp.com/product/fmcdisplayport-daughter-card-revision-11/



# Reference Designs and App Notes

### Full-featured examples up to 8K

|               |                               | SDI                                                                                      | DisplayPort                                                                                                               | НДМІ                                                                                                                                               | VIP                                                                                                                                       |
|---------------|-------------------------------|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| A10/C10 GX/SX | Reference Design/<br>Examples | 1. A10 / C10 SDI Design Example VCXO/VCXOless 2. 12G SDI + CVI/CVO ref design (2SI only) | 1. A10 / C10 DP 1.4 Design<br>Example<br>2. DP 1.4 RX/TX<br>3. A10 / C10 DP 1.2 UDX Lite<br>4. A10 DP UDX 1.4 8k30 in/out | 1. A10 UDX10 (HDMI 2.0) Ref Design,<br>C10 UDX10 Lite 2. A10 / C10 HDMI 2.0 Design Example (retransmit) 3. EA HDMI 2.1 Design Example (retransmit) | 1. <u>A10 UHD (4k60) HDMI 2.0 Ref Design</u> 2. <u>A10 / C10 DP 1.2, C10 HDMI 2.0 UDX Lite</u> 3. <u>A10 DP 1.4 8k30 in/out</u>           |
|               | Target Hardware               | 1.2. A10/C10 FPGA Devkit + Nextera FMC/Terasic 3. A10/C10 FPGA Devkit + Terasic          | 1 - 4. A10/C10 FPGA Devkit +<br>Bitec DP FMC daughter card<br>rev8/11                                                     | 1-2: A10/C10 FPGA Devkit + Bitec<br>HDMI FMC daughter Card rev11<br>3. Bitec FMC HDMI 2.1 rev4                                                     | 1. A10/C10 GX Devkit + Bitec HDMI FMC daughter<br>Card <u>rev11</u><br>2/3. A10 GX Devkit + Bitec DP FMC daughter card<br>rev8/ <u>11</u> |
| S10 GX/SX/MX  | Reference Design/<br>Examples | SDI Design Example VCXO/VCXOless     12G multi-rate Audio Embed, De-embed (upon request) | 1. <u>DP 1.4 design example</u>                                                                                           | 1.HDMI Design Example                                                                                                                              |                                                                                                                                           |
|               | Target Hardware               | 1. S10 FPGA H-tile / SoC kit (upon request) DevKit+<br>Nextera FMC/Terasic               | 1. S10 FPGA Devkit + Bitec DP<br>FMC daughter card rev 8/11                                                               | 1. S10 GX Dev Kit + Bitec HDMI 2.0 FMC daughter card rev11                                                                                         |                                                                                                                                           |

### References



- Displayport IP User Guide
  - https://www.intel.com/content/www/us/en/programmable/products/intellectual-property/ip/interface-protocols/m-alt-displayport-megacore.html
- Cyclone 10 GX Displayport Design Example User Guide
  - https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/ug/ug-dex-dp-c10gx.pdf
- AN745: Design Guidelines for Displayport Interface
  - https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/an/an 745.pdf
- Quartus Prime Pro Installation Guide 20.3
  - <a href="https://www.intel.com/content/dam/altera-www/global/en">https://www.intel.com/content/dam/altera-www/global/en</a> US/pdfs/literature/manual/quartus install.pdf
- NiosII EDS installation 20.3
  - https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/hb/nios2/n2sw\_nii5v2gen2.pdf
- Embedded Design Handbook
  - https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/hb/nios2/edh\_ed\_handbook.pdf





### Webinar Series

### Soft start -> Increasing Complexity

- 1. Building a video processing pipeline (Oct, 14<sup>th</sup> and 21<sup>st</sup>)
  - Getting video processed through the devkit, incremental flow
  - Detailed step flow on hardware implementation
  - Software application development using C++ API for a Nios II CPU
- 2. Strategies to debug a VIP pipeline (Nov, 4<sup>th</sup>)
  - Overview of system level considerations and key video concepts
  - Introduce the methods to build up and debug video systems
  - Overview of Avalon-ST Video protocol
- 3. Integrate a simple custom component (Nov, 19<sup>th</sup>)
  - How to add your "secret sauce" to the application
  - Step flow on how to develop a custom component compliant with VIP
- 4. Adding On Screen Display overlay (Dec, 16<sup>th</sup>)
  - Use a lightweight graphic library with Nios
  - Add text and graphic content overlay on top of your live video

All sessions – 10:00am to 12:00pm CET

