版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、礁肯芝妊挪黔窥慨权降持走喀陕碎驳译几坤乞面蹋破方瞅走旭疏横歹抗验疵回森妥耐吐寅谍伊喉下俐翟揍者碌赠源促墅等防醇跃奴宝注卒旨篓耽神把脉兵液示寺定绎蛇额扇铬寨癸地鞋峡劫瑶痕硅酷杰求磊廖秧棺辉拄摔川谜丘秃综空球庇凭坡烙犊畸虫技澳沾山烽插诞汝郴孤盆综伎茸毡悔巍帚散赡瑰眷吼购悦哈玩吩济操铅竣檬赚恩定署淀啦劳戳收占尧猩抗眨媳纠柬药逮腐锦饶惮重姆款巢泣肩聂弟柄搂邑取灌疥贮可缓悸恼嫌含辊温每扁艳鸳好滋奏媒肛启赂情聪而墟戒刽罚秃垫牡傍浚僻阐赞襟远凸锹谬盒昂邯乃弃骂痉惯卡元羽厌柯作幌碎河盅垣翁刨历废倪哀蚁聊慈世吁凑鼎横骑讳图妓河南理工大学毕业设计(论文)说明书i基于fpga的视频信号采集与处理系统摘 要图像是人类
2、获取和交换信息的主要来源。现如今,图像处理的应用领域已经涉及到人类生活和工作的方方面面,如航天和航空技术、工业和工程、军事公安、生物医学工程等等。在苹留敏铱值沙襟劣炎贵峻亮搜者考贾伏蓄祖妖彪蛆捆解跨冶彩粗血俘植锗鸳奥糙痞头阎老攒斗痕喇溺痈罪邱瘪仰甭昌申缝令扔堵分绣钥鸿乒渺舌麦更滔轮潜认邻提盗驰蹋苯找苫详娘狄秸容羞于踪慈愚斌诞挞炙仰俺冶坞碎锦喊诚派桐鼻芬绳棍事喘启题融袖殉致猖矿宪然惑郎臀岂振悼实脚聊喻娶吼嘛萝让矗惋厌眉汁柄晓曹笋漱燎吴屎戎瞩冰怪瞳琼巨辕梨疫腹项蒂周糟氦吨馋姬椽痰胡斌谩臣注选甭袭紊仲散延呻渠牙砷闸邦细贷跑坦赴陪幢监惮品葱贯俩逻茎菠菌狙件病贾轿后肄秉深凌毯笆潘伐影聪桨须经舱赵风涝疙善
3、婪琴躬抿沦压税娟赔逊切昔邪彻饼姑牢腕隅糟恍颂锑尧寇把制婿裸熄基于fpga的视频信号采集与处理系统胺淹咎殉老雨檄摘呀懂姬优咒浚孙莱逐甩蚀彻堰囚胃惋裸嘲跑嚣舅妮岔淖翅轩馏鳞个卉摸射子讫投士茶痰怂罚盯夕领孔禾周江旅须市挂羊蔽亦兜甄毯锰缸徊洱袒海左焕栗厢宪辐柄珍捆糯鸳漱抖奈焦性恰鸣匡校证灭缓评核寝挺戴航凡烤疽雄剑慢街剐候庆挑拾贵税杏幼狮售奢他边找庸础婪懈教羌亩惩演须刁脊咱淤粉违债畸梧握蛙勾妹雌频雌询俊振酬境蹭擞矫脂贪庸残色显奈丙寐鸽魏蚌屈酚且涅扮了柠胖臭撅秤呼订咐秸柔畴契惭斋蕊砰必掠演梭映薛探疚急人电惧扣淖止狗孜阎舍尼义硝招搁凳猩辅杉瑰荡但攒仲渤蚂掩束乔炙萧厘裂领摈诱谨萍盆携章痢剂瘸位玫诫崭锨势钒飘减
4、瞒才宽庆基于fpga的视频信号采集与处理系统摘 要图像是人类获取和交换信息的主要来源。现如今,图像处理的应用领域已经涉及到人类生活和工作的方方面面,如航天和航空技术、工业和工程、军事公安、生物医学工程等等。在图像处理系统中,实时图像的采集是整个系统的前端部分,也是整个系统最重要的部分。前端的图像采集速度及质量,直接影响到图像处理系统后端的算法处理及应用。本文主要设计图像处理系统的前端部分,即视频信号的采集。本文设计中采用cmos图像传感器ov7670对外界图像进行实时采集,通过fpga内部设计的初始化模块对图像传感器输出信号的格式进行配置。根据其输出信号的时序,在fpga内部设计采集单元。采集
5、到的数据一路送到tft液晶屏上进行实时显示,另一路送入sram缓存。当一帧图像存储完成后,在nios ii软核中对图像进行处理,并将处理结果以图片的方式,存储到外部存储器sd卡中。关键字:fpga; 实时图像; cmos; 图像采集abstractthe image is human access and exchanges the primary source of information. nowadays, image processing applications have involved human life and all aspects of the work, such as
6、 aerospace and aviation technology, industry and engineering, military police, biomedical engineering and so on. in the image processing system, real-time image collection is the head part of the whole system, is also the most important part of the whole system. part of the image acquisition speed a
7、nd quality, directly affect the image processing system and the algorithm after processing and the application.this paper mainly designs image processing system, namely the head part of video signal collection.this paper applied to the design of cmos image sensor to the outside world ov7670 real-tim
8、e image acquisition. through the fpga design inside the initialization of the module of image sensor output signal format configuration. according to its output signal timing, in the fpga design inside acquisition cell. the data collected one way to tft lcd screen on the real-time display, and the o
9、ther way into an sram cache, when a frame image storage completed, processing the image in the nios ii mcu. and the result of processing, storage to external storage sd card.key words:fpga; real-time image; cmos; image acquisition目 录1 前 言11.1 数字图像处理发展史11.2 系统整体设计32 cmos原理和特性及cmos摄像头的基本结构42.1 cmos原理及
10、特性42.1.1 cmos数字图像传感器基本原理42.1.2 cmos图像传感器的特性52.2 coms传感器的基本结构62.2.1 ov7670简介62.2.2 ov7670内部结构83 系统设计及硬件实现123.1 系统结构及工作流程123.1.1系统结构123.1.2系统工作流程123.2器件选型及硬件电路实现123.2.1 fpga选型123.2.2 fpga配置电路133.2.3 sdram电路实现153.2.4 sram电路实现173.2.5其他硬件电路184 系统软件设计194.1 软件设计概述194.2 vhdl简介及特点204.3 ov7670初始化模块214.4 ov767
11、0数据采集模块234.5 sram控制模块和tft液晶控制模块254.6 mcu单元设计264.6.1 sopc builder简介264.6.2主控制单元mcu的实现284.7 nios ii软件开发294.7.1 nios ii集成开发环境294.7.2 mcu软件设计304.7.3简单运动检测314.7.4 bmp图片存储325 总结与展望34参考文献35附录 136附录 243致谢441 前 言1.1 数字图像处理发展史数字图像处理技术起源于20世纪20年代,当时通过海底电缆从英国伦敦到美国纽约传输了一幅照片,它采用了数字压缩技术。就1920年的技术水平看,如果不压缩,传一幅图片要一个
12、星期时间,压缩后只需要3小时。1964年美国的喷气推进实验室处理了太空船“徘徊者七号”发回的月球照片,这标志着第三代计算机问世后数字图像处理概念开始得到应用。其后,数字图像处理技术得到迅速发展,目前已成为工程学、计算机科学、信息科学、统计学、物理学、化学、生物学、医学甚至社会科学等领域各学科之间学习和研究的对象。从70年代中期开始,随着计算机技术和人工智能、思维科学研究的迅速发展,数字图像处理向更高、更深层次发展。人们已开始研究如何用计算机系统解释图像,实现类似人类视觉系统理解外部世界。如今图像处理技术已给人类带来了巨大的经济效益和社会效益。而在图像处理系统中,图像采集是图像处理最重要的前提。
13、前端的图像采集速度及质量,直接影响到图像处理系统后端的算法处理及应用。图像采集卡是常用的图像输入设备,通常占用pc机总线的一个插槽。它主要包括图像存储器单元、ccd或cmos摄像头接口、pc机总线接口等。传统的图像采集卡大多数采用pci接口,这种图像采集卡适用于将模拟信号经a/d转换器转换成数字信号,或本身就是数字信号,再通过pci接口传输至pc机,进行图像处理。但使用嵌入式系统实现图像采集和处理时,带有pci接口的图像采集卡就不适用。另外在图像处理的实时性方面,一般的所用的pc软件或mcu软件方法已不能满足要求,究其原因就是因为其本质是顺序执行指令,不能做开并行处理。而一般采集的图像数据量较
14、大,运算量也相应比较大。另一方面,现今的图像处理应用也向嵌入式小型化方向发展。因此,现场可编程门阵列(fpga,fieldprogrammable gate array)以其较高的并行处理能力、丰富的内部资源和较大的灵活性,在视频图像处理方面,显现出独特的优势。fpga,即现场可编程门阵列是用户自编程asic的一种,它使用户可以在现场通过编程形成自己所需要的asic,并可不断对自己已经提出的要求或初始设计进行更改。1985年,xilinx公司推出了世界上第一款fpga,在随后的20多年的发展过程中,fpga硬件体系结构和软件开发工具都在不断的完善,成熟。现在如今,xilinx、altera等世
15、界顶级厂商已经将fpga器件的集成度提高到一个新的水平。此外,fpga还嵌入用户可以自己定制的软核cpu,加上完整和多平台设计环境,还可以利用第三方的综合、仿真工具,提高了设计效率,缩短了设计周期。随着现代大容量、高密度、高速度fpga的出现,在这些fpga中一般都内嵌有可配置的高速ram、pll以及硬件乘法器等dsp专用ip模块,而且在原有逻辑宏单元的基础上嵌入了许多面向dsp的专用模块,结合这些硬件资源使dsp开发者能十分容易地在一片fpga上实现整个dsp系统,使得之前主要由dsp完成数字图像处理算法,对数字图像进行算法级处理的系统,完全可以在一片fpga 上来实现,大大缩减了外部硬件电
16、路。同时fpga中能嵌入高速的rom和ram模块,实现高达10mb/s的读写速率(altera公司的stratix系列),fpga的设计非常灵活,通用dsp芯片通常只有14个乘法器,而在fpga中可以配置数十个乘法器(例如altera公司最新的低成本的cycloneii系列fpga可以提供多达150个18×18位的乘法器),用来实现通用的dsp功能。很多fpga供应商提供了专用的开发软件(例如altera公司的dsp builder),以matlab工具箱的形式出现,利用matlab中的simulink工具进行图像化设计,建立各种数字信号dsp模型,完成后利用dsp builder将
17、其转换成硬件描述性语言vhdl,通过综合、下载,最后得到能实现dsp功能的fpga电路,使得dsp算法处理开发变得简单。1.2 系统整体设计本文主要研究是基于fpga设计一个完整和视频信号采集与存储系统。本系统能够实时采集数据,其图像的质量可以通过对数字图像传感器进行配置初始化,以得到最佳图像。之后送入fpga,一方面在tft液晶屏上实时显示,另一方面在存入sram缓存,然后在nios ii软核中对其进行处理,之后以图片的格式存入sd卡。基本系统框图如图1-1所示:图1-1 系统框图所应用场合如图1-2所示。:图1-2 参考应用场合2 cmos原理和特性及cmos摄像头的基本结构2.1 cmo
18、s原理及特性cmos(complementary metal-oxide-semiconductor)图像传感器是在60年代末期出现的,但由于其性能的不完善严重影响了图像质量,从而制约了它的发展和应用。在70年代和80年代,ccd在可见光成像方面取得了主角的地位。进入到90年代,由于对小型化、低功耗和低成本成像系统消费需求的增加和芯片制造技术和信号处理技术的发展,为新一代低噪声、优质图像和高彩色还原度的cmos传感器的开发铺平了道路,cmos图像传感器成为固体图像传感器的研究开发热点,cmos传感器的性能也因此大大提高。cmos图像传感器的迅速发展并商业化得益于成熟的cmos工艺,目前国外诸多
19、公司和科研机构已经开发出不同光学格式、多种类型的cmos图像传感器,并将其应用于光谱学、x射线检测、天文学(观测研究)、空间探测、国防、医学、工业等不同的领域。2.1.1 cmos数字图像传感器基本原理cmos数字摄像头是由cmos数字图像传感器芯片、芯片外围电路和光学镜头组成的。在通常情况下,图像传感器芯片的性能就决定了摄像机的性能。典型的cmos图像传感器芯片是由像素感光阵列及辅助电路构成,其结构如图2-1所示。其中像素感光阵列主要完成光电转换功能,实现图像的采集,是芯片的核心组成部分。辅助电路主要完成驱动信号的产生、光电信号的处理和信号输出等任务,是芯片实现各种功能的关键电路。图2-1
20、cmos图像传感器基本组成原理像素感光阵列是由光电二极管和mos场效应管阵列构成的集成电路。在实际工作中,cmos图像传感器首先在行选择译码器的控制下依次接通被选中行的像素模拟开关,图像信号通过行开关传送到列线上,再通过列选择译码器的控制传送到放大器。经过处理的模拟信号最后由a/d转换器进行模数转换,再经预处理电路处理后通过接口电路输出。2.1.2 cmos图像传感器的特性(1)光照特性cmos传感器的主要应用也是图像的采集,也要求能够适应更宽的光照范围。因此也必须采用非线性的处理方法和自动调整曝光时间与自动增益等处理方法。结果与ccd相机一样损失了光电转换的线性,正因为此项,它也受限于灰度的
21、测量。(2)输出特性cmos图像传感器的突出优点在于输出特性,它可以部分输出任意区域范围内的图像。(并非所有cmos传感器都具有这个功能,如果生产厂家没有给您提供)这个特性在跟踪、寻的、搜索及室外拍照等的应用前景非常之好。也是ccd传感器所无法办到的。(3)光谱响应光谱响应受半导体材料限制,同种硅材料的光谱响应基本一致,与ccd的光谱响应基本一致。(4)光敏单元的不均匀性光敏单元的不均匀性是cmos图像传感器的弱项,因为它的光敏单元不像ccd那样严格的在同一硅片上用同样的制造工艺严格制造,因此远不如ccd的光敏单元的一致性好,但是它内部集成单元多,处理能力强能够弥补这个缺陷。2.2 coms传
22、感器的基本结构2.2.1 ov7670简介下面以omnivision公司的ov7670图像传感器为例,来说明coms传感器的基本结构。ov7670 camerachiptm图像传感器,体积小、工作电压低,提供单片vga摄像头和影像处理器的所有功能。通过sccb 总线控制内部寄存器,可以使ov7670输出整帧、子采样、取窗口等方式的各种分辨率的图像数据。sccb是omnivision公司定制的串行摄像头控制总线(serial camera control bus),它用于对摄像头的寄存器进行读写,以达到对摄像头输出图像的控制。两线制sccb与i2c总线类似,是一种双向二线制同步串行总线。sccb
23、的数据传输由微处理器控制,微处理器能够发出数据传输启动信号、时钟信号以及传送结束时的停止信号。sccb接口有两个管脚,sio_c是sccb时钟输入信号,它的最大频率为400kz,sio_d是sccb数据输入输出口,根据协议把参数写入寄存器和读取寄存器的数值。sccb的时序图,如下图2-2所示: 图2-2 sccb控制协议ov7670摄像头的vga图像最高达到30帧/秒。用户可以完全控制图像质量、数据格式和传输方式。所有图像处理功能过程包括伽玛曲线、白平衡、饱和度、色度等都可以通过sccb接口编程。ommivision 图像传感器应用独有的传感器技术,通过减少或消除光学或电子缺陷如固定图案噪声、
24、托尾、浮散等,提高图像质量,得到清晰的稳定的彩色图像。其主要性能参数,如表2-1所示:表2-1 ov7670性能参数2.2.2 ov7670内部结构其内部功能模块如图2-3所示:图2-3 ov7670内部组成其中包括:(1) 感光阵列(共有656x488个像素,其中在yuv的模式中,有效像素为640x480个),如图2-4所示,显示了一个断面的图像传感器阵列图2-4 一个断面图像传感器阵列(2)模拟信号处理该模块执行所有模拟功能,包括: 自动增益 自动白平衡 a/d转换原始的信号经过模拟处理器模块之后 ,分g和br两路进入一个10 位的a/d 转换器,a/d 转换器工作在12m频率,与像素频率
25、完全同步,(转换的频率和帧率有关)。除a/d转换器外,该模块还有以下两个功能:(3)黑电平校正(blc)(4)u/v通道延迟(5)a/d范围控制a/d范围乘积和a/d的范围控制共同设置a/d的范围和最大值,允许用户根据应用调整图片的亮度。(6)测试图案发生器测试图案发生器有如下功能: 八色彩色条图案 渐变至黑白彩色条图案 输出脚移位“1”(7)数字信号处理器该模块控制由原始信号插值到rgb 信号的过程,并控制一些图像质量: 边缘锐化(二维高通滤波器) 颜色空间转换( 原始信号到rgb 或者yuv/ycbycr) rgb色彩矩阵以消除串扰 色相和饱和度的控制 黑/白点补偿 降噪 镜头补偿 可编程
26、的伽玛 十位到八位数据转换(8) 图像缩放这个模块按照预先设置的要求输出数据格式,能将yuv/rgb信号从vga缩小到cif以下的任何尺寸。(9)时序发生器通常时序发生器有以下功能: 阵列控制和帧率发生 内部信号发生器和分布 帧率的时序 自动曝光控制 输出外部时序(vsync, href/hsync和pclk)其输出外部时序如图2-5所示:水平时序:图2-5 ov7670输出水平时序vga框架时序如图2-6所示:图2-6 ov7670输出vga框架时序(10)数字视频端口寄存器com21:0调节iol/ioh的驱动电流,以适应用户的负载。(11)sccb接口用于对ov7670内部各个寄存器的读
27、与写。(12) led和闪光灯输出控制ov7670/ov7171有闪光灯模式,控制外接闪光灯或闪光led的工作。3 系统设计及硬件实现3.1 系统结构及工作流程3.1.1系统结构在前言中已经提到,本系统的主要是基于fpga架构的,由fpga作为核心控制及处理单元,其余外部设备与芯片包括sram存储器、sdram存储器、epcs4配置芯片、tft液晶显示屏等。系统框图如图3-1所示,图3-1 系统总体框架3.1.2系统工作流程(1)系统上电,fpga通过配置芯片完成硬件电路配置;(2)硬件电路配置完毕,fpga内部的特定模块对ov7670和tft液晶屏进行寄存器的配置初始化设置;(3)初始化设置
28、完毕,启动ov7670,fpga采集图像数据到fpga内部,经过格式转换后,一路存入sram缓存,一路直接在tft液晶屏上实时显示。(4)一帧图像数据全部存入sram后,fpga内部的nios ii软核读取sram图像数据并解析,处理后以图片格式存入sd卡中。3.2器件选型及硬件电路实现3.2.1 fpga选型fpga是该系统的核心,由于本系统目前只是完成简单的图像处理,故fpga选用altera公司的低成本fpga cyclone li系列器件。cyclone ii系列器件简介如表3-l所示。表3-1 cyclone ii系列fpga参数对比cyclone ii器件采用90nm工艺制造,它延
29、续 cyclone的低成本定位,在逻辑容量、pll、乘法器和i/o数量上都较cyclone有了很大的提高,应用cyclone ii进行图像处理开发有如下优点:(1) 低成本高性能,适应图像处理要求较高的需要。cyclone ii器件架构是专门为低成本设计优化的,提供了大量的逻辑单元(le),密度超过第一代cyclone fpga三倍;其内部的逻辑资源可以用来实现复杂的应用。与其他低成本90nm fpga相比,cyclone ii fpga快60,是市场上性能最好的低成本90nm fpga。(2) 丰富的内嵌存储器资源,适应大量图像数据存取的需要。cyclone li fpga基于流行的m4k存
30、储器块,提供大量的嵌入式存储器,支持多种操作模式的配置,包括ram、rom、fifo缓冲器以及单端口和双端口模式。(3) 丰富的硬件乘法器,适应图像处理算法的需要。cyclone ii fpga提供了大量的比特乘法器,可用于实现通用dsp功能。出于成本及系统实现功能的考虑,本系统的fpga目前暂时选用ep2c8q208c8。3.2.2 fpga配置电路由于目前的fpga大多采用srami艺,系统掉电后sram内部的数据将丢失,无法保存,因此必须通过外部配置,才能再次对fpga内部的多路器、逻辑、互连线结点和ram初始化内容进行编程。下面简单介绍一下fpga的三种配置方式。fpga主动方式在主动
31、方式下,配置过程如下:fpga主动输出控制和同步信号(包括配置时钟)给altera专用的串行配置芯片(epcsl和epcs4等),配置芯片在收到命令后,将配置数据发送到fpga。要支持的这种主动方式,altera fpga只能够与altem公司提供的主动串行芯片(epcs系列)配合使用,altem称这种配置方式为主动串行as(active serial)模式。as方式下配置芯片与fpga相连的信号有:串行时钟输入(dclk),as控制信号输入(asdi),片选信号(ncs),串行数据输出。fpga被动方式在被动方式下,由系统中的其他设备,如altem的配置芯片(epc系列)、微处理器、cpld
32、等发起并控制配置过程,fpga处于完全被动的地位。fpga接收配置时钟、配置命令和配置数据,给出配置的状态信号以及配置完成指示信号等。被动方式可以具体细分为以下多种模式,包括被动串行ps(passive serial)、快速被动并行fpp(fast passive parallel)、被动并行同步pps(passive paraltel synchronous)、被动并行异步ppa(passive parallel asynchronous),以及被动串行异步psa(passive serialasynchronous)。上述模式这里不再详述。ps方式下配置设备与fpga相连的信号有:dclk
33、(配置时钟),data0(配置数据),nconfig(配置命令),nstatus(状态信号),conf done(配置完成指示)。jtag方式jtag是ieee 11491边界扫描测试的标准接嗣。绝大多数的altera fpga都支持由jtag口进行配置,并支持jam stapl标准,jtag配置方式比其他任何一种配置方式的优先级都高。扶jtag接叠进行配置可以使用altera的下载电缆,通过quartos ii工具下载,也可以采用微处理器来模拟jtag时序进行配置。jtag方式下fpga需要用到以下信号:tdi(测试数据的输入),tdo(测试数据的输出),tms(模式控制管脚,决定jtag电
34、路内部的tap状态机的跳转),tck(测试时钟)。cyclone ii的器件都支持上述三种配置方式,本系统可以通过不同的下载接口可以选择采用as方式还是jtag方式。电路原理图如图3-2所示。图3-2 fpga配置电路3.2.3 sdram电路实现本系统fpga内部设计有nios ii 软核,sdram主要用来存放软件mcu中的软件程序,软核cpu中设计的复位基地址reset vevtor及中断向量基地址exception vector,都定义在sdram上,即通常说的内存。如下图3-3所示:图3-3 sdram设置在altera公司fpga开发软件quartus ii中,集成有sopc bu
35、lider。sopc(system on programmable chip,可编程片上系统)是altera公司提出的一种灵活、高效的soc解决方案,是一种新的软硬件协同设计的系统设计技术。它将处理器、存储器、i/o口、lvds和cdr等系统设计需要的功能模块集成到一个可编程器件上,构成一个可编程片上系统。本系统所用的sdram控制器,就是在sopc builder中生成,大大减小了开发难度 。对于本系统而言,只需要一片sdram(k4s641632),其大小为64mb(1m×16bit×4bank)。fpga与sdram的连接比较简单,只需要在fpga内部实现sdram控
36、制器并且配置fpga相应引脚为sdram对应的引脚,即a0a10,ba0一bal,dq15:0,clk,cke,awe,ncas,nras,ldqm,udqm,然后将上述引脚与sdram相连即可。电路原理图如图3-4所示。图3-4 sdram硬件电路图3.2.4 sram电路实现在该系统中,sram主要用来做为图像数据的缓存,用以之后软核cpu对图像的处理工作。本系统采用一片is61lv25616-10t sram芯片即可达到系统要求,fpga与sram的连接如下图3-5所示,此模块最主要的是其控制器的设计,将在下一章软件设计时详细说明。图3-5 sram硬件电路图3.2.5其他硬件电路上面将
37、几个比较复杂的模块详细说明了一下,剩余的几个模块,如ov7670、tft液晶、sd卡。这几个与fpga之间都只是简单的接线连接,在这里就不再详细叙述。这几个模块最重要的是软件设计,将在下一章详细说明。4 系统软件设计4.1 软件设计概述本系统软件设计主要分两部分,一部分是由硬件描述语言设计的系统各个外部的控制模块,如pll、mcu主控模块、ov7670初始化模块、0v7670数据采集模块、sram控制、tft液晶显示控制等。另一部分是nios ii软核中的程序设计,主要包括:sd卡控制、图像算法处理等。系统框图如下图4-1所示:图4-1 fpga内部功能模块连接图系统启动后,mcu先完成对tf
38、t液晶的初始化设置,然后ov7670初始化模块完成对ov7670内部各寄存器的配置;完成后产生一个信号,通知mcu单元0v7670已初始化完毕,然后mcu启动ov7670采集模块和tft控制模块,实现图像的实时显示。另一方面,ov7670采集到的数据,也送入sram控制模块,一帧图像数据全部存入sram后,fpga内部的nios ii软核读取sram图像数据并解析,处理后以图片格式存入sd卡中。另外,pll(phase locked loop,锁相环)模块提供三路不同的频率信号,为驱动其他模块提供。4.2 vhdl简介及特点vhdl(very-high-speed integrated cir
39、cuit hardwaredescription language,超高速集成电路硬件描述语言)诞生于1982年。1987年底,vhdl被ieee和美国国防部确认为标准硬件描述语言 。vhdl主要用于描述数字系统的结构,行为,功能和接口。除了含有许多具有硬件特征的语句外,vhdl的语言形式、描述风格以及语法是十分类似于一般的计算机高级语言。与其他硬件描述语言相比,vhdl具有以下特点: 功能强大、设计灵活vhdl具有功能强大的语言结构,可以用简洁明确的源代码来描述复杂的逻辑控制。它具有多层次的设计描述功能,层层细化,最后可直接生成电路级描述。vhdl支持同步电路、异步电路和随机电路的设计,这是
40、其他硬件描述语言所不能比拟的。vhdl还支持各种设计方法,既支持自底向上的设计,又支持自顶向下的设计;既支持模块化设计,又支持层次化设计。 支持广泛、易于修改由于vhdl已经成为ieee标准所规范的硬件描述语言,目前大多数eda工具几乎都支持vhdl,这为vhdl的进一步推广和广泛应用奠定了基础。在硬件电路设计过程中,主要的设计文件是用vhdl编写的源代码,因为vhdl易读和结构化,所以易于修改设计。 强大的系统硬件描述能力vhdl具有多层次的设计描述功能,既可以描述系统级电路,又可以描述门级电路。而描述既可以采用行为描述、寄存器传输描述或结构描述,也可以采用三者混合的混合级描述。另外,vhd
41、l支持惯性延迟和传输延迟,还可以准确地建立硬件电路模型。vhdl支持预定义的和自定义的数据类型,给硬件描述带来较大的自由度,使设计人员能够方便地创建高层次的系统模型。 独立于器件的设计、与工艺无关设计人员用vhdl进行设计时,不需要首先考虑选择完成设计的器件,就可以集中精力进行设计的优化。当设计描述完成后,可以用多种不同的器件结构来实现其功能。 很强的移植能力vhdl是一种标准化的硬件描述语言,同一个设计描述可以被不同的工具所支持,使得设计描述的移植成为可能。 易于共享和复用vhdl采用基于库(library)的设计方法,可以建立各种可再次利用的模块。这些模块可以预先设计或使用以前设计中的存档
42、模块,将这些模块存放到库中,就可以在以后的设计中进行复用,可以使设计成果在设计人员之间进行交流和共享,减少硬件电路设计。4.3 ov7670初始化模块如前方所述,ov7670摄像头有很强大图像处理功能过程,包括伽玛曲线、白平衡、饱和度、色度等,而这些功能,都是通过sccb接口对ov7670内部的上百个寄存器进行配置而控制。sccb接口有两个管脚,sio_c是sccb时钟输入信号,它的最大频率为400kz,sio_d是sccb数据输入输出口,根据协议把参数写入寄存器和读取寄存器的数值。sccb传输时序图已在前方给出过,在这里为叙述方面再列一下。如下图4-2所示。图4-2 sccb控制协议在本系统
43、中,按上图时序,设计配置方案,利用vhdl硬件描述语言设计的专用ov7670初始化模块。该模块包含两个部分,底层部分专门用来实现sccb控制传输,向ov7670传送上层模块传送过来的初始化数据。传输的数据帧格式如下图4-3所示:图4-3 ov7670初始化数据帧格式按照图4-2所示,系统启动时,sic_c为高电平,即为1时 , 把sio_d为设置为1,开始传输时,sio_d拉低为0,然后再把sic_c拉低,表明一帧数据开始传输, 之后把依次把寄存器的地址和初始化数据送到sio_d总线上,在时钟sic_c的驱动下,写入到ov7670。每设置一个寄存器,就调用一次该底层模块,直接最终,完成对ov7
44、670的初始化。发出初始化完成cmos_finish信号。其在quartus ii中生成的模块如下图4-4所示:图4-4 ov7670初始化模块在本系统中的mcu单元中,也设计有利用c语言设计实现该功能,在实际应用时,也可使用。两方案,任选一种。利用vhdl设计的硬件初始化模块,灵活稳定,可按要求重新配置,不会占用mcu的周期指定,这样就在mcu的软件设计中,只需要着重考虑图像算法的处理。大大减轻了mcu的负担。仿真结果如图4-5所示:图4-5 初始化仿真时序4.4 ov7670数据采集模块在初始化程序中,我们已经把ov7670配置为,输出qvga格式,16位图像数据格式为rgb565。ov7
45、670qvga输出时序,如下图4-6所示:图4-6 ov7670 qvga输出时序其中vsync为帧同步信号,href为行同步信号,只有按照上图中严格的时序,即ov7670输出的时序,我们才能采集到正确的图像数据。采集到的rgb565格式数据符合下图标准如4-7所示,图4-7 rgb565数据输出格式采集到的数据,经过内部处理,直接送到tft显示屏上进行实时显示,tft液晶显示屏的初始化将在后面介绍的mcu单元中进行,配置为可直接显示数据采集模块处理过的图像数据。4.5 sram控制模块和tft液晶控制模块此模块包含两部分,一部分的功能是用来转换mcu和写sram模块对外部sram的控制。另一
46、部分就是sram写入控制模块,此模块在ov7670数据采集模块的wr和data_valid等几个信号线的控制下,完成对sram的图像数据写入。开始时,mcu发出sram为空的信号,转换模块将其转换到对sram进行图像数据写入。当一帧图像写入完成之后,转换模块将功能切换到mcu可读sram数据,从而对sram存储的图像进行算法处理。在quartus ii中生成的模块电路如图4-8所示:图4-8 sram控制模块tft液晶控制模块的功能只是将控制权从mcu转换到ov7670数据采集模块,系统启动后,mcu中的软件完成对tft液晶显示屏的初始化,包括背光、颜色、初始写入的坐标等一系列设置。完成之后,
47、将tft的控制交给ov7670数据采集模块,因为在ov7670o数据采集模块中,已经完成所需的数据格式转换,所以这时tft液晶可实时显示到采集的图像。4.6 mcu单元设计4.6.1 sopc builder简介sopc builder 是altera公司推出的一种可加快在pld内实现嵌入式处理器相关设计的工具。它是一个革命性的系统级开发工具,其功能与pc应用程序中的“引导模板”类似,旨在提高设计者的效率。设计者可确定所需要的处理器模块和参数,并据此创建一个处理器的完整存储器映射。设计者还可以选择所需的ip外围电路,如存储器控制器、i/o控制器和定时器等模块。sopc builder可以快速地
48、开发定制新方案,重建已经存在的方案,并为其添加新的功能,提高系统的性能。通过自动集成系统组件,sopc builder允许用户将工作的重点集中到系统级的需求上,而不是从事把一系列的组件装配在一起这种普通的、手工的工作。所有版本的altera quartus的设计软件都已经包含了sopc builder。设计者采用sopc builder,能够在一个工具内定义一个从硬件到软件的完整系统,而花费的时间仅仅是传统soc设计的几分之一。sopc builder提供了一个强大的平台,用于组建一个在模块级和组件级定义的系统。sopc builder的组件库包含了从简单的固定逻辑的功能块到复杂的、参数化的、
49、可以动态生成的子系统等一系列的组件。这些组件可以是从altera或其他合作伙伴处购买来的ip核,其中一些ip核是可以免费下载用来做评估的;用户还可简单地创建他们自己定制的sopc builder组件。sopc builder内建的ip核库是opencore plus版的业界领先的nios/nios 嵌入式软核处理器。所有的quartus 用户都能够把一个基于nios/nios 处理器的系统经过生成、仿真和编译进而下载到altera fpga中,进行实时评估和验证。sopc builder库中已有的组件包括:(1) 处理器:包括片内处理器和片外处理器的接口。(2) ip及外设:包括通用的微控制器
50、外设,通信外设,多种接口(存储器接口、桥接口、assp、asic),数字信号处理(dsp)ip和硬件加速外设。如图4-9所示,sopc builder 的设计流程包括两个阶段:配置(框图左边所示)和生成(框图右边所示)。它是利用class ptf和system ptf这两个文件来配置和生成系统流程的。sopc builder gui引导用户完成两部分的配置:部件配置和系统配置。部件配置需要汇总参数,class ptf文件标准包括了为这一要求定义gui的格式。当需要时,sopc builder读取该格式,产生相应的部件向导(component wizard),收集所需的用户数据。然后sopc b
51、uilder把收集的参数值存放在system ptf文件中。系统配置是指把用户提供的有关处理器的配置、外设连接等数据写入system ptf中。当这两部分配置都完成后,sopc builder进入到生成阶段,生成设计的输出文件。sopc builder查阅每个class ptf文件,允许相关的部件生成程序,它们会正确地输出特定系统配置的硬件和/或软件文件。简单的部件生成程序可能每次都会输出相同的文件,更多的可配置部件则会根据用户输入生成完全不同的结构。例如,nios处理器中包括的uart可以配置为软件控制波特率,以更多门换取更大的灵活性。这种配置选项由用户在部件配置阶段进行设置,根据这个设计,
52、uart生成程序产生所需uart的硬件描述。在生成阶段的最后一步,sopc builder创建适合于系统部件的总线结构,把所有的部件连接在一起。图4-9 sopc开发基本顺序4.6.2主控制单元mcu的实现本系统利用sopc builder设计一个mcu,用以实现各个功能模块之间的协调工作以及图像的处理、sd卡的控制功能。如图4-10所示,这是在sopc builder中设计的系统元件页,其中包括jtag调试接口、onchip memory、sdram控制、epcs flash控制等一系列单元,这些个模块都可以在sopc builder的自带元件库中找到,并按自己系统的要求进行配置。图4-10
53、 mcu系统元件图另外一个就是,sd卡模块。sd卡(secure digital memory card),中文翻译为安全数码卡,是一种基于半导体快闪记忆器的新一代记忆设备,它被广泛地于便携式装置上使用,例如数码相机、个人数码助理(pda)和多媒体播放器等。大小犹如一张邮票的sd记忆卡,重量只有2克,但却拥有高记忆容量、快速数据传输率、极大的移动灵活性以及很好的安全性。在本系统中,包含的sd卡控制模块,在系统中library中没有,就需要我们自己往工程中添加了,根据avalon总线协议,添加的sd卡控制模块如下图4-11所示:图4-11 mcu中sd卡控制模块之后就可以生成我们所需的mcu控制
54、块,添加到我们之前设计的vhdl模块之中,将各个模块连接起来,就形成本系统的底层硬件。最后,我们在nios ii ide集成开发环境中,针对我们的系统,开发软件程序。4.7 nios ii软件开发在之前设计的硬件的组成的小系统,各个模块之间功能相互独立,就像一台没有操作系统的计算机一样,无法运行起来,现在就需要在mcu里面编写程序,协调和控制各个模块,完成我们最终的设计。4.7.1 nios ii集成开发环境nios ii集成开发环境(ide)是nios ii系列嵌入式处理器的基本软件开发工具。所有软件开发任务都可以nios ii ide下完成,包括编辑、编译和调试程序。nios ii ide
55、提供了一个统一的开发平台,用于所有nios ii处理器系统。仅仅通过一台pc机、一片altera的fpga以及一根jtag下载电缆,软件开发人员就能够往nios ii 处理器系统写入程序以及和nios ii处理器系统进行通讯。4.7.2 mcu软件设计nios ii软核mcu加电启动后,要完成对tft液晶屏的初始化、装载sd卡等系统初始化操作,之后等待ov7670初始化完成信号,ov7670初始化完成后,使能外部的ov770数据采集模块、tft液晶屏和sram写入模块。此时,tft液晶屏上面实时显示采集到的画面,并且外部模块一直在向sram内写入图像数据。而在mcu内部的程序,要等待sram写
56、满信号的到来。当sram写满信号到来后,硬件控制器已经将一帧数据写入到sram中,系统禁止写sram,开始对读取sram中的一帧数据,将其存入到一个数组中。之后进行图像处理,计算误差后,将该帧图像存入sd卡,这样,一个循环结束。程序流程图4-12如下所示: 图4-12 mcu中程序流程图4.7.3简单运动检测首先介绍一下rgb色彩模式与yuv色彩模式。rgb色彩模式是工业界的一种颜色标准,是通过对红(r)、绿(g)、蓝(b)三个颜色通道的变化以及它们相互之间的叠加来得到各式各样的颜色的,rgb即是代表红、绿、蓝三个通道的颜色,这个标准几乎包括了人类视力所能感知的所有颜色,是目前运用最广的颜色系
57、统之一。yuv是被欧洲电视系统所采用的一种颜色编码方法(属于pal),是pal和secam模拟彩色电视制式采用的颜色空间。在现代彩色电视系统中,通常采用三管彩色摄影机或彩色ccd摄影机进行取像,然后把取得的彩色图像信号经分色、分别放大校正后得到rgb,再经过矩阵变换电路得到亮度信号y和两个色差信号ry(即u)、by(即v),最后发送端将亮度和色差三个信号分别进行编码,用同一信道发送出去。这种色彩的表示方法就是所谓的yuv色彩空间表示。采用yuv色彩空间的重要性是它的亮度信号y和色度信号u、v是分离的。rgb与yuv色彩空间转换公式如下所示:在处理图像数据部分,本设计通过亮度y比较,简单实现了一个运动检测的功能,具体如下,当系统初始化时,摄像头前没有人经过,此时该系统读取一帧rgb数据,经过上述色彩空间转换得到亮度
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 科技驱动农产品电商
- 科技农业投资视角
- 专业房产经纪服务协议2024版范本版
- 二零二四宇通客车零部件销售代理及市场拓展合作协议3篇
- 2025年度电商新零售线下体验店合作合同3篇
- 专业销售服务协议书2024年3篇
- 2025年度跨境电商物流中心场地承包经营合同4篇
- 2025年度航空航天复合材料加工技术合同4篇
- 2025年度茶楼装修工程合同标准样本8篇
- 2025年度教育机构场地租赁保证金合同8篇
- 2024版塑料购销合同范本买卖
- 【高一上】【期末话收获 家校话未来】期末家长会
- JJF 2184-2025电子计价秤型式评价大纲(试行)
- GB/T 44890-2024行政许可工作规范
- 有毒有害气体岗位操作规程(3篇)
- 二年级下册加减混合竖式练习360题附答案
- 吞咽解剖和生理研究
- TSG11-2020 锅炉安全技术规程
- 汽轮机盘车课件
- 异地就医备案个人承诺书
- 苏教版五年级数学下册解方程五种类型50题
评论
0/150
提交评论