采用FPGA和CMOS数字传感器实现图像监测系统的设计

描述

   图像监测在许多领域有着广泛的应用,目前已经安装上的图像监测系统大约60%沿用早期的摄像头加电视和录像带,并采用有线模拟视频传输技术构成。这种方案存在图像质量低、录像带不易保管、资源容易删改、录像机磁鼓寿命短、需专人看管换带、数据的存储量大、查询取证检索和图像压缩后期处理困难等难点。另一方面,有线模拟视频监测存在无线联网、只能以点对点的方式监视现场、布线工程量极大、对距离十分敏感、不能为远程实时监测和中心联网监测提供可扩展性等技术性缺陷。本文提出一种采用FPGA和CMOS数字传感器实现前端数据采集、利用单片机进行图像鉴别和压缩、通过以太网控制器实现图像数据传输的图像监测系统。该系统不仅实现了图像信号数据采集,而且数据传输速度和稳定性高;不仅灵活性好、成本低,而且具有网络化、智能化等优点。
    1 系统组成和工作原理
    整个图象监测系统采用C/S架构,由本地服务器和多台智能图像采集前端组成分布式网络监测系统。本地服务器和图像采集前端在实现时使用的是自成局域网的方案,采用UDP传输协议和分时轮循管理模式。客户端采集数据,本地服务器处理数据和发送数据。本地服务器之间通过广域网连接,采用FTP传输协议。系统网络连接如图1所示。

FPGA   

 嵌入式CPU对采集来的数据进行识别处理,并将有效的图像数据通过以太网卡控制器发送到本地服务器,本地服务器进行图像处理或显示,并向各个终端发送控制信息。同时,本地服务器还决定是否处理过的数据发送到广域网上。
    2 图像采集传输系统
    图像采集传输系统前端采集图像信号,并将它转化为数字信号,由CPU将这些图像数据通过网络上传到服务器,以供服务器进行图像处理或显示等。同时,服务器也通过网络同图像采集前端发送控制信号、显示信息,向终端查询设备状态、设备信息以及发布网络的辅助协议数据包等。图像采集传输系统包括图像采集存储模块、输入输出模块、电源设计模块、通信模块、红外检测和有效图像识别模块以及其它的附属单元。

FPGA

    2.1 图像采集存储模块
    系统的图像传感器选择的是CMOS型高分辨率、高速率彩色图像传感器OV7620。如果用CPU直接从CMOS芯片中采集数据,CPU的速度跟不上,存在着高速外设与低速CPU之间不匹配的问题,因此用FPGA实现图像传感器和CPU之间的速度匹配,如图2所示。FPGA内部可以分为内存分配、产生SRAM的读写时序和地址、为网卡和CMOS提供主频、键盘扩展、产生LCD的控制时序等几部分以及其它附属模块。
    FPGA根据CPU的读写信号和CMOS的输出信号产生缓存的读写时序和地址信号。当一帧图像采集完成时,FPGA向CPU发出一个申请信号,表示缓存里面有一帧数据可以进行读取。如果CPU不应答,表示这帧数据可以丢弃。这时FPGA重新根据CMOS图像传感器的输出信号向缓存输送一帧数据,如此循环。如果CPU给出应答信号,FPGA停止向缓存输送数据,等待CPU发送读信号。当CPU发出读信号时,FPGA把CPU的读信号转化为内存的读信号。即FPGA首先根据CMOS的输出数据转化为内存的读信号。
    2.2 人机界面设计
    键盘采用4×4矩阵键盘,键的功能定义分为数字键和功能键,数字键为0~9,系统的功能键主要有CLR(清除键)、OK(确认键)、MENU(主菜单键)、上翻键、下翻键、查年系统IP地址键。液晶显示器选用信利公司的产品,其分辨率为128×32点阵。人机界面接口如图3所示。

FPGA

    图3人机界面接口
    2.3 红外检测和图像识别模块
    红外检测和有效图像识别模块的作用是减轻网络的负载,使在实际网络中传输的任何连续两帧图像数据不会重复。采用嵌入式CPU进行图像的模式识别,判断连续两帧图像是否有变化。其电路如图4所示。
    2.4 RS422通信模块
    为了使图像采集前端和其它设备能够进行网际互联,系统挂接了一套全双工总线式RS422串口通讯模式接口电路,满足了传输速率不太高、传输距离远的要求。在实际传输中系统选用的波特率为19200,多机通讯模式,一帧数据长度为11位。
    3 嵌入式系统
    以太网控制器DM9008F的数据总线是与系统CPU的数据总线直接相连的,通过红外检测的方式判断图像是否有效。为了提高图像数据的导入速度,系统使用的图像数据由高速缓存直接导入DM9008F的环行缓冲区。图像数据不经过CPU,CPU只产生UDP数据报的报文格式信息:报头、目的地址、本机地址等。这种模式的优点是节省了CPU的时间,同时使数据流向显得简单明了。如果通过算法判断图像是否有效,CPU必须实时计算当前帧的图像并判断其是否和前几帧图像的变化程度一致,这时CPU应产生UDP数据报的所有数据。这样虽然提高了判断图像是否有变化的准确率,但浪费了CPU的时间。采用FPGA来产生地址总线的低五位是为了选择网卡内部的工作寄存器。其框图如图5所示。
    4 系统软件设计
    系统软件包括单片机应用软件、服务器管理软件以及它们之间的通讯协议。单片机软件采用C51和汇编语言联合编写的方式,由主程序、键盘扫描程序、配置CMOS参数子程序、网卡读取数据模块、数据包处理模块、数据包发送模块等组成。单片机主程序流程图如图6所示。单片机的嵌入式软件主要包括网卡控制器TCP/IP软件的实现、键盘识别、液晶驱动的编写、对图像的读写和计算处理、配置CMOS参数、RS422串行通讯软件的编写以及与服务器之间协议的实现等部分。
    服务器软件主要读取图像数据和下发扫描指令及控制信息。为了调试方便,服务器管理软件采用Delphi编写。Delphi 4.0以上的版本都支持两种组件,即ClientSocket和ServerSocket,这是对Winsocket进行细分的结果。它们分别作为客户端和服务器端的组件。通过这两种组件之间的通信。再加上辅助的应用程序代码,就可以实现通信。
    智能化、网络化、数字化图像监测系统已经是国内外发展的趋势。实验证明:该系统不仅实现了图像数据等大容量信息的网络传统递。而且也完成了上位机对终端的控制、信息获取及图像采集前端对上位机的数据上传、信息回复等一套完整灵活的双向通讯协议的实现。在图像采集的设计中,利用FPGA技术较好地解决了高速外设与低速CPU之间不匹配的问题,使图像采集可以在8位嵌入式系统中实现。图像采集传输系统采用了一种高速数据传输方式——以太网,使系统的传输速率高且稳定可靠。红外检测和有效图像识别模式优先图像,减轻了网络传输的负荷,使整套系统传输效率更高。

FPGA





有你想看的精彩 




至芯科技-FPGA就业培训来袭!你的选择开启你的高薪之路!5月30号西安中心开课、欢迎咨询!
为FPGA设计添加复位功能的注意事项
芯片设计流程概述


FPGA




扫码加微信邀请您加入FPGA学习交流群



FPGA
FPGA


欢迎加入至芯科技FPGA微信学习交流群,这里有一群优秀的FPGA工程师、学生、老师、这里FPGA技术交流学习氛围浓厚、相互分享、相互帮助、叫上小伙伴一起加入吧!


点个在看你最好看





原文标题:采用FPGA和CMOS数字传感器实现图像监测系统的设计

文章出处:【微信公众号:FPGA设计论坛】欢迎添加关注!文章转载请注明出处。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分