如何通过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×320,用黑白模式就能基本满足图像识别对图像特征点的要求。 因此本系统采样的参数是在图像分辨率取为320×320、黑白模式、zv图像格式中进行的。
cmos图像芯片zv端口格式的输出波形如图3所示。图中vsync是垂直场同步信号,其下降沿表示一帧图像的开始(cmos是按列采集图像的),href是水平场同步信号,其上升沿表示一列图像数据的开始。pclk是输出数据同步信号,y是图像灰度信息。下面介绍fpga如何对图像传感器的数据采样。
图3 ov7620在zv端口格式的输出时序
为了进行速度匹配,fpga和pc之间有两根握手信号: ready和ack。它们来协调fpga对同一个数据存储芯片的读写过程。ready是fpga通知pc图像数据已经读完信号;ack是pc通知fpga数据已读完信号,两者都是低电平有效。
在数据采样期间,将ready拉高,表示正在采集,这时fpga根据ov7620的vsync、href、pclk产生图像mem_wr(写信号)和address(地址),读取ov7620的数据到高速缓存,到下一个vsync信号时,表示一帧数据已经采完,接着向pc机发送申请ready信号,表示图像采集完成,如果pc不给应答信号ack,fpga开始采样下一帧数据放到高速缓存中,并覆盖原有的数据;若pc响应,fpga停止采样数据。
pc读取数据电路
pc读取数据是通过并口的epp模式进行的。在epp模式下读时序如图4所示。 在读模式下,nwrite(epp写信号)保持高电平, 当ndatastb(epp读信号)变低时,准备读取外设数据;当外设数据准备好后,使nwait(外设忙标志)为高,这时pc程序向基址+4的端口(epp数据端口)执行一个i/o读操作(ndatastb信号);在读脉冲ndatastb信号的上升沿,pc读取数据总线上数据。整个过程是在一个isa周期内完成的。
图4 epp模式下读时序
fpga完成对epp协议实现的时序如图5。pc不停查询ready信号是否有效,直到ready有效时,pc才可以读取图像数据,同时将ack置高,表示pc正在读取数据缓存中的图像数据。这时fpga停止采集图像(不产生写信号),fpga检测pc通过epp发出读脉冲(cpu_ds),产生高速缓存mem_rd(读信号)和地址,从高速缓存中读取一个字节放到并口上,同时向pc上发送一个busy信号,pc在这个时刻之后可以读取一个字节数据,完成整个数据读写。读取数据过程中epp端口的pc_write(写信号)要一直保持为高电平。
图5 fpga对epp协议的实现时序
结语
fpga对cmos高速数据采集方法,可以把cmos的主动器件通过fpga变成可控制的方式,pc可间接对存储体进行寻址运算。在该系统中用pc的并口实现了cmos信号的高速采集处理,按前述软硬件方法制作的系统,实际稳定的采样速率达到了15帧/s, 该系统已应用在管道无损检测样机中,效果良好。这种信号采集方法还可以在其它诸多需要高速图像数据采集的场合应用。

IPTV视频编解码标准的对比与选择
基于SEPIC变换器的开关电源电路设计
集成电路行业目前的投资热,到底来自哪?
机器人等级考试有什么用?这几件事情你必须知道!
汽车内串行通信总线
如何通过FPGA和EPP技术对图像传感器进行数据采集
液晶拼接屏到底好在哪
如何通过快速纳米传感器技术诊断防治传染病
《森林生态系统服务功能评估规范》国家标准解读发布
第一代5G设计手机中调制解调器与射频集成的关键与亮点
钟鼎式分样器由哪些部分组成
电子芯闻早报:骁龙820内置硬件智能保护功能
爱立信:2030年全球5G消费市场价值有望达到31万亿美元
主流电视都有哪些热门技术
燃气灶电磁阀的两个作用
目前有哪些连接器技术在推动着医疗连接器市场
2020年投产的安培架构GPU上,英伟达将改用三星的7nm EUV工艺进行生产
低压变频器多少伏 低压变频器的工作原理
带你深入浅出了解C++中数据库
受蛲虫大脑启发构建AI系统,利用神经元控制车辆