0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于单片机和VNC1L-1A芯片实现图像采集系统的设计

牵手一起梦 来源:现代电子技术 作者:刘威,李莉,陈海燕 2021-04-05 11:06 次阅读

作者:刘威,李莉,陈海燕,王法秀,王莹

图像采集技术随着科技的不断进步在全球的应用已越来越广泛,如军用工业、医疗、电子等各领域。在国内,各行各业对采用图像采集技术的工业自动化智能化需求也广泛出现,逐步开始了工业现场的应用,比如,制药行业的药品检测分装、印刷业的印刷色彩检测、PCB板的表面质量检测、LCD屏的质量检测等。所以,以图像采集功能为核心,开发一款适合工业领域应用且功能齐全、操作方便的图像采集系统会给用户带来很大的实惠。

目前图像采集方面已有很多且很完善的方案,本文设计选择了利用FPGA进行图像采集的方案,设计了一套图像采集系统。与普通应用于工业方面的图像采集系统不同,本系统添加了存储功能,并对传统的控制操作的方式进行了改进。

1 系统总体设计

系统总体设计如下:图像通过VGA接口用显示器显示,显示速率可达25 f/s;系统可以将在显示器上看到的当前图像以位图的格式存储到优盘或其他USB设备中,并可以对存储的图像进行回显;用遥控器代替了按键的控制方式,可以在几米范围内用遥控器调节曝光、增益、十字线、存图和读图等所有功能,操作灵活方便。系统用美光公司的130万像素MT9T001作为图像传感器Altera公司的FPGA芯片EP2C8Q208来完成图像采集和显示功能的控制,在实时浏览图像时,它从MT9T001中采集出Bayer阵列的黑白图像数据,然后将采集的数据用插值算法转换成24位RGB数据,由于采集图像的速度为40 MHz,而VGA显示的速度只有25 MHz,所以FPGA将转换完的数据放到SDRAM中缓存一下再送给驱动VGA显示的ADV7125芯片;ADV7125为ADI公司的高速数模转换芯片,将数字真彩色图像数据转换成可以用VGA接口传输的模拟视频信号;用Atmel公司的ATmega 8L芯片来完成遥控器的解码、读写USB设备的控制以及位图格式的创建等;用集成了文件系统的FTDI的VNC1L-1A芯片作为与USB设备通信的接口芯片,单片机加一片接口芯片完成USB的Host功能,省去了对文件系统的处理,节约了软件的开发时间。将这款带存储功能和遥控控制方式的图像采集系统应用到了工业领域,做成产品,作为工业众多工业相机中的一种。图1是其总体设计框图。

基于单片机和VNC1L-1A芯片实现图像采集系统的设计

2 存储模块设计

目前存储数据的方式有很多种,如硬盘、FLASH、光盘等,其中容易携带且使用方便的应是移动硬盘、优盘、SD卡,这几种方式都可以通过USB口来传输数据(SD卡或CF等可借助相应的读卡器再通过USB口传输数据),可见USB总线的应用已经很普遍,USB总线的即插即用、速度快、可以自供电等优点也的确是其他设备所不能比的。所以系统的存储部分设计成USB设备,USB设备分为USB主(Host)设备和USB从(Device)设备,USB从设备只能被动地由主设备写入或读出数据,不符合本系统的要求。所以选择了USBHost设备,只要将优盘等USB从设备插到系统的USB口上,就可以将当前要存储的图片存储到U盘等存储设备中。

USB Host设备的典型例子是PC机,这种Host功能是在操作系统下完成的,所以现在市面上可以移植操作系统的微控制器芯片大多都集成了USB Host功能,像三星和飞利浦的ARM芯片、君正公司开发的MIPS核芯片JZ4740等。这种采用带操作系统的方案对有一定经验的开发人员来说开发起来比较容易,但对生手来说需要一定的熟悉过程。只为了实现USB Host功能就选择用操作系统的方式完成整个系统的控制是没有必要的,这样做不仅浪费资源,而且会增加底层驱动的开发时间。所以本设计选择了比较简单的方式,只用一片单片机和一个USB接口芯片来完成USB Host功能。这样只要会用单片机的开发人员都可以做USBHost设备。市场上USB从设备的接口芯片有飞利浦的PDIUSBDl2和ISPl581等,但USB Host接口芯片则比较少。经试验,最终确定VNClL-1A这款芯片作为USB Host控制器

2.1 USB Host控制器

VNClL-1A芯片在FTDI公司Vinculum系列中第一个嵌入了USB主控制器,不仅能处理USB Host接口和数据,还内置了MCU和FLASH,而且也封装了USB Device类。它集成了12~48 MHz的时钟倍频器,支持上电复位功能,嵌入了64 KB FLASH ROM,4 KB SRAM,拥有FTDI提供的标准的USB固件库,支持USB 2.O的全速(12 Mb/s)和低速(1.5 Mb/s)速率。28个GPIO可以做通用I/O和命令监测接口,具有2对USB总线接口,可以用串口或者磁盘方式对其烧写程序。当芯片作为主设备要与优盘等从设备通信时,它可以处理FAT文件系统,支持FATl2,FATl6,FAT32格式,文件命名方式为传统的8.3格式,即文件名不超过8个字符,扩展名为3个字符,如文件名可以为text.txt。在执行具体的操作时只需要向VNClL发送一个简单的命令就能完成像新建文件夹、新建文件、读文件、写文件、打开关闭文件等功能。比如要在优盘中创建一个hello.-txt文件,可以用字符方式向VNClL逐一写入“OPW+空格+hello.txt+回车”的字符,就可以在优盘中看见一个hello.txt的文件,或者用十六进制代码的方式发送“09 20 file OD”,其中file为hello.txt各字符的相应ASCII码值。厂家在网站上提供了免费的目标代码,用户可以根据不同的需求下载不同的目标代码,在本设计中,选择用一个USB口作USBHost功能的VDAPFUL_V3_65.ROM目标代码,并设计成串口方式将目标代码烧录到芯片中。所以用户不用关心VNClL内部程序是怎么执行的,只关心需要它完成USB主设备还是从设备还是其他功能,去找相应的目标代码就可以了,烧录完程序的VNCIL芯片就相当于一颗接口芯片,只要接口连接正确,时序操作正确需要的功能就会正常运行。VNC-lL拥有专门的UART,SPI和并口引脚,所以对它进行控制时可以选用三种接口中的任意一种,如果想看一下操作命令的返回值,可以用串口方式连接到PC机上,在PC机上用串口调试助手向VNClL发送相应的命令后,会看到对应的返回值情况。

2.2 存储过程的实现

位图图像在计算机中使用很广泛,例如在Windows中,记事本、写字板中的文字就是用位图图像表示出来的。许多以其他格式存储的图像,就是在位图图像的基础上,进行优化处理后得到的,例如JPEG图像等。在数字图像处理中,许多算法就是针对24位真彩色位图或灰度位图设计的。因此,将采集的图像以位图的格式存储便于后期对图像的处理。位图的存储格式分为24位真彩色格式和灰度位图格式,24位真彩色格式比灰度位图格式大2/3,因为灰度图像是用一个字节表示一个像素,而24位真彩色位图是用三个字节表示一个像素,所以本设计用灰度位图格式存储图像。

当要存储一帧图像时,ATmega8L向VNClL发送新建文件命令,在存储设备中就会新建一个.BMP文件,然后ATmega8L再将位图的14 B的文件头、40 B的信息头、1 024 B的颜色索引表写入.BMP文件的开始部分,写完后ATmega8L给FPGA一个ready信号,FPGA收到此信号后直接将图像数据通过VNC1L送到存储设备的.BMP文件中;FPGA送完一帧图像数据后再给ATmega8L一个结束信号,之后ATmega8L执行关闭当前文件命令,至此一个BMP图存储结束。本设计希望此系统采集的所有图像在存储设备中用单独的文件夹存储,这样每次在新插入存储设备时ATmega8L要先向VNC1L发送一个查询命令,查询当前根目录中是否已存在本系统专用的文件夹,如果没有则新建此文件夹,有则在此文件夹中查询是否已经有.BMP文件,如果没有则新建,并且文件名以数字编号O开始命名,如果有则要查询当前哪个文件名的编号最大,然后以最大编号数加一的方式作为要新建文件的文件名。当要从存储设备中读取一幅图像时,ATmega8L同样要执行查询文件夹和文件是否存在的命令,如果都存在则从文件名编号最大的那张图片开始读取。读取过程与写过程类似,只是用的命令不同,而且读的时候要等VNC1L将位图的1078B的文件信息读完后才能将图像数据传给FPGA。VNC1L与FPGA和ATmega8L用并口的方式进行通信,只需8条数据线和4根信号线即可完成数据传输,接口连接如图2所示。

3 遥控功能设计

目前大多数的电子产品采用的控制方式都是开关式按键或触摸的方式,如数码相机、手机等,工业用的设备也是如此。本文所述的控制方式采用了无线的遥控方式,这种遥控方式在电视机领域已应用多年,技术已经很成熟,原理简单,易于实现。由于选用的遥控器适用于36~40 kHz载波频率的红外接收器,所以设计中选用了36 kHz红外接收器,ATmega 8L接收红外接收器的信号,从中解析出遥控器上各个按键的码值,并会转去执行遥控器上相应按键上的功能。遥控器上设计了21个按键,代表了此系统拥有的所有功能,分别为:

图像存储功能 按下存储键就可以将当前看到的画面存储到存储设备中;

图像预览即读图功能 将存储在存储设备中的图片重新读出,在显示器上显示,预览图片时可以在当前图片的基础上,上翻或下翻即可循环浏览已存储的所有图片;

红、绿、蓝增益及曝光值的调节功能 可以对这4个参数进行增大和减小的控制;

双十字线的控制和调节功能 当想要十字线功能时只要按一下十字线按键就会在当前实时显示的画面上看到两条十字交叉的线,十字线的位置可以根据用户的需要任意移动,当需要双十字线时需要两个控制十字线的按键都按下,使用双十字线可以圈定整幅画面上重点观察的范围;

图像冻结功能 当冻结键按下时显示器上的整个画面冻结,此时不能进行存图、读图或其他任何操作;

当前参数值保存功能 此键按下后会对当前的增益、曝光、十字线位置等参数的当前值存储到ATmega8L的E2PROM中,这样在下次启动系统时,系统会将E2PROM保存的各参数值一一读出;

复位初始参数值功能 如果用户不小心将某一参数值调乱了,可以按下此键来恢复系统最原始的参数值。

4 结语

本文所述的图像采集系统中存储方案的选择和设计对于数据量稍大又不是很复杂的系统的设计具有借鉴作用,而且将遥控器技术作为系统控制操作的方式,让人耳目一新,此图像采集系统应用于工业领域,操作方便且实惠新颖。

责任编辑:gt

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

    关注

    455

    文章

    50791

    浏览量

    423494
  • 单片机
    +关注

    关注

    6036

    文章

    44557

    浏览量

    635128
  • lcd
    lcd
    +关注

    关注

    34

    文章

    4426

    浏览量

    167462
收藏 人收藏

    评论

    相关推荐

    基于FIFO芯片和MC9S12DG128单片机实现图像采集系统的设计

    单片机应用系统中,由于图像采集速度、程序存储器和数据存储器的寻址空间的限制,要完整存储30 fps、640×480像素大小的一幅图像是相当
    的头像 发表于 11-27 08:40 5411次阅读
    基于FIFO<b class='flag-5'>芯片</b>和MC9S12DG128<b class='flag-5'>单片机</b><b class='flag-5'>实现</b><b class='flag-5'>图像</b><b class='flag-5'>采集</b><b class='flag-5'>系统</b>的设计

    STM32F1系列单片机的时钟系统

      这是stm32的时钟系统,时钟与单片机的关系就好比心脏与人的关系一样,它为单片机的运行提供时间基准。STM32F1系列单片机的时钟树请看
    发表于 03-23 17:44 2882次阅读
    STM32F<b class='flag-5'>1</b>系列<b class='flag-5'>单片机</b>的时钟<b class='flag-5'>系统</b>

    单片机实现USB2.0通讯的全数字图像的实时采集

    单片机实现USB2.0通讯的全数字图像的实时采集主要论述利用USB2.0 单片机接口技术实现
    发表于 03-31 13:51

    【案例分享】遥控式可存储的图像采集系统的设计与实现

    的FTDI的VNC1L-1A芯片作为与USB设备通信的接口芯片单片机加一片接口芯片完成USB的Host功能,省去了对文件
    发表于 07-13 05:00

    单片机应用系统设计的基本方法

    19-1. 单片机典型应用系统组成19-2.单片机应用系统实例19-3.单片机应用
    发表于 03-23 12:22 40次下载

    单片机图像采集与网络传输

    本文介绍一个嵌入了TCP/IP 协议栈的89C52 单片机,通过图像采集模块,采用组播方式,实现图像
    发表于 08-21 12:14 45次下载

    单片机系统中高速数据采集实现

    介绍一种单片机系统中 高速数据采集实现方法,在单片机与高速A/D转换器之间以静态存储器作缓冲
    发表于 07-18 16:59 193次下载
    <b class='flag-5'>单片机</b><b class='flag-5'>系统</b>中高速数据<b class='flag-5'>采集</b>的<b class='flag-5'>实现</b>

    FIFO芯片单片机实现图像采集系统

    单片机应用系统中,由于图像采集速度、程序存储器和数据存储器的寻址空间的限制,要完整存储30 fps、640480像素大小的一幅图像是相当困
    发表于 05-10 09:46 2.1w次阅读
    FIFO<b class='flag-5'>芯片</b>和<b class='flag-5'>单片机</b><b class='flag-5'>实现</b>的<b class='flag-5'>图像</b><b class='flag-5'>采集</b><b class='flag-5'>系统</b>

    基于51单片机与GPRS的彩信报警系统的设计与实现

    设计一种基于 GPRS 和51 单片机的彩信报警系统。利用单片机技术、带彩信协议GPRS 无线通信模块、图像捕获和图像压缩编码功能模块,
    发表于 12-06 09:34 13次下载
    基于51<b class='flag-5'>单片机</b>与GPRS的彩信报警<b class='flag-5'>系统</b>的设计与<b class='flag-5'>实现</b>

    使用51单片机实现温度采集系统的设计资料说明

    数字单总线温度传感器是目前最新的测温器件,它集温度测量,A/D转换于一体,单总线结构,数字量输出,直接与单片机相接等优点。可用它组成单路或多路温度测量装置。叙述基于51单片机温度采集
    发表于 09-17 10:29 53次下载
    使用51<b class='flag-5'>单片机</b><b class='flag-5'>实现</b>温度<b class='flag-5'>采集</b><b class='flag-5'>系统</b>的设计资料说明

    如何使用STM32单片机实现温度采集报警系统的设计

    本文档的主要内容详细介绍的是如何使用STM32单片机实现温度采集报警系统的设计包括了:包含源程序、原理图PCB等文件。
    发表于 01-18 08:00 35次下载
    如何使用STM32<b class='flag-5'>单片机</b><b class='flag-5'>实现</b>温度<b class='flag-5'>采集</b>报警<b class='flag-5'>系统</b>的设计

    51单片机 Proteus仿真 基于单片机的风扇转速采集系统 电机转速采集

    电子发烧友网站提供《51单片机 Proteus仿真 基于单片机的风扇转速采集系统 电机转速采集.pdf》资料免费下载
    发表于 11-12 19:06 41次下载
    51<b class='flag-5'>单片机</b> Proteus仿真 基于<b class='flag-5'>单片机</b>的风扇转速<b class='flag-5'>采集</b><b class='flag-5'>系统</b> 电机转速<b class='flag-5'>采集</b>

    AN4453_基于STM32L1xx系列单片机ADPCM算法的实现

    AN4453_基于STM32L1xx系列单片机ADPCM算法的实现
    发表于 11-21 08:11 0次下载
    AN4453_基于STM32<b class='flag-5'>L1</b>xx系列<b class='flag-5'>单片机</b>ADPCM算法的<b class='flag-5'>实现</b>

    基于51单片机的脉搏采集系统设计

    本次脉搏采集系统使用的是STC89C52单片机作为主控芯片,通过血氧模块进行脉搏检测,采集到的数据会上传到
    的头像 发表于 09-01 09:16 1345次阅读
    基于51<b class='flag-5'>单片机</b>的脉搏<b class='flag-5'>采集</b><b class='flag-5'>系统</b>设计

    基于瑞萨RL78/L1A单片机的智能体脂秤方案

    基于瑞萨RL78/L1A单片机的智能体脂秤方案
    的头像 发表于 09-19 16:50 822次阅读
    基于瑞萨RL78/<b class='flag-5'>L1A</b><b class='flag-5'>单片机</b>的智能体脂秤方案