《以FPGA为核心的机器视觉系统设计方案详解.docx》由会员分享,可在线阅读,更多相关《以FPGA为核心的机器视觉系统设计方案详解.docx(5页珍藏版)》请在第一文库网上搜索。
1、以FPGA为核心的机器视觉系统设计方案详解机迷视觉就是用机器代替人眼来做测量和判断。机器视觉作为人类视觉与大脑的延伸,是衡量现代工业自动化程度的标志之一。近年来,随着计算机技术尤其是多媒体技术和数字图像处理及分析理论的成熟,以及大规模集成电路的迅速发展,机器视觉技术得到了广泛的应用研究,取得了巨大的经济与社会效益。机器视觉系统主要由3部分组成:图像的获取、图像的处理和分析、输出或显示。本文介绍了基于咏的一种机器视觉系统,该系统采用GigeVision摄像机来获取图像,在FPGA中采用了GigeVisionIP核,根据TCP/IP传送协议实现了FPGA与PC机的数据通讯。1 FPGA实现机器视觉
2、的优势随着机器视觉系统应用中分辨率的提高和压缩篁法的进步,对系统性能和构架灵活性提出了更高的要求,以实现系统的快速更新。可选择的系统构架包括标准单元ASIC,ASSP以及各种可编程解决方案,如数字信号处理器(DSP)或媒体处理器和FPGA。每种构架都具有各自的优缺点,最终选择取决于终端设备要求和解决方案的可用性。理想构架应具有以下特点:高性能、灵活性、易升级性、低开发成本以及具有随着应用成熟和产量增加向更低成本迁移的能力。FPGA具有并行运算、反复使用、大量可使用的软核的优势,是实现机器视觉理想构架的合理选择。FPGA是小批量系统提高集成度、可靠性的最佳选择之一。随着V1S1工艺的不断提高,单
3、一的1内部已可以容纳上百万个晶佳萱,这使得FPGA芯片所能实现的功能也越来越强,同时也可以实现系统集成。FPGA有大量软核,可以方便进行二次开发。FPGA甚至包含地左机和DSP软核,并且IO数仅受FPGA自身IO限制,所以,FPGA又是单片机和DSP的超集。也就是说,单片机和DSP能实现的功能,FPGA一般都能实现。在SOC设计中,基于FPGA器件设计工艺的发展使得越来越多的功能集成到一个芯片成为可能。为实现这一目标,有一种非常实用的SOC设计方法,称为基于核的设计,它将系统的功能划分为不同的核。采用IP(Inte11ectua1Property)核来完成特定的设计功能。本文就是采用了Gige
4、ViSiOn的IP核来完成主要部分设计的。2机器视觉系统设计2 .1设计原理系统原理框图如图1所示。图1系统或件体系结构心)这个解决方案基于Xi1inX低功耗低成本的SPartan3EFPGA芯片上实现,它提供了整合Camera1ink,GigeVisionIP,千兆以太网MAC的平台和可选的Visua1App1ets软件。2. 2视频输入模块在ITS及安防行业,现在主要使用的是模拟摄像机,也有部分厂家推出了网络摄像机(PCamera)。GigeViSiOn摄像机与他们之间的对比如表1所示。寰I各类摄像机对比揽像机S梨GigEVRion摄像机慢N摄像吴同络摄像机成像元件逐行打精CCD0村格Ce
5、1)1:雷留有效像素640X480!392X1040.2048X2048720X576640X480记强娥Jb格式8b10bM-fUr模内81It字险出O1乐瑞/MD1OOOBSETBNC!OBSKT100BSKTX出忸冬(fs)-*1:30ft*s2002525-3O效樨区城尤成城无瓜馆MPE(;JPEG送优就J1可以不可以可以部分心把鸵出可以不可以不可以SDK有心/)J)牛制升宸雄度成从以上的对比表可以看出,GigeViSiOn摄像机的主要优点是:(1)逐行扫描;(2)高清晰,缓高分辨率达到4百万像素;(3)帧率高:最高帧率达到200f/s;(4)数据未经压缩,无损失;(5)可以根据需要输
6、出部分扫描数据;(6)可以通过软件自动改变摄像机参数,适应变化的现场环境;(7)后期应用开发方便。基于GigeViSion摄像机的优点,本系统采用GigeViSiOn摄像机。2.3FPGA中使用的模块FPGA中使用Camera1ink来进行与相机的互连。Camera1ink是一个应用于高端机器视觉的强大的数据通道。它使用一个专门的电缆连接和标准化的通信协议。Camera1ink支持大量的数据和高数据传输率,适合今天的图像数据传输的要求。在系统中Xi1inxFPGA中使用的GigeVision是一种由AIA(AutomatedImagingAsSoCiation)开发的相机接口标准。这是一项开放
7、性的标准,它能让来自不同厂家的摄像机与应用软件通过吉比特以太网实现相互间的无间合作。GigeViSiOn使用了一个标准的千兆以太网连接同其高带宽(1Gb/s)实现了未经压缩图像和数据的实时传输。使用GigeVisionIP是实现高性能机器视觉应用的理想解决方案。一个吉比特以太网相机使用Camera1ink与GigeVision相连。GigeVision是一种实现单/多相机与单/多计算机相连接进行数据集中和分布式处理的理想标准。使用标准千兆以太网允许使用标准电缆和连接矍,从而降低材料费和整合成本以及后续增长以太网带宽的可扩展性。本方案中使用的GigeVisionIP核是根据的GigeViSion
8、规范10版的GigeViSiOn数据流协议的硬件实现。它是由XiIinX的合作伙伴FeithSensor-to-ImageoGmhH发开的。因为通过硬件来实现数据流通道可以达到千兆以太网的最大吞吐量。IP核的结构如图2所示。GigEVisioncoredeodataMHi1CCsdran图2GigeVisionIP桢州朽GigeViSion的核心由内存控制器、吉比特以太网MAC、控制微处理器和一个视频处理单元组成。GigeViSion核提供了吉比特以太网MAC接入系统的其余部分,处理GigeViSiOn数据流通道,对GigeViSiOn通道再发送申请包进行解码,并提供一个嵌入式CPU的网络接口
9、。CPU处理了除GigeViSiOn数据流控制以外的所有网络协议。内存控制器作为特殊的视频帧缓冲区,它不是缓冲输入的视频帧,而是把它们分成可供网络传输和实现GigeVision数据流协议的部分处理包重发送功能的较小区域。FPGA中与计算机相连的部分使用的是Finger1akesEngineering为Xi1inx开发的PhantomTriModeMACIP核。它与GigeVisionIP核集成在一起,充分应用1Gb/XRx/Tx速率,支持IPv4,IPv6,JumboPacket和MDIO0Phantom核具有独特的重新计时路径,从而能降低时钟缓冲器计数值同时简化核的集成度,对于低成本的Spa
10、rtan器件和高性能的Virtex构架都是理想的选择。2.4主机接口设计本方案中使用吉比特以太网与计算机连接,计算机上需安装Visua1App1ets软件。Visua1APPIetS是由Si1iConSOftWare开发的一款软件,可完全兼容XiIinX的FPGA。Visua1APP1etS完成了一个极其强大、灵活、快速和优化的GigeViSiOr1开发平台,它使不熟悉FPGA的机器视觉专家也能简单地操作这个系统。Si1iconSOftware开发的ViSUaIAPPIetS为最先进的FPGA设计工具,经由易学易用的图形接口,可以开发出图像处理专用的FPGAconfiguration,即所谓的
11、app1eto借由Visua1App1ets可以:(1)使影像卡变成一个高效能的影像处理器;(2)现代FPGA的潜能可由任何使用者自行发挥;(3)影像处理的解决方案可在数分钟内完成;(4)达成硬件阶层的快速开发。使用Visua1App1ets,不必拥有较深的硬件知识,如数字电路、时间分析、FPGA硬件设计语言。使用ViSUa1APPIetS只要将各个处理模块之间作链接,各种链接的兼容性可实时显示,各模块间能以不同的位相关系作链接,同时也能评估系统需求资源与数据带宽分析,甚至于分析每个模块连接点之间的流量,快速找到设计瓶颈。设计完成后,产生编译档只要几分钟的时间,期间不需要任何人工动作,App1et可立即在microDisp1ay中使用并进行参数设定,同时也会自动产生一个ViSUa1C+SDKproject03结语本文根据以FPGA芯片为核心设计了一种通用的机器视觉系统,可以应用到产品生产线、车辆皆能监控管理等各种场合。采用磁的高性能视觉标准和国际知名大公司开发的IP核以及主机ViSUa1APPIetS软件的使用极大地提升了系统的性能、可靠性。