衡阳派盒市场营销有限公司

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>FPGA相機(jī)邊緣檢測開源分享

FPGA相機(jī)邊緣檢測開源分享

2023-07-10 | zip | 0.03 MB | 次下載 | 免費

資料介紹

描述

該項目將展示如何實施完整的端到端圖像處理管道,以實施能夠以 30fps 的速度運行的邊緣檢測視覺算法,以檢測道路車道。

?
?
poYBAGOlJs2AGtfUAAlW6-j4RJ8752.jpg
?
1 / 3
?

一、簡介

要實現(xiàn)實時車道檢測,我們的想法是拍攝圖像并將其傳遞給邊緣檢測器 IP。最著名的一種是 Sobel 邊緣檢測器。然而,Canny 邊緣檢測器具有可編程閾值的優(yōu)勢。即時修改閾值可以適應(yīng)不同的光照條件。

https://en.wikipedia.org/wiki/Canny_edge_detector

視覺處理流水線在邏輯上可以分為三個部分。圖像源、圖像處理管道和圖像接收器

?

?
pYYBAGOlJtCAbjB9AAD4wV-AWo4500.png
?

?

從高層次的角度來看,需要一個圖像源(可以是相機(jī)傳感器或圖像模式生成器)和一個接收器(可以是顯示器)。

2.硬件塊

首先,必須將所有原型硬件部件放在一起。在這種情況下,系統(tǒng)硬件僅由五個組件組成。

a) MiniZed ZYNQ 開發(fā)板

b) OV7670 相機(jī)

c) Arduino 屏蔽穿孔板

d) 10pin 0.1inch 母頭

e) VGA PMOD

OV7670 相機(jī)安裝在一個 10 針 0.1 英寸母接頭上,該接頭本身焊接到原型板上。VGA PMOD 連接到 MiniZed 雙 PMOD 接頭連接器最后一步是將 VGA 電纜連接到顯示器。

?
poYBAGOlJwOADJ6lAA_Wa_4cbas252.jpg
?

一旦硬件系統(tǒng)組裝在一起,下一步就是使用 Vivado 在 FPGA (PL) 上設(shè)計硬件。

3.FPGA硬件

1. 圖片來源

有許多相機(jī)接口,但最簡單的是使用并行總線的 CMOS 傳感器,例如古老的 OV7670 相機(jī)傳感器。然而,要使用這樣的傳感器,必須實現(xiàn)一個相機(jī)捕獲模塊,該模塊將從傳感器傳輸?shù)淖止?jié)流轉(zhuǎn)換為適當(dāng)?shù)膮f(xié)議,在我們的例子中是 AXIS 總線。

此外,必須通過在 PL 中將配置模塊實現(xiàn)為從 BRAM 讀取配置的 I2C 模塊或在 PS 中將配置模塊實現(xiàn)為通用相機(jī)驅(qū)動程序來配置相機(jī)。PS 配置顯然更靈活,所以我選擇了這個選項。

?

?
pYYBAGOlJwWAV6N1AABtVQ3HR8I090.png
?

?

Vivado 設(shè)計中的圖像源是與 OV7690 CMOS 相機(jī)接口的定制 IP。相機(jī)使用并行八位接口此外,還有兩個同步信號HSYNC和VSYNC,其選通模式分別表示行和幀。相機(jī)使用輸出像素時鐘 PCLK。像素速率與 PCLK 同步。OV7690 相機(jī)還需要一個 24 MHz (XCLK) 相機(jī)時鐘作為輸入。

OV7690 每個像素輸出 2 個字節(jié)。根據(jù)配置代碼,相機(jī)可以配置為使用不同的色彩空間。IP 配置為使用 RGB565 色彩空間。相機(jī)的控制是通過 AXI 接口完成的。攝像機(jī) IP 在內(nèi)存中分配了一個位置。要啟動相機(jī),必須設(shè)置位以啟用相機(jī)輸出數(shù)據(jù)。數(shù)據(jù)本身使用 AXIS (AXI Stream) 協(xié)議打包。

2. 跨時鐘域

來自相機(jī)的 AXIS 輸出被發(fā)送到異步 FIFO。這是需要跨越兩個不同時鐘域時使用的一種方法。

?

FIFO 的從端連接到 PCLK,而 FIFO 的主端連接到工作頻率為 50MHz 的 AXI 主時鐘域。主時鐘必須始終高于從時鐘,否則 FIFO 將溢出導(dǎo)致丟失像素。

?
poYBAGOlJwiADZy8AABqNm4NDQw336.png
?

?

在像素流穿過時鐘域后,它通過子集轉(zhuǎn)換器發(fā)送。這是一個 AXIS IP 塊,可將 RGB565 數(shù)據(jù)重新映射為 24 位數(shù)據(jù)包。圖像處理 IP 使用 24 位,因為每種顏色都分配了 8 位。

下一個元素是 AXIS 開關(guān)。該 IP 作為 AXIS 流的簡單多路復(fù)用器運行。它可以通過 AXI lite 接口或利用 AXIS 頻閃信號自動配置。在此特定應(yīng)用中,啟用了 AXIS 開關(guān)的 AXI Lite 接口。然而,這需要實施 SDK 驅(qū)動程序來配置開關(guān)多路復(fù)用器。

3.圖像過濾

Canny 邊緣檢測器 IP 是使用 Vivado HLS 構(gòu)建的。它是用 C 語言編寫的。HLS 的主要優(yōu)點是允許快速部署 IP。缺點是生成的邏輯是模糊的,通常不如手工制作Verilog 代碼高效,盡管它可以接近它。在任何情況下,生成 Canny IP 都涉及使用 Vivado HLS 2013 和 2018.3 版本的 xfopencv。這是一組 C++ 庫,復(fù)制了用于 FPGA 邏輯的眾所周知的 OpenCV 庫。

Xilinx 最近發(fā)布了 Vivado 2019.1 以及 HLS 2019.1。這需要使用帶有非免費修訂框架的 SDSOC。

已實施的修訂代碼的主要更改是修改功能以支持 AXIS 協(xié)議的輸入和輸出。此外,AXI Lite 總線用于將所有可編程變量捆綁在一個集合中,并通過連接到 GP0 ZYNQ 總線的 AXI 互連將它們暴露給 PS 內(nèi)存映射。

?

?
pYYBAGOlJwyAL8qtAACR9fV-h2E900.png
?

?

最后,為了在兩個不同的 IP 之間切換,使用了 AXI 開關(guān)。

?

?
poYBAGOlJw-ABlnqAAEZq1YHXhE666.png
VDMA 配置為寫入模式。
?

?

VDMA 配置為三重緩沖模式。VDMA 需要在運行前通過 AXI lite 接口進(jìn)行配置,該接口將其連接到主 AXI 互連。

下面的代碼顯示了針對 VGA 分辨率的 VDMA 配置。

	Xil_DCacheFlush();    
	Xil_ICacheInvalidate();    
	/* Start of VDMA Configuration */    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0x30, 0x8B);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0xAC, 0x10000000);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0xB0, 0x100F0000);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0xB4, 0x101E0000);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0xA8, WIDTH*2);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0xA4, WIDTH*2);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0xA0, HEIGHT);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0x00, 0x8B);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0x5C, 0x10000000);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0x60, 0x100F0000);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0x64, 0x101E0000);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0x58, WIDTH*2);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0x54, WIDTH*2);    
   Xil_Out32(XPAR_VDMA_S2MM_BASEADDR + 0x50, HEIGHT);     

。。

VTC 本身配置為 VGA 分辨率。

?

?
poYBAGOlJxGAfEoiAAEA6uPNZ2Q084.png
?

?

這基本上是一個 R2RDAC,它采用數(shù)字?jǐn)?shù)據(jù)總線以及行和幀同步信號 HSYNCS 和 VSYNC,并將數(shù)據(jù)發(fā)送到監(jiān)視器。

正如您在下面看到的,應(yīng)用程序在正常 VGA 模式、灰色模式(看起來更像藍(lán)色)和邊緣檢測模式之間不斷切換。

?

?
?
?
?
pYYBAGOlJz6AVIIzAAo3uh_mjPk252.jpg
?
1 / 3
?

概括

該項目展示了如何在 ZYNQ FPGA SoC 上實現(xiàn)完整的端到端視覺處理流水線。硬件能夠以 30 fps 的速度進(jìn)行實時邊緣檢測。

其他想法包括:

  • 添加更多濾波器類型,如中值、高斯、索貝爾、普維特等。
  • 為 MiniZed 構(gòu)建一個 PYNQ 發(fā)行版以從 Linux 訪問 IP,以構(gòu)建一個無線 WiFi 攝像頭。
  • 升級到更高清晰度的相機(jī)傳感器。

?

?


下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1A7159和A7139射頻芯片的資料免費下載
  2. 0.20 MB   |  55次下載  |  5 積分
  3. 2PIC12F629/675 數(shù)據(jù)手冊免費下載
  4. 2.38 MB   |  36次下載  |  5 積分
  5. 3PIC16F716 數(shù)據(jù)手冊免費下載
  6. 2.35 MB   |  18次下載  |  5 積分
  7. 4dsPIC33EDV64MC205電機(jī)控制開發(fā)板用戶指南
  8. 5.78MB   |  8次下載  |  免費
  9. 5STC15系列常用寄存器匯總免費下載
  10. 1.60 MB   |  7次下載  |  5 積分
  11. 6模擬電路仿真實現(xiàn)
  12. 2.94MB   |  4次下載  |  免費
  13. 7PCB圖繪制實例操作
  14. 2.92MB   |  2次下載  |  免費
  15. 8零死角玩轉(zhuǎn)STM32F103—指南者
  16. 26.78 MB   |  1次下載  |  1 積分

本月

  1. 1ADI高性能電源管理解決方案
  2. 2.43 MB   |  452次下載  |  免費
  3. 2免費開源CC3D飛控資料(電路圖&PCB源文件、BOM、
  4. 5.67 MB   |  141次下載  |  1 積分
  5. 3基于STM32單片機(jī)智能手環(huán)心率計步器體溫顯示設(shè)計
  6. 0.10 MB   |  137次下載  |  免費
  7. 4A7159和A7139射頻芯片的資料免費下載
  8. 0.20 MB   |  55次下載  |  5 積分
  9. 5PIC12F629/675 數(shù)據(jù)手冊免費下載
  10. 2.38 MB   |  36次下載  |  5 積分
  11. 6如何正確測試電源的紋波
  12. 0.36 MB   |  19次下載  |  免費
  13. 7PIC16F716 數(shù)據(jù)手冊免費下載
  14. 2.35 MB   |  18次下載  |  5 積分
  15. 8Q/SQR E8-4-2024乘用車電子電器零部件及子系統(tǒng)EMC試驗方法及要求
  16. 1.97 MB   |  8次下載  |  10 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935121次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
  4. 1.48MB  |  420062次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233088次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191367次下載  |  10 積分
  9. 5十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
  10. 158M  |  183335次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81581次下載  |  10 積分
  13. 7Keil工具M(jìn)DK-Arm免費下載
  14. 0.02 MB  |  73810次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65988次下載  |  10 積分
爱玩棋牌官方下载| 百家乐官网庄闲当哪个好| 百家乐官网咋样赢钱| 真人游戏网站| 赌场百家乐官网代理| 联众百家乐的玩法技巧和规则 | 大发888官网z46| 百家乐官网视频麻将下载| 百家乐高手怎么下注| 波音百家乐官网网上娱乐| 金樽百家乐的玩法技巧和规则| 阜阳市| 澳门百家乐规例| 百家乐官网真钱在线| 百家乐网络真人斗地主| 百家乐官网投注翻倍方法| 赌场百家乐的玩法技巧和规则| 至尊百家乐官网下载| 迪威百家乐赌场娱乐网规则| 百家乐官网投注技巧球讯网| 百家乐QQ群娱乐| 百家乐官网透明牌靴| 大发888官方网站登录| 中原百家乐官网的玩法技巧和规则 | 大发百家乐游戏| 博彩乐透乐| 百家乐桌码合| 百家乐官网棋牌辅助| 百家乐揽法大全| 百家乐官网分析网| 大发888官网客服| 百家乐游戏百家乐| 博狗百家乐官网真实| 新东泰百家乐的玩法技巧和规则| 网上百家乐官网大转轮| 大发888娱乐场下载 zhidu| 百家乐接线玩法| 网上百家乐官网可靠| 捷豹百家乐娱乐城| 百家乐官网牌盒| 百家乐官网实时路单|