基于51单片机的酒精测试仪设计.doc

上传人:小飞机 文档编号:4003951 上传时间:2023-03-31 格式:DOC 页数:30 大小:254.50KB
返回 下载 相关 举报
基于51单片机的酒精测试仪设计.doc_第1页
第1页 / 共30页
基于51单片机的酒精测试仪设计.doc_第2页
第2页 / 共30页
基于51单片机的酒精测试仪设计.doc_第3页
第3页 / 共30页
基于51单片机的酒精测试仪设计.doc_第4页
第4页 / 共30页
基于51单片机的酒精测试仪设计.doc_第5页
第5页 / 共30页
点击查看更多>>
资源描述

《基于51单片机的酒精测试仪设计.doc》由会员分享,可在线阅读,更多相关《基于51单片机的酒精测试仪设计.doc(30页珍藏版)》请在三一办公上搜索。

1、第一章 研究内容TGS822对酒精浓度的变化,其阻值产生相应的变化,然后通过取样电阻分压的变化表现出来;人体血液酒精浓度的不同,其呼出的气体中酒精浓度也不同。通过TGS822对呼出气体中酒精浓度的反应以取样电压的形式送入到ADC0809,进行A/D转换后并将转换的数据送入单片机进行分析处理,并判断是否醉酒驾车,再通过液晶板显示出来。DS18B20其自身的温度传感器所产生的温度数字数据存入其自身的存储器,单片机对其控制读出温度数据,然后经过计算处理,将当前环境温度由液晶板输出。第2章 总体设计2.1 本课题的设计任务及要求2.1.1 设计任务设计并制作酒精测试仪,其组成如图2.1所示。TGS82

2、2对酒精浓度的变化,其阻值产生相应的变化,然后通过取样电阻分压的变化表现出来;人体血液酒精浓度的不同,其呼出的气体中酒精浓度也不同。通过TGS822对呼出气体中酒精浓度的反应以取样电压的形式送入到ADC0809,进行A/D转换后并将转换的数据送入单片机进行分析处理,并判断是否醉酒驾车,再通过液晶板显示出来。DS18B20其自身的温度传感器所产生的温度数字数据存入其自身的存储器,单片机对其控制读出温度数据,然后经过计算处理,将当前环境温度由液晶板输出。数字输出模拟输出传感器模数转换控制输出单片机LCD显示输出图2.1系统设计方框图2.1.2 设计要求(1)传感器TGS822的电压模拟输出范围为0

3、-5V;(2)模数转换芯片ADC0809采样电压范围为0-5V,分辨率为8位,采样精度为5/256V,达到256个量化级的数字电压,其工作频率为1MHz;(3)单片机AT89C52工作频率为6 MHz;(4)LCD显示器用50K的可调电阻调节使其清晰显示,消除“鬼影”。2.2 系统整机原理图分析如图2.2系统整机原理图,本系统工作原理如下:单片机的晶振为6MHz,可以直接通过ALE口输出1 MHz为ADC0809作为工作时钟而不需要进行分频,然后通过单片机的P2.0、P3.7分别控制ADC0809的ALE和START端口进行模数转换;通过P2.2、P2.3、P2.5分别控制ADDB、ADDC、

4、ADDA端口进行选择模拟数据输入口;通过P0口进行ADC0809数据输出。TGS822的采样电压由ADC0809的IN0口输入,通过转换后由其D0-D7输出到单片机的P0口,然后通过传感器的特性公式计算由P1口将数据通过LCD的DB0-DB7输出。第3章 系统硬件设计3.1系统硬件设计原理图分析本硬件由五部分组成:单片机模块,模数转换模块,酒精传感器模块,温度传感模块。其系统硬件设计原理图如图3.2所示,其整机工作原理如下,本系统由单片机AT89C2控制,其直接控制三个模块:数转换模块将酒精传感器采集到模拟电压信号转换成输送到单片机控制处理,温度传感器DS18B20可以将采集到的温度信号直接以

5、数字信号的形式传到单片机,LCD显示模块可以将经过单片机处理过的酒精气体浓度和温度的具体量化值显示。图3.1系统硬件设计原理图3.2单片机模块单片机的选择AT89S52是低功耗、高性能、采用CMOS工艺的8位单片机,其片内具有8KB 的可在线编程的Flash 存储器。该单片机采用了ATMEL公司的高密度、非易失性存储器技术,与工业标准型80C51单片机的指令系统和引脚完全兼容;片内的Flash存储器可在线重新编程,或者使用通用的非易失性存储器编程;通用的8位CPU与在线可编程Flash集成在一块芯片上,从而使AT89S52 功能更加完善,应用更加灵活;具有较高的性能价格比,使其在嵌入式控制系统

6、中有着广泛的应用前景。MCS单片机都采用40引脚的双列直插封装方式。下图为引脚排列图, 40条引脚说明如下:1主电源引脚Vss和Vcc(1)Vss接地(2)Vcc正常操作时为+5伏电源2外接晶振引脚XTAL1和XTAL2(1)XTAL1内部振荡电路反相放大器的输入端,是外接晶体的一个引脚。当采用外部振荡器时,此引脚接地。(2)XTAL2内部振荡电路反相放大器的输出端。是外接晶体的另一端。当采用外部振荡器时,此引脚接外部振荡源。3控制或与其它电源复用引脚RST/VPD,ALE/和/Vpp(1)RST/VPD 当振荡器运行时,在此引脚上出现两个机器周期的高电平(由低到高跳变),将使单片机复位在Vc

7、c掉电期间,此引脚可接下图8051引脚排列图上备用电源,由VPD向内部提供备用电源,以保持内部RAM中的数据。(2) ALE/正常操作时为ALE功能(允许地址锁存)提供把地址的低字节锁存到外部锁存器,ALE 引脚以不变的频率(振荡器频率的)周期性地发出正脉冲信号。因此,它可用作对外输出的时钟,或用于定时目的。但要注意,每当访问外部数据存储器时,将跳过一个ALE脉冲,ALE 端可以驱动(吸收或输出电流)八个LSTTL电路。对于EPROM型单片机,在EPROM编程期间,此引脚接收编程脉冲(功能)。(3)外部程序存储器读选通信号输出端,在从外部程序存储取指令(或数据)期间, 在每个机器周期内两次有效

8、, 同样可以驱动八LSTTL输入。(4)/Vpp 、/Vpp为内部程序存储器和外部程序存储器选择端。当 /Vpp为高电平时,访问内部程序存储器,当/Vpp为低电平时,则访问外部程序存储器。对于EPROM型单片机,在EPROM编程期间,此引脚上加21伏EPROM编程电源(Vpp)。4、输入/输出引脚P0.0 - P0.7,P1.0 - P1.7,P2.0 - P2.7,P3.0 - P3.7。(1)P0口(P0.0 - P0.7)是一个8位漏极开路型双向I/O口,在访问外部存储器时,它是分时传送的低字节地址和数据总线,P0口能以吸收电流的方式驱动八个LSTTL负载。(2)P1口(P1.0 - P

9、1.7)是一个带有内部提升电阻的8位准双向I/O口。能驱动(吸收或输出电流)四个LSTTL负载。(3)P2口(P2.0 - P2.7)是一个带有内部提升电阻的8位准双向I/O口,在访问外部存储器时,它输出高8位地址。P2口可以驱动(吸收或输出电流)四个LSTTL负载。(4)P3口(P3.0 - P3.7)是一个带有内部提升电阻的8位准双向I/O口。能驱动(吸收或输出电流)四个LSTTL负载。3.3 模数转换器模块ADC0809性能的介绍模数转换电路的功能是将连续变化的模拟量转换为离散的数字量,是架起模拟系统跟数字系统之间连接的桥梁。对于本系统而言,就是用于快速、高精度地对输入的酒精浓度信号进行

10、采样编码,将其转换成单片机所能够处理的数字量。模数转换电路是本系统的关键部分,其性能的好坏直接影响整个系统的质量。根据A/D 转换器的工作原理可将A/D 转换器分成两大类:一类是直接型A/D转换器;另一类是间接型A/D 转换器。在直接型A/D 转换器中,输入的模拟电压被直接转换成数字代码,不经任何中间变量。在间接型A/D 转换器中,首先把输入的模拟电压转换成某种中间变量(时间、频率、脉冲宽度等等),然后再把这个中间变量转换为数字代码输出。1主要特性(1)8路8位A/D转换器,即分辨率8位。(2)具有转换起停控制端。(3)转换时间为100s。(4)单个+5V电源供电。(5)模拟输入电压范围0+5

11、V,不需零点和满刻度校准。(6)工作温度范围为-40+85摄氏度。(7)低功耗,约15mW。2内部结构ADC0809由4部分逻辑结构构成,如图3.3所示。ADC0809是CMOS单片型逐次逼近式A/D转换器,它由8路模拟开关、地址锁存与译码器、比较器、8位开关树型D/A转换器、逐次逼近寄存器、三态输出锁存器等其它一些电路组成。因此,ADC0809可处理8路模拟量输入,且有三态输出能力,既可与各种微处理器相连,也可单独工作。输入输出与TTL兼容。3外部特性(引脚功能)ADC0809芯片有28条引脚,采用双列直插式封装,如图3.3所示。下面说明各引脚功能。IN0IN7:8路模拟量输入端。2-12-

12、8:8位数字量输出端。ADDA、ADDB、ADDC:3位地址输入线,用于选通8路模拟输入中的一路。ALE:地址锁存允许信号,输入,高电平有效。START: A/D转换启动信号,输入,高电平有效。EOC: A/D转换结束信号,输出,当A/D转换结束时,此端输出一个高电平(转换期间一直为低电平)。OE:数据输出允许信号,输入,高电平有效。当A/D转换结束时,此端输入一个高电平,才能打开输出三态门,输出数字量。CLK:时钟脉冲输入端。要求时钟频率不高于640KHZ。REF(+)、REF(-):基准电压。Vcc:电源,单5V。GND:地。4. ADC0809的工作原理ADC0809的工作过程是:首先输

13、入3位地址,并使ALE=1,将地址存入地址锁存器中。此地址经译码选通8路模拟输入之一到比较器。START上升沿将逐次逼近寄存器复位。下降沿启动 AD转换,之后EOC输出信号变低,指示转换正在进行。直到AD转换完成,EOC变为高电平,指示AD转换结束,结果数据已存入锁存器,这个信号可用作中断申请。当OE输入高电平 时,输出三态门打开,转换结果的数字量输出到数据总线上。图3.3 ADC0809系统内部结构框图和外部引脚图3.4酒精传感器模块3.4.1传感器性能分析TGS822气体传感器的敏感材料是金属氧化物,最具代表性的是SnO2。金属氧化物晶体如SnO2在空气中被加热到一定高的温度时,氧被吸附在

14、的带一个负电荷的晶体表面。然后,晶体表面的供与电子被转移到吸附的氧上,结果在一个空间电荷层留下正电荷。这样,表面势能形成一个势垒,从而阻碍电子流动。在传感器的内部,电流流过SnO2微晶的结合部位(晶粒边界)。在晶粒边界,吸附的氧形成一个势垒阻止载流子自由移动,传感器的电阻即缘于这种势垒。还原性气体出现时,带有负电荷的氧的表面浓度降低,导致晶粒边界的势垒降低。降低了的势垒使传感器的阻值减小了。传感器阻值和还原性气体浓度之间的关系可由下面的一定范围气体浓度方程表示:Rs=AC-这里:Rs=传感器电阻 A=常数 C=气体浓度 =Rs曲线的斜率费加罗气体传感器的气敏素子,使用在清洁空气中电导率低的Sn

15、O2。当存在检知对象气体时,传感器的电导率随空气中气体浓度增加而增大。使用简单的电路即可将电导率的变化,转换为与该气体浓度相对应的输出信号。TGS822 传感器对酒精、有机溶剂灵敏度高,在酒精检测器等方面得到广泛使用。相同特性的 TGS823,采用了陶瓷底座,可以在200的高温气氛中使用。表3.3.1 TGS822性能参数一览表型号素子类型TGS8228系列标准封装对象气体塑料、SUS双重金属网酒精、有机溶剂检测范围505000ppm标准回路条件标准试验条件下的电学特性加热器电压VH5.0+0.2V DC/AC回路电压VCMAX 24VPs15mw负载电压加热器电压RLRH可变Ps15mw38

16、+3.0 W (室温)加热器功率PH660+50mw VH=5.0V传感器电阻RS300ppm乙醇中 1-10kW灵敏度(Rs的变化率)0.4+0.1Rs(EtOH:300ppm)Rs(EtOH:50ppm)标准试验条件试验气体条件回路条件20+2, 65+5%RHVC=10.0+0.1V DC/ACVH=5.0+0.05V DC/AC预热条件七天以上下图3.3.1中纵坐标也以传感器电阻比(Rs/Ro)表示,这里的Rs,Ro 定义如下:Rs=含300ppm 乙醇、各种温/湿度下的电阻值Ro=含300ppm 乙醇、2065%R.H.下的电阻值图3.3.1不同浓度气体对应的阻值3.3.2呼出酒精气

17、体浓度与血液酒精浓度关系表3.3.2 血液与呼气酒精含量换算一览表序 号呼出气体中酒精浓度mg/L呼出气体中酒精浓度106血液中酒精浓度mg/100mL10.022711.85520.045423.691030.068135.531540.090947.432050.113659.282560.136371.133070.159183.023580.181894.864090.2045106.7145100.2272118.5650110.2500130.4555120.2727141.2660130.2954154.1565140.3181166.0070150.3409177.897516

18、0.3636189.7280170.3863201.1585180.4091213.4390190.4318225.3395200.4515237.12100210.6618355.68150220.9091474.24200车辆驾驶人员血液中的酒精含量大于或等于80mg/100ml的驾驶行为。表3.3.2血液酒精含量临界值一览表行为类别对 象临界值(mg/100ml)饮酒驾驶车辆驾驶人员20醉酒驾驶车辆驾驶人员80由表3.3.2血液酒精含量临界值可以进行定量的分析车辆驾驶人员酒后驾驶后血液中的酒精浓度,进而对于该司机的酒驾行为类别进行定性,如血液酒精浓度低于20 mg/100ml,则认为是饮

19、酒驾驶,可以对其酌情处理;如若血液酒精浓度超过了20 mg/100ml且低于80 mg/100ml,则认为是醉酒驾驶,应按照国家交通法规对其处理。3.4 LCD显示模块1602字符型LCD通常有14条引脚线或16条引脚线的LCD,多出来的2条线是背光电源线VCC(15脚)和地线GND(16脚),其控制原理与14脚的LCD完全一样,其中:引脚 符号 功能说明1 VSS 一般接地2 VDD 接电源(+5V)3 V0 液晶显示器对比度调整端,接正电源时对比度最弱,接地电源时对比度最高(对比度过高时会产生“鬼影”,使用时可以通过一个10K的电位器调整对比度)。4 RS RS为寄存器选择,高电平1时选择

20、数据寄存器、低电平0时选择指令寄存器。5 R/W R/W为读写信号线,高电平(1)时进行读操作,低电平(0)时进行写操作。6 E E(或EN)端为使能(enable)端,下降沿使能。7 DB0 底4位三态、 双向数据总线 0位(最低位)8 DB1 底4位三态、 双向数据总线 1位9 DB2 底4位三态、 双向数据总线 2位10 DB3 底4位三态、 双向数据总线 3位11 DB4 高4位三态、 双向数据总线 4位12 DB5 高4位三态、 双向数据总线 5位13 DB6 高4位三态、 双向数据总线 6位14 DB7 高4位三态、 双向数据总线 7位(最高位)(也是busy flang)15 B

21、LA 背光电源正极16 BLK 背光 电源负极寄存器选择控制表即为ASCII码表RS R/W 操作说明0 0 写入指令寄存器(清除屏等)0 1 都busy flag(DB7),以及读取位址计数器(DB0DB6)值1 0 写入数据寄存器(显示各字型等)1 1 从数据寄存器读取数据1602液晶模块内部的字符发生存储器(CGROM)已经存储了160个不同的点阵字符图形,这些字符有:阿拉伯数字、英文字母的大小写、常用的符号、和日文假名等,每一个字符都有一个固定的代码,比如大写的英文字母“A”的代码是01000001B(41H),显示时模块把地址41H中的点阵字符图形显示出来,我们就能看到字母“A”。因

22、为1602识别的是ASCII码,试验可以用ASCII码直接赋值,在单片机编程中还可以用字符型常量或变量赋值,如A。图3.4 LCD1602外部引脚图第4章 系统软件开始设置第一行显示内容设置显示模式显示第一行内容延时延时关显示延时初始化DS18B20跳过读序列号清屏延时启动温度转换延时关显示初始化延时跳过读序列号读取温度值并计算设置第一行显示位置显示第一行内容设置第一行显示内容显示第一行内容控制ADC0809转换设置第二行显示内容读取数据比较计算显示第二行内容4.1整机系统流程图4.1.1ADC程序流程图计算读出数据初始化判断ADC是否转换完毕开始 否 否 是单片机对ADC进行初始化,使其能进

23、入正常工作状态,通过判断ADC转换判断标志EOC,看其是否转换完毕,如果没有,则继续判断,如若完成则将ADC转换的数据由单片机读取并计算,然后进入下一环节。4.1.2 LCD程序流程图判断饮酒状态开始初始化LCD写入数据判断LCD是否忙碌饮酒驾驶醉酒驾驶 是 是 否 单片机对LCD进行初始化,使其能进入正常工作状态,然后判断LCD是否处于忙碌状态,如果是则继续判断,如若不是则将从ADC转换后计算出来的结果通过输出指令输出,并判断计算出的结果处于哪种状态,并输出。附录1 酒精测试仪程序#include#includesbit rs=P24; /LCD液晶引脚定义,p0接DB0_DB7sbit r

24、w=P27;sbit ep=P26;sbit ale=P20; /ADC0809引脚定义sbit start=P37;sbit oe=P35;sbit eoc=P36;sbit adda=P25;sbit addb=P22;sbit adc=P23;sbit light=P30; /报警输出sbit DQ=P33; /DS18B20输入脚定义sbit DE=P31;unsigned char tempL=0;unsigned char tempH=0;float temperature;unsigned char code dis1=WORK START;/状态显示unsigned char

25、code dis2=ALCOHOL TEST;unsigned char code dis3=mg/100ml;unsigned char code dis4=SAFE DRIVING;unsigned char code dis5=DRINK-DRIVING;unsigned char code dis6=DRUNK DRIVING;void delay(unsigned char ms) /延时1unsigned char i,j;while(ms-)for(i=0;i250;i+)for(j=0;j50;j+)_nop_();_nop_();void delay2(unsigned in

26、t time ) /延时2unsigned int n;n=0;while (n0;i-)DQ=1;delay2(1);DQ=0;dat=1;DQ=1;if(DQ)dat|=0x80;delay2(4);return(dat);WriteOneChar(unsigned char dat) /向DS18B20写一字节数据unsigned char i=0;for(i=8;i0;i-)DQ=0;DQ=dat&0X01;delay2(5);DQ=1;dat=1;delay2(4);ReadTemperature(void) /向DS18B20读温度值Init_DS18B20();WriteOneC

27、har(0xcc);WriteOneChar(0x44);delay2(125);Init_DS18B20();WriteOneChar(0xcc);WriteOneChar(0xbe);tempL=ReadOneChar();tempH=ReadOneChar();temperature=(tempH*256)+tempL)*0.0625;delay2(200);return(temperature);main()float x,y,k;unsigned int da,n,temp1,temp2,i,gw,sw,bw,kw,xw;light=0;/数据初始化lcd_init();delay(

28、3);lcd_pos(0);i=0;while(dis1i!=0)/显示开始工作lcd_wdat(dis1i);i+;lcd_pos(0x41);i=0;while(dis2i!=0)/显示开始测试lcd_wdat(dis2i);i+;delay(32);while(1)/无限循环测试lcd_init();/初始化LCDale=0;/初始化ADC0809start=0;adda=0;/定义TGS822信号输入引脚号addb=0;adc=0;_nop_();ale=1;/启动 ADC0809start=1;_nop_();start=0;_nop_();_nop_();_nop_();_nop_

29、();_nop_();_nop_();while(eoc=0);/判断ADC0809是否转换完毕oe=1;/打开ADC0809数据锁存_nop_();da=P1;/读取转换后数据oe=0;y=(2550/da-10)/9.27;/代入传感器性质公式进行计算if(y2.68)x=61.61-4.08*y;else if(y2.38)x=139.3-33.3*y;else if(y2.23)x=218.7-66.7*y;else if(y2.128)x=288.6-98*y;else if(y2)x=262.88-85.9*y;else if(y1.89)x=254.5-81.8*y;else i

30、f(y1.62)x=450-185.2*y;else if(y1.209)x=347.1-121.7*y;lse if(y0.822)x=816.5-516.8*y;else if(y0.635)x=1279.2-1069.5*y;elsex=2238.7-2580.6*y;if(da=1000)/判断数据大小,按位输出lcd_pos(0x85);lcd_wdat(gw);lcd_pos(0x83);lcd_wdat(sw);lcd_pos(0x82);lcd_wdat(bw);lcd_pos(0x81);lcd_wdat(kw);else if(n=100)lcd_pos(0x85);lcd

31、_wdat(gw);lcd_pos(0x83);lcd_wdat(sw);lcd_pos(0x82);lcd_wdat(bw);elselcd_pos(0x85);lcd_wdat(gw);lcd_pos(0x83);lcd_wdat(sw);lcd_pos(0x86);/输出单位i=0;while(dis3i!=0)lcd_wdat(dis3i);i+;n=n/10;if(n=20 & n=100)/判断数据大小,按位输出lcd_pos(0x85);lcd_wdat(gw);lcd_pos(0x83);lcd_wdat(sw);lcd_pos(0x82);lcd_wdat(bw);lcd_pos(0x81);lcd_wdat(kw);else if(n=10)lcd_pos(0x85);lcd_wdat(gw);lcd_pos(0x83);lcd_wdat(sw);lcd_pos(0x82);lcd_wdat(bw);elselcd_pos(0x85);lcd_wdat(gw);lcd_pos(0x83);lcd_wdat(sw);lcd_pos(0x86);lcd_wdat(0xdf);lcd_pos(0x87);lcd_wdat(0x43);delay(16);

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号