基于FPGA和EPP的圖像傳感器高速數據采集系統
USB、串口、并口是PC機和外設進行通訊的常用接口,但對于數據量大的圖像來說,若利用串行RS-232協議進行數據采集,速度不能達到圖像數據采集所需的要求;而用USB進行數據采集,雖能滿足所需速度,但要求外設必須支持USB協議,而USB協議與常用工程軟件的接口還不普及,給使用帶來困難。有些用戶為了利用標準并行口(SPP)進行數據采集,但SPP協議的150kb/s傳輸率對于圖像數據采集,同樣顯得太低。因此,為了采集數據量大的圖像數據,本文采用了具有較高傳輸速率的增強型并行口協議(EPP)和FPGA,實現對OV7620CMOS圖像傳感器進行高速數據采集,它最高速率可以達到2Mb/s。
硬件電路方案
圖1為基于FPGA和EPP技術對OV7620CMOS圖像傳感器的高速數據采集系統原理框圖,它主要由三部分組成:OV7620的參數配置電路、圖像采樣電路以及PC讀取數據電路。
圖1 系統原理框圖
OV7620的參數配置電路
系統在上電后需要對CMOS采像芯片進行初始化,以確定采集圖像的開
窗位置、窗口大小和彩色或黑白工作模式等。這些參數的配置是通過OV7620芯片上提供的SCCB接口進行的。
SCCB接口是采用一種簡單、雙向二線制的同步串行總線I2C總線,接口引線有SCL和SDA。由于89C2051沒有標準的I2C總線接口,可以用軟件程序來模擬I2C總線,OV7620開窗位置和開窗大小、黑白和彩色模式以及掃描方式均可通過相應寄存器來設置。這些寄存器都是可讀/寫的,具體操作方法如下:可以采用頁寫的方式,即在寫寄存器過程中要先發送寫允許指令OX42,然后發送寫數據的目的寄存器地址,接著為要寫的數據。寫完一個寄存器后,CMOS會自動把寄存器地址加一,程序可繼續向下寫,而不需要再次輸入地址。讀寄存器是同樣過程,只不過指令改為OX43。
I2C總線功能的實現完全是依靠SCL、SDA線上電平的狀態以及兩者之間的相互配合實現的。I2C總線規約中規定的條件如下:
啟動時序:SCL為高電平時, SDA出現一個下降沿;
傳輸時序:在啟動條件滿足后,SDA為穩定數據狀態, SCL產生一個正脈沖,將傳送一位數據;
應答時序: 在從機接收到一個完整的數據字節時,在主機釋放SDA的情況下,主機給SCL輸出一個正的時鐘脈沖,從機將SDA拉低,以表應答;
停止條件:當SCL為高電平時,SDA出現一個上升沿,該條件可以解決多機競爭的問題,即在兩個器件對話時,第三者插入會終止前者的數據通信,其主要特點在于各器件每一位都在判斷總線的狀態。
I2C總線的啟動和停止條件如圖2所示。
圖2 I2C總線的啟動和停止條件
圖像采樣電路
在隧道的平行度、無損檢測、垂直度測量儀中常選用的圖像分辨率為320
評論