《电子技术应用》
您所在的位置:首页 > 嵌入式技术 > 业界动态 > 基于单片机的线阵CCD实时检测系统的开发

基于单片机的线阵CCD实时检测系统的开发

2008-08-29
作者:江川贵 廖启征 魏世民

    摘 要: 分析了线阵" title="线阵">线阵CCD用于实时检测系统" title="检测系统">检测系统的特点和要求,介绍了一种基于AT89C2051单片机的线阵CCD实时检测系统的设计方案。本方案电路结构简单可靠,信号处理灵活恰当,有一定的通用性和启发性。
    关键词: CCD  单片机  驱动  检测系统

 

    CCD(Charge Coupled Devices)电荷耦合器件[1]应用系统的关键技术在于CCD驱动时序的产生和输出信号的采集与处理。目前驱动主要有直接数字电路驱动、EPROM驱动、专用IC驱动、复杂的CPLD驱动等常用的驱动方法,但是它们存在着逻辑设计较为复杂、调试困难、柔性较差等缺点。在数据采集和处理方面,大多数都经过差动放大、采样保持、A/D转换,再通过总线或采集卡等接口与PC机相连。这种系统结构庞大,而且在信号处理、通信软件和界面设计等方面要耗费大量的精力。应该说这种应用系统在静态测量处理方面有其优点,但如果要满足实时控制系统的连续检测要求以及系统体积精小而容易装配等特点,则必须简化驱动电路、数据采集过程和处理方式。本文正是出于这种考虑,开发出了一种基于单片机的实时性检测系统:仅用Atmel公司一块小型的AT89C2051单片机便能产生稳定、精确、高速的驱动脉冲。该电路结构简单、调试方便、CPU占用率低,将驱动、采集和处理融为一体,而且与上位机" title="上位机">上位机的连接仅用两条导线便可实现检测信息传输。这种方法大大简化了线阵CCD检测系统的结构,在机器人视觉、智能小车、轨迹导引等动态检测方面有独特的应用优势。
1 线阵CCD实时检测系统模型
    以机器人路径识别为例具体说明如何利用线阵CCD开发实时动态环境检测系统。
    假设在一个深色(如黑色、蓝、绿等)平面上用宽度为30mm的白线作为机器人将要运动的轨迹导引线,利用线阵CCD开发出检测白线轨迹的检测系统。先利用光学系统用摄像头将路面信息成像到CCD的感光面上;然后读取白线的位置检测信息作为机器人的视觉,让机器人在上位机的控制下沿白线轨迹运动。这是一个典型的CCD实时检测系统。整体检测系统如图1所示。

 


2 硬件设计
    利用CCD的光电特性,设计出的电路应能判别视频信号上输出的深色和白色区别,这样才能识别白线,时刻反应机器人当前所在的物理位置,以便对其运动做相应的调整。
    线阵CCD选用NEC公司的μPD3575D型号[4]。芯片为20脚DIP封装,像敏单元数目为1024,像敏单元大小为14μm×14μm×14μm(相邻像元中心距为14μm),光敏区域采用高灵敏度和低暗电流PN结作为光敏单元, 内置采用保持电路、输出放大电路,外观尺寸为25.5mm×10mm,易于装卸。该器件工作在5V驱动(脉冲)、12V电源条件下。
    系统简要电路如图2所示。驱动用的单片机是AT89C2051。它是Atmel公司生产的自带2KB可编程Flash存储器的与MSC-51兼容的高性能处理器。它与常规的51芯片有相同的核心和相近的结构功能如RAM、定时/记数器、中断结构、串行口、振荡器和时钟电路等;有最高达24MHz的振荡频率,能高速地驱动CCD;有较少的精简I/O端口,因此体积很小,非常适用做小型应用系统的处理器。对很多嵌入式控制应用提供了一个高度灵活的有效解决方案。本线阵CCD检测系统发挥了其小而灵活的特点,既使系统资源得到了充分的应用又让系统结构精简紧奏。电路中二值化" title="二值化">二值化部分的电位器R_T用来调整二值化比较电平的阀值(0~5V),通过它调节整个CCD的灰度分辨率?眼3?演。同时整个系统对外接口十分简单,只需接上电源和两条通向上位机的信号线。上位机只需等待同步信号FC和检测脉冲信号" title="脉冲信号">脉冲信号BIN_OUT到来的中断信号,与AT89C2051相互独立,彼此之间没有任何时钟信号或复用关系。因此实际运用中器件互换性较强,既可选用普通的AT89C51进行一定的端口扩展接收FC和BIN_OUT,也可选用中断能力较强的SOC芯片C8051FXX系列等。整个检测系统具有良好的柔性,最终电路体积可控制在手掌心大小之内。

 


3 信号时序及软件设计
    由于硬件设计时考虑用软件产生CCD驱动信号,这样软件设计的最大难点为既要满足CCD芯片的驱动信号要求又要完成检测信息的完整表述。综合比较各种方法后得出了整个软件设计思路如下:
    驱动描述:NEC公司的线阵μPD3575D所需驱动信号与TOSHIBA公司传统的TCD系列略有差异,具体驱动信号为:时钟Φ10、转移脉冲ΦTG、复位时钟ΦRO和采样保持时钟ΦSHO,时序关系如图3所示。

 


    μPD3575D为双沟道线阵CCD,它有两列525位的CCD移位寄存器,分列在像敏阵列的两边,在一个积分的ΦTG周期中至少有525个Φ10脉冲。另外考虑到一些暗信号和空驱动,本系统开发中取Φ10脉冲宽度约为10μs、ΦTG积分时间为12ms。
    单片机驱动主要是通过程序编程控制输出驱动的时序信号,可以通过修改程序方便地修改输出时序。单片机是靠指令产生I/O口的输出逻辑,在使用逻辑转移指令时,必须注意精心配置,避免产生驱动时序相位上的不同步。因为转移指令要根据某些条件产生程序分支,而分支程序在不同的条件下执行周期通常不同?眼2?演,会造成CCD驱动时序不同步。
    检测过程描述:参见图2的系统电路图,当CCD被驱动后因其光电特性会有视频模拟信号Vout输出,信号如图4所示。可以看出:模拟信号Vout在CCD扫描到深色区和白色区有明显的幅值大小区别,要提取的信息就是这个变化的电压信号。但单片机不能直接处理模拟信号Vout,因此必须先将Vout通过二值化处理得到数字信号BIN(见图2二值化电路部分)。这样便得到了反映白线左右两个边缘的脉冲信号BIN。为了方便上位机的处理,不直接输出信号BIN,而是将 BIN反馈给AT89C2051,让其通过程序编制来捕捉其上升沿和下降沿的跳变,再从另外的引脚输出与BIN上升沿和下降沿同步的负脉冲信号BIN_OUT。这样上位机可方便地通过中断检测到白线的左右侧。这里AT89C2051还要输出一个同步信号FC(即驱动转移脉冲ΦTG)。因为系统是在连续扫描地面信息,故FC脉冲可标志CCD上一次扫描的结束和新一行扫描的开始。新一行开始扫描时,上位机收到FC负脉冲后可进入中断对定时器T0、T1清零并立即开始计数。当收到BIN_OUT的第一个负脉冲后进入中断并停止定时器T0;当收到BIN_OUT的第二个负脉冲后进入中断并停止定时器T1,读出定时器T0、T1里的数t0、t1。t0、t1便反映了路面白线的坐标位置,很明显t1与t0之差便是白线宽度。

 


    综合以上驱动和检测信号要求得出:在主程序中用一个死循环产生连续的四路驱动脉冲,并通过嵌入相应的其他功能的指令来保证四个驱动脉冲的相位关系,对BIN信号的上升沿和下降沿的判断也在此循环中完成。对BIN信号的当前状态还必须有一个状态标志BIN_STATE。一旦遇到BIN信号有电平变化便给出相应的BIN_OUT负脉冲,而BIN_OUT恢复高电平是靠定时器T0溢出中断服务程序实现的。
    P_1O        EQU      P1.7      ;时钟脉冲信号Φ10
    P_RO        EQU      P1.6      ;复位时钟信号ΦRO
    P_SHO       EQU      P1.5      ;采样保持时钟信号ΦSHO
    P_TG        EQU      P1.4      ;转移脉冲信号ΦTG
    BIN         EQU      P1.2      ;二值化后的数字信号
    P_FC        EQU      P1.0      ;同步信号输出
    P_BIN_OUT   EQU      P1.1      ;BIN_OUT检测信号
    BIN_STATE   BIT      20H       ;BIN信号的状态标志
    主要驱动程序:
    LOOP:       CPL      P_1O        
                INC      R5
                CLR      P_SHO     
                JNB      BIN_STATE,  LINE1
                SETB     P_SHO         
                JB       BIN,   LINE3
                CLR      BIN_STATE    ;BIN有下降沿
                CLR      P_BIN_OUT    ;BIN_OUT负脉冲输出
                SETB     TR0          ;启动定时器等待定时中断恢复高电平
                SJMP     LINE3
    LINE1:      SETB     P_SHO        
                JNB      BIN, LINE3
                SETB     BIN_STATE    ;BIN有上升沿
                CLR      P_BIN_OUT    ;BIN_OUT负脉冲输出
                SETB     TR0          ;启动定时器等待定时中断恢复高电平
    LINE3:      CLR      P_RO
                NOP
                SETB     P_RO
                CJNE     R5, #50, LOOP ;控制光积分时间
                MOV      R5, #0
                INC      R6
                CJNR     R6, #25, LOOP
                MOV      R6, #0
                CLR      P_TG      
                CLR      P_FC       
                MOV      R7, #200
                DJNZ     R7, $
                SETB     P_TG
                SETB     P_FC
                SJMP     LOOP
    本系统用一片小型单片机完全实现了预定功能,几乎没有复杂的外围电路器件,结构简单可靠,硬件、软件代价都较低,系统成本预算较低。整个检测系统用在机器人视觉上实验效果也非常理想。系统可根据具体的需要和要求进行扩展和改变,如增加信号输出、改变检测系统和上位机的信号接口等。

参考文献
1  王庆有.CCD应用技术.天津:天津大学出版社?熏 2000
2  何立民.MSC-51系列单片机应用系统设计系统配置与接口技术. 北京?押北京航空航天大学出版社,2002
3  万 英.CCD二值化测量的阀值自动调节方法.光学技术,2003;(3):370~371
4  NEC公司.线阵CCD图像传感器技术手册. 2003

本站内容除特别声明的原创文章之外,转载内容只为传递更多信息,并不代表本网站赞同其观点。转载的所有的文章、图片、音/视频文件等资料的版权归版权所有权人所有。本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如涉及作品内容、版权和其它问题,请及时通过电子邮件或电话通知我们,以便迅速采取适当措施,避免给双方造成不必要的经济损失。联系电话:010-82306118;邮箱:aet@chinaaet.com。