DIY编程器网

标题: I2C总线CMOS型PB-0300数字图像传感器 [打印本页]

作者: liyf    时间: 2014-10-5 10:06
标题: I2C总线CMOS型PB-0300数字图像传感器
I2C总线CMOS型PB-0300数字图像传感器

摘要:介绍CMOS型数字图像传感器PB-0300的性能特点、功能设置、与MCS-51系列单片机的接口电路及编程技术。
   关键词:I2C总线 数字图像 传感器
1 功能描述
1.1 性能特点
PB-0300系列CMOS型有源像素数字图像传感器,内置模数转换8、位并行数据输出、64个内部寄存器,采用I2C总线控制,可编程控制;可以在彩色和黑白两种模式下工作。当外接24MHz时钟晶振时,可以获得30帧/s的图像输出。在上电期间,自动调入缺省参数设置,包括自动曝光功能,所以可以不编程情况下使用传感器。主要性能指标如表1。

表1 主要性能指标
阵列格局640×487(311 680像素)
VGA参考:640×480(307 200像素)
像素大小和类型有源光电二极管,空间分辨力:7.9μm×7.9μm
帧速率/(帧/s)0~39
最大数据传输速度/(MB/s)24(在24MHz时钟下)
功率/mW300(最大数据速度下)
数字信噪比(1lux条件下)大于20dB(10:1)(对绿色像素,30Hz的以照明度)
数字敏感度红色:950bit/lux-second,绿色:650bit/lux-second,
蓝色:750bit/lux-second,(增益为10,ADC参考为+5.0V)
工作电压/V+5.0
工作电流/mA060
工作温度/℃-5~70
输出8位彩色(单色)数字输出
快门电子旋转抓拍
可编程控制项窗口尺寸和位置、信号增益、曝光参数、自动曝光参数、ADC参考、帧速率、DAC偏置

1.2 内部结构
PB-0300由五大部分组成:数字逻辑模块、像素阵列、列平行的增益电路和读出电路、8位ADC、偏置DACs,如图1所示。
主要引脚功能如表2。

表2 主要引脚功能描述
引脚名称工作方式功  能  描  述
LINE_VALID输出行有效信号--图像数据在数据输出总线上时有效
FRAME_VALID输出帧有效信号
SDATA输入/输出I2C数据通道
SCLK输入I2C时钟
PIX_CLOCK输出像素时钟,下降沿有效
CLOCK_OUT输出主时钟输出
CLOCK_IN输入时钟输入,标称主时钟为24MHz
DOUT0~7输出8位并行数据输出
SADDR输入器件连线地址脚,SADDR=5V:写地址=BA,读地址=BB;SADDR=0V:写地址=92,读地址=93
VREF1输出ADC参考偏置
STANDBY输入关闭模拟偏置电路和内部时钟(省电)
RESET_BAR输入复位键,低电平有效

PB-0300有三种分开的供电电源:数字电源、模拟电源和传感器阵列电源。使用时要特别注意各电源间的相互影响。
2 图像输出格式与时序
PB-0300控制像素数据输出的信号有:帧有效(FRAME-VALID)信号、行有效(LINE-VALID)信号、像素时钟(PIXCLK)信号。FRAME-VALID信号控制一帧有效图像的输出,高电平有效;LINE-VALID信号控制每行有效信号的输出, 高电平有效;PIXCLK信号控制每个像素的输出,当FRAME-VALID和LINE-VALID均为高电平时,每个像素时钟周期输出一个8位像素信号;并行的DOUT0~DOUT7是像素数据的8位输出,它们始终和像素时钟同步。在PIXCLK处于下降沿时,数据输出和LINE-VALID都不能改变。在默认的VGA(640×480)下,当每行640个有效像素信号输出之后,LINE-VALID变为低电平,PB-0300按一定编码方式向外输出982个无效信号,然后再输出像素信号。当480行有效像素和无效信号完全输出之后,传感器再输出9行空白信号。这期间FRAME-VALID为低电平,标志着当前帧的结构和下一帧的开始;同时,读入寄存器的最新值,通过对寄存器编程而改变的图像参数在下一帧生效。信号输出时序如图2所示。
3 寄存器设置
PB-0300共有64个寄存器(R0-R63),地址依次为00H~3FH,在缺省情况下有自动曝光功能;可以改变输出图像的大小、位置和速度;通过调节像素累积时间、ADC参考和增益值可以控制采集到的图像亮度。下面介绍几个主要寄存器的功能。
*复位控制寄存器(R13)
R13能够使PB-0300复位到上电后的缺省状态。首先向R13的最低位写入“1”,使PB-0300处于复位状态,然后再写入“0”继续工作。
*窗口位置与大小控制寄存器(R1,R2,R3,R4)
控制采集图像窗口的位置与大小。只有在此窗口内的像素才能有效地读出。窗口的像素个数最大值为640×480。R1为行起始坐标,R2为列起始坐标,(1024-R3)为有效行数,(1024-R4)为有效列数;窗口大小的默认值为VGA(640×480),右上角坐标为(0,0),左下角坐标为(639,479)。
*像素累积控制寄存器(R8,R9)
控制像素的采光时间,R8为累积帧数,R9为累积行数,实际总的累积时间,即实际处理完一帧图像的时间为:Tint=[(R8×(1024-R3)+R9)×Trow,其中,Trow为处理完一行有效像素所用的时间。一般的R8设置为0,R9的最大值为有效图像窗口的行数。Tint的值应该能信号避免由于光闪烁使图像产生条纹。在60Hz光闪烁频率下,Tint必须为1/120s的整数倍;50Hz频率下,Tint必须为1/100的整数倍。
*帧速率控制寄存器(R5,R6,R10)
控制每行和每帧有效像素信号之间的无效信号时间。当其它图像参数改变时,通过改变上帧速度控制寄存器的值为调节帧速率。若通过R4减小有效像素列数后,处理一行有效像素的时间将变短,帧速率将增加。这时可以调节R5的值来增加每行元效信号的输出数量和时间,从而使帧速率保持不变;同理,若改变有效像素行数时,调节R6来保持帧速率。R10是通过控制PIXCLK的输出来改变像素输出时间的。

[attach]32204[/attach]
图2 信号输出时序


    *增益设置寄存器(R43,R44,R45,R46,R53)
设置输出像素的各种颜色的增益值。像素信号在模数转换前经过增益放大电路,分别对各种颜色进行处理,R43、R46分别对应蓝色和红色,R44、R45都对应绿色,R53是全局设置。一般的照明情况下(100~1000lx),增益值为1~8,编程的值是多少,对应的增益值就是多少。从R53可以读出自动曝光模式下的增益值。
*模数转换参考(ADC)控制寄存器(R25)
通过改变模数转换参考值,改变图像的数字输出,从而调节图像亮度。当图像亮度大时,增加ADC值,得到的图像将变暗;当图像较暗时,减小ADC值,得到的图像将变亮。在非自动曝光模式下,R25控制ADC的最大参考值(最小参考值为0),其典型值在24~38之间。在自动曝光模式下,ADC参考值不能改变。
*信号漂移值设置寄存器(R32)
设置信号漂移值,调节图像的亮度,可以设置正负两种值。当图像太暗时,给R32加一个正值,像素信号变大,使得图像变亮;当图像太亮时,给R32加一个负值,使图像变暗。
4 PB-0300与单片机的接口
当PB-0300复位至默认状态下时,能够自动工作,此时采用自动曝光功能,输出的图像为640×480像素,输出速率为30帧/s。也可以通过修改寄存器的值来改变传感器的工作方式和提高图像的输出质量。在MCS-51系列单片上,可以使用虚拟I2C总线软件包VIIC模拟I2C总线,对PB-0300的寄存器进行读写。接口电路如图3所示。
PB-0300采用16位寄存器,需要写入2个字节,写满之后寄存器地址自动增加。所以对连接寄存器进行写操作时,只需写入第一个寄存器的地址;进行读操作时,先对控制寄存器空写一次,以明确操作对象,然后进行读数。子程序WRITE是将默认状态下R5的值(510)修改为340(0214H),使图像输出为VGA(640×480),输出速率为25帧/s。子程序READ是以读R9、R10为例的典型程序。子程序清单如下:
VSDA EQU P1.7
VSCL EQU P1.6
SLA EQU 50H
NUMBYT EQU 51H
MTD EQU 30H
MRD EQU 40H
WRITE:MOV 30H,#05H ;寄存器R5地址
MOV 31H,#02H ;寄存器值(0214H)
MOV 32H,#14H
MOV SLA,#0BAH ;寻址并为写操作
MOV NUMBYT,#03H ;写入字节数
LCALL WRNBYT
RET
READ:MOV 30H,#09H ;寄存器的R9地址
MOV NUMBYT,#01H ;写入字节数
MOV SLA,#0BAH ;寻址并为写操作
LCALL WRNBYT
MOV SLA,#0BBH ;寻址并为读操作
MOV NUMBYT,#04H;读出字节数
LCALL RDNBYT
RET

    可以利用USB接口直接读出PB-0300芯片的数据。在LINE-VALID和FRAME-VALID信号均为高电平时,按照像素时钟PIXCLK的输出读数。由于USB接口速度快,能够将PB-0300的数据实时地传送到计算机内。
PB-0300具有体积小、功耗低、接口简单的特点,而且编程操作灵活,可以不用编程在默认方式下工作,也可以通过编程来改变输出图像的质量、大小和速度等,特别适合于现场应用中。PB-0300系列目前流行使用的是PB-0330。
作者: 李小路    时间: 2021-6-20 07:21
谢谢分享




欢迎光临 DIY编程器网 (http://diybcq.com./) Powered by Discuz! X3.2