毕业设计(论文)-基于AT89C51单片机的数字温度计设计.doc_第1页
毕业设计(论文)-基于AT89C51单片机的数字温度计设计.doc_第2页
毕业设计(论文)-基于AT89C51单片机的数字温度计设计.doc_第3页
毕业设计(论文)-基于AT89C51单片机的数字温度计设计.doc_第4页
毕业设计(论文)-基于AT89C51单片机的数字温度计设计.doc_第5页
已阅读5页,还剩26页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

烟台汽车工程职业学院学生毕业论文数字温度计设计学生姓名: 入学时间: 2008年9月 专业名称: 电子信息工程技术 班 级: 08电子信息一班 指导教师: 职 称: 讲 师 烟台汽车工程职业学院二一一年五月摘 要随着现代信息技术的飞速发展和传统工业改造的逐步实现,能够独立工作的温度检测与显示系统应用于诸多领域。传统的温度检测以热敏电阻为温度敏感元件。热敏电阻的成本低,需要外加信号处理电路,而且可靠性相对较差,测温准确度低,检测系统也有一定的误差。与传统的温度计相比,这次设计的是基于ds18b20的数字温度计,它具有读数方便,测温范围广,测温精确,数字显示,适用范围宽等特点。在本设计中选用at89c51型单片机作为主控制器件,采用ds18b20数字温度传感器作为测温元件,通过4位共阳极led数码显示管并行传送数据,实现温度显示。本设计的内容主要分为两部分,一是对系统硬件部分的设计,包括温度采集电路和显示电路;二是对系统软件部分的设计,应用c语言实现温度的采集与显示。通过ds18b20直接读取被测温度值,送入单片机进行数据处理,之后进行输出显示,最终完成了数字温度计的总体设计。其系统构成简单,信号采集效果好,数据处理速度快,便于实际检测使用。关键词:单片机at89c51;温度传感器ds18b20;led数码管;数字温度计目 录0 前言11 数字温度计设计的可行性分析21.1数字温度计设计方案论证21.1.1方案一21.1.2方案二21.2单线技术22 系统的硬件设计42.1核心处理器的设计42.1.1 at89c51简介42.1.2复位电路的设计72.1.3晶振电路的设计82.2温度采集电路设计82.2.1 ds18b20简介92.2.2 ds18b20的内部结构102.2.2 ds18b20的测温原理132.3显示电路的设计162.3.1 led数码管162.3.2显示电路173 系统的软件设计183.1 ds18b20的单线协议和命令183.1.1初始化183.1.2 rom操作命令183.1.3 内存操作命令193.1.4 数据处理203.2温度采集程序设计213.3温度显示程序设计234 结束语24参考文献25致 谢26烟台汽车工程职业学院 数字温度计设计0 前言在日常生活及工业生产过程中,经常要用到温度的检测及控制,温度是生产过程和科学实验中普遍而且重要的物理参数之一。在生产过程中,为了高效地进行生产,必须对它的主要参数,如温度、压力、流量等进行有效的控制。温度控制在生产过程中占有相当大的比例。温度测量是温度控制的基础,技术已经比较成熟。传统的测温元件有热电偶和二电阻。而热电偶和热电阻测出的一般都是电压,再转换成对应的温度,这些方法相对比较复杂,需要比较多的外部硬件支持1。我们用一种相对比较简单的方式来测量。随着国民经济的发展,人们需要对各中加热炉、热处理炉、反应炉和锅炉中温度进行监测和控制。采用单片机来对他们控制不仅具有控制方便,简单和灵活性大等优点,而且可以大幅度提高被控温度的技术指标,从而能够大大的提高产品的质量和数量。本设计主要介绍了用单片机和数字温度传感器ds18b20相结合的方法来实现温度的采集,以单片机at89c51芯片为核心,辅以温度传感器ds18b20和led数码管及必要的外围电路,构成了一个多功能单片机数字温度计。该装置适用于人民的日常生活和工、农业生产的温度测量与报警,实现对温度的监测。其主要研究内容包括两方面,一是对系统硬件部分的设计,包括温度采集电路和显示电路;二是对系统软件部分的设计,应用c语言实现温度的采集与显示。通过利用数字温度传感器ds18b20进行设计,能够满足实时检测温度的要求,同时通过led数码管的显示功能,可以实现不间断的温度显示,并带有复位功能。本次设计的主要思路是利用51系列单片机,数字温度传感器ds18b20和led数码显示器,构成实现温度检测与显示的单片机控制系统,即数字温度计。通过对单片机编写相应的程序,达到能够实时检测周围温度的目的。11 数字温度计设计的可行性分析1.1数字温度计设计方案论证1.1.1方案一由于本设计实现的是测温电路,首先我们可以使用热敏电阻之类的器件,利用其感温效应,将其随被测温度变化的电压或电流值采集过来,进行a/d转换后,就可以用单片机进行数据的处理,通过显示电路就可以将被测温度显示出来,这种设计需要用到a/d转换电路,感温电路比较麻烦。因此,我们引出第二种方案。1.1.2方案二我们可以采用技术成熟、操作简单、精确度高的温度传感器,在此,可以选用数字温度传感器ds18b20,根据它的特点和测温原理,很容易就能直接读取被测温度值并进行转换,这样就可以满足设计要求。从以上两种方案,很容易看出,采用方案二,电路比较简单,软件设计也比较简单,故在本设计中采用了方案二。通过方案二设计的温度计总体电路图如附录图c所示,控制器采用单片机at89c51,温度传感器采用ds18b20,用4位led数码管以串口并行输出方式传送数据实现温度显示。1.2单线技术目前,常用的微机和外设之间数据传输的串行总线3有i2c总线、spi总线等,其中i2c总线采用同步串行双线(一根时钟线,一根数据线)方式,而spi总线采用同步串行三线(时钟线,输入线,数据输入线)方式。这两种总线需要至少两根或两根以上的信号线。美国达拉斯半导体公司推出了一项特有的单线技术。该技术于上述总线不同,它采用单根信号线,即可传输时钟,又能传输数据,而且数据传输时是双向的,因而这种单线技术具有线路简单,硬件开销少,成本低廉。便于扩展的优点。单线技术适用以单主机系统,单主机能够控制一个或多个从机设备。主机可以是微控制器,从机可以是单线器件,它们之间的数据交换,控制都由这根线完成。主机或从机通过一个漏极开路或三态端口连至该数据线,以允许设备在不发送数据时能够释放线,而让其它设备使用。单线通常要求外接一个约5k的上拉电阻,这样,当该线闲置时,器件状态为高电平。主机和从机之间的通信主要分为3个步骤:初始化单线器件,识别单线器件和单线数据传输。由于只有一根线通信,所以它们必须是严格的主从结构,只有主机呼叫从机时,从机才能应答,主机访问每个单线器件都必须严格遵循单线命令序列,从机遵守上述三个步骤的顺序。如果命令序列混乱,单线器件将不会响应主机。所有的单线器件都有遵循严格的协议,以保证数据的完整性。单线协议有复位脉冲,其他均由主机发起,并且所有命令和数据都是字节的地位在前。272 系统的硬件设计2.1核心处理器的设计2.1.1 at89c51简介对于单片机的选择,可以考虑使用8031与8051系列,由于8031没有内部ram,系统又需要大量内存存储数据,因而不适用。所以,我们选用51系列单片机at89c51。at89c51是美国atmel公司生产的低功耗,高性能cmos8位单片机,片内含4kbytes的可编程的flash只读程序存储器,兼容标准8051指令系统及引脚,并集成了 flash 程序存储器,既可在线编程(isp),也可用传统方法进行编程,因此,低价位at89c51单片机可应用于许多高性价比的场合,可灵活应用于各种控制领域,对于简单的测温系统已经足够。单片机at89c51具有低电压供电和体积小等特点,四个端口只需要两个口就能满足电路系统的设计需要,很适合便携手持式产品的设计使用系统可用二节电池供电2。at89c51的主要特性如下: (1)与msc-51兼容;(2)4k字节可编程闪烁存储器;(3)寿命:1000写、檫循环;(4)数据保留时间:10年;(5)全静态工作时间:0hz-24hz(6)三级程序存储器锁定;(7)128*8为内存ram;(8)32根可编程i/o线;(9)两个16位定时器/计数器;(10)5个中断源;(11)可编程串行通道;(12)低功耗的闲置和掉电模式;(13)片内振荡器和时钟电路;1、at89c51引脚图芯片at89c51的引脚排列和逻辑符号如图2.1所示。图 2.1 at89c51单片机引脚图2、at89c51引脚功能介绍单片机芯片at89c51为40引脚双列直插式封装。其各个引脚功能4介绍如下:(1) vcc:供电电压;(2) gnd:接地;(3) p0口p0口为一个8位漏级开路双向i/o口,每个管脚可吸收8ttl门电流。当p1口的管脚写”1”时,被定义为高阻输入。p0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在flash编程时,p0口作为原码输入口,当flash进行校验时,p0输出原码,此时p0外部电位必须被拉高。(4) p1口p1口是一个内部提供上拉电阻的8位双向i/o口,p1口缓冲器能接收输出4ttl门电流。p1口管脚写入”1”后,电位被内部上拉为高,可用作输入,p1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在flash编程和校验时,p1口作为第八位地址接收。(5) p2口p2口为一个内部上拉电阻的8位双向i/o口,p2口缓冲器可接收,输出4个ttl门电流,当p2口被写”1”时,其管脚电位被内部上拉电阻拉高,且作为输入。作为输入时,p2口的管脚电位被外部拉低,将输出电流,这是由于内部上拉的缘故。p2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,p2口输出地址的高八位。在给出地址”1”时,它利用内部上拉的优势,当对外部八位地址数据存储器进行读写时,p2口输出其特殊功能寄存器的内容。p2口在flash编程和校验时接收高八位地址信号和控制信号。(6) p3口p3口管脚是8个带内部上拉电阻的双向i/o口,可接收输出4个ttl门电流。当p3口写入”1”后,它们被内部上拉为高电平,并用作输入。作为输入时,由于外部下拉为低电平,p3口将输出电流(ill),也是由于上拉的缘故。p3口也可作为at89c51的一些特殊功能口,同时p3口同时为闪烁编程和编程校验接收一些控制信号。其具体功能如表2.1所示。表2.1 p3口特殊功能介绍端口定义符号表示功能描述p3.0rxd串行输入口p3.1txd串行输出口p3.2int0外部中断0p3.3int1外部中断1p3.4t0定时器0外部输入p3.5t1定时器1外部输入p3.6wr外部数据存储器写选通p3.7rd外部数据存储器读选通(7) rst:复位输入端。当振荡器复位时,要保持rst脚两个机器周期的高电平时间。(8) ale / prog当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在flash编程期间,此引脚用于输入编程脉冲。在平时,ale端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ale脉冲。如想禁止ale的输出可在sfr8eh地址上置0。此时,ale只有在执行movx,movc指令时ale才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ale禁止,置位无效。(9) psen外部程序存储器的选通信号。在由外部程序存储器取址期间,每个机器周期psen两次有效。但在访问外部数据存储器时,这两次有效的psen信号将不出现。(10) ea/vpp当ea保持低电平时,访问外部rom;注意加密方式1时,ea将内部锁定为reset;当ea端保持高电平时,访问内部rom。在flash编程期间,此引脚也用于施加12v编程电源(vpp)。(11) xtal1:反向振荡放大器的输入及内部时钟工作电路的输入。(12) xtal2:来自反向振荡器的输出。2.1.2复位电路的设计单片机复位电路的设计如图2.2所示。该复位电路采用手动复位与上电复位相结合的方式。当按下按键s1时,vcc通过r1电阻给复位输入端口一个高电平,实现复位功能,即手动复位。上电复位就是vcc通过电阻r2和电容c构成回路,该回路是一个对电容c充电和放电的电路,所以复位端口得到一个周期性变化的电压值,并且有一定时间的电压值高于cpu复位电压,实现上电复位功能5。图2.2 单片机复位电路2.1.3晶振电路的设计单片机晶振电路的设计如图2.3所示。xtal1(x1)为反向振荡放大器的输入及内部时钟工作电路的输入。xtal2(x2)是来自反向振荡器的输出。按照理论上at89c51使用的是12mhz的晶振,但实测使用11.0592mhz。所以设计者通常用的是11.0592mhz。2.2温度采集电路设计由于传统的热敏电阻等测温元件测出的一般都是电压,再转换成对应的温度,需要比较多的外部元件支持,且硬件电路复杂,制作成本相对较高。这里采用dallas公司的数字温度传感器ds18b20作为测温元件。图2.3 单片机晶振电路2.2.1 ds18b20简介dallas 最新单线数字温度传感器ds18b20是一种新型的”一线器件”,其体积更小、更适用于多种场合、且适用电压更宽、更经济。dallas 半导体公司的数字化温度传感器ds18b20是世界上第一片支持”一线总线”接口的温度传感器。温度测量范围为-55+125 摄氏度,可编程为9位12 位转换精度,测温分辨率可达0.0625摄氏度,分辨率设定参数以及用户设定的报警温度存储在eeprom 中,掉电后依然保存。被测温度用符号扩展的16位数字量方式串行输出;其工作电源既可以在远端引入,也可以采用寄生电源方式产生;多个ds18b20可以并联到3 根或2 根线上,cpu只需一根端口线就能与诸多ds18b20 通信,占用微处理器的端口较少,可节省大量的引线和逻辑电路。因此用它来组成一个测温系统,具有线路简单,在一根通信线,可以挂很多这样的数字温度计,十分方便6。ds18b20 的性能特点如下: (1)独特的单线接口方式,ds18b20在与微处理器连接时仅需要一条总线即可实现微处理器与ds18b20的双向通讯;(2)ds18b20支持多点组网功能,多个ds18b20可以并联在唯一的三线上,实现组网多点测温;(3)ds18b20在使用中不需要任何外围元件,全部传感元件及转换电路集成在形如一只三极管的集成电路内;(4)适应电压范围更宽,电压范围:3.05.5v,在寄生电源方式下可由数据线供电;(5)测温范围-55125,在-10+85时精度为0.5;(6)零待机功耗;(7)可编程的分辨率为912位,对应的可分辨温度分别为0.5、0.25、0.125和0.0625,可实现高精度测温;(8)在9位分辨率时最多在93.75ms内把温度转换为数字,12位分辨率时最多在750ms内把温度值转换为数字,速度更快;(9)用户可定义报警设置;(10)报警搜索命令识别并标志超过程序限定温度(温度报警条件)的器件;(11)测量结果直接输出数字温度信号,以一线总线串行传送给cpu,同时可传送crc校验码,具有极强的抗干扰纠错能力;(12)负电压特性,电源极性接反时,温度计不会因发热而烧毁,但不能正常工作。以上特点使ds18b20非常适用与多点、远距离温度检测系统。ds18b20内部结构主要由四部分组成:64位光刻rom、温度传感器、非挥发的温度报警触发器th和tl、配置寄存器。ds18b20的管脚排列、各种封装形式如图 3.4 所示。其中,dq 为数据输入/输出引脚,也可用作开漏单总线接口引脚,当被用在寄生电源工作方式下,可以向器件提供电源;gnd为地信号;vdd为可选择的电源引脚,当工作于寄生电源时,此引脚必须接地。其电路图2.4所示。2.2.2 ds18b20的内部结构图2.4为ds1820的内部结构框图,它主要包括寄生电源、温度传感器、64位激光rom单线接口、存放中间数据的高速暂存器(内含便笺式ram),用于存储用户设定的温度上下限值的th和tl触发器存储与控制逻辑、8位循环冗余校验码(crc)发生器等七部分。ds18b20采用3脚pr35封装或8脚soic封装。其中,64 bit闪速rom的结构如下:8bit 校验crc48bit 序列号8bit 工厂代码(10h)msb lsbmsb lsbmsb lsb开始的8位是产品类型的编号,接着是每个器件的惟一的序号,共有48 位,最后8位是前面56 位的crc 检验码,这也是多个ds18b20可以采用一线进行通信的原因。温度报警触发器th和tl,可通过软件写入户报警上下限。图2.4 ds18b20内部结构框图温度传感器ds18b20的内部存储器还包括一个高速暂存ram和一个非易失性的可电擦除的eeram。高速暂存ram的结构为8字节的存储器,结构如图2.5所示。图2.5高速暂存ram结构图其中,前2个字节包含测得的温度信息,第3和第4字节th和tl的拷贝,是易失的,每次上电复位时被刷新。第5个字节,为配置寄存器,它的内容用于确定温度值的数字转换分辨率。ds18b20工作时寄存器中的分辨率转换为相应精度的温度数值。暂存存储器的第5个字节是配置寄存器,可以通过相应的写命令进行配置,其内容如下:0r1r0111111msb lsb其中r0和r1是温度值分辨率位,可按表2.2进行配置。表2.2温度值分辨率配置表r1r0分辨率最大转换时间(ms)009位93.75ms(tconv/8)0110位183.50ms(tconv /4)1011位375ms(tconv /2)1112位750ms(tconv)当ds18b20接收到温度转换命令后,开始启动转换。转换完成后的温度值就以16位带符号扩展的二进制补码形式存储在高速暂存存储器的第1、2字节。单片机可通过单线接口读到该数据,读取时低位在前、高位在后,数据格式以0.0625/lsb形式表示。温度值格式如下:低232221202-12-22-32-4高sssss262524msb lsb这是12位转化后得到的12位数据,存储在ds18b20的两个8比特的ram中,二进制中的前面5位是符号位,如果测得的温度大于0,这5位为0,只要将测到的数值乘于0.0625即可得到实际温度;如果温度小于0,这5位为1,测到的数值需要取反加1再乘于0.0625即可得到实际温度。格式中,s表示位。对应的温度计算:当符号位s=0时,表示测得的温度植为正值,直接将二进制位转换为十进制;当s=1时,表示测得的温度植为负值,先将补码变换为原码,再计算十进制值。例如+125的数字输出为07d0h,+25.0625的数字输出为0191h,-25.0625的数字输出为ff6fh,-55的数字输出为fc90h。ds18b20温度传感器主要用于对温度进行测量,数据可用16位符号扩展的二进制补码读数形式提供,并以0.0625/lsb形式表示。表2.3是部分温度值对应的二进制温度表示数据。表2.3部分温度的二进制表示温度数字输出(二进制)数字输出(16进制)+12500000111 1101000007d0h+8500000101 010100000550h+25.062500000001 100100010191h+10.12500000000 1010001000a2h+0.500000000 000010000008h000000000 000000000000h-0.511111111 11111000fff8h-10.12511111111 01011110ffe5h-25.062511111110 01101111ff6fh-5511111100 10010000fc90hds18b20完成温度转换后,就把测得的温度值与ram中的th、tl字节内容作比较,若tth或ttl,则将该器件内的告警标志置位,并对主机发出的告警搜索命令作出响应。因此,可用多只ds18b20同时测量温度并进行告警搜索。在64位rom的最高有效字节中存储有循环冗余校验码(crc)。主机根据rom的前56位来计算crc值,并和存入ds18b20中的crc值做比较,以判断主机收到的rom数据是否正确。2.2.2 ds18b20的测温原理ds18b20的测温原理如图2.8所示,图中低温度系数晶振的振荡频率受温度的影响很小用于产生固定频率的脉冲信号送给减法计数器1,高温度系数晶振随温度变化其震荡频率明显改变,所产生的信号作为减法计数器2的脉冲输入,图中还隐含着计数门,当计数门打开时,ds18b20就对低温度系数振荡器产生的时钟脉冲后进行计数,进而完成温度测量.计数门的开启时间由高温度系数振荡器来决定,每次测量前,首先将-55所对应的基数分别置入减法计数器1和温度寄存器中,减法计数器1和温度寄存器被预置在-55所对应的一个基数值。图2.6 外部封装形式 图2.7 传感器电路图图2.8 ds18b20测温原理图减法计数器1对低温度系数晶振产生的脉冲信号进行减法计数,当减法计数器1的预置值减到0时温度寄存器的值将加1,减法计数器 1的预置将重新被装入,减法计数器1重新开始对低温度系数晶振产生的脉冲信号进行计数,如此循环直到减法计数器2计数到0时,停止温度寄存器值的累加,此时温度寄存器中的数值即为所测温度。图2.6中的斜率累加器用于补偿和修正测温过程中的非线性其输出用,于修正减法计数器的预置值,只要计数门仍未关闭就重复上述过程,直至温度寄存器值达到被测温度值,这就是ds18b20的测温原理。另外,由于ds18b20单线通信功能是分时完成的,它有严格的时间概念,因此读写时序很重要。系统对ds18b20的各种操作必须按协议进行。操作协议为:初始化ds18b20(发复位脉冲)发rom功能命令发存储器操作命令处理数据。在正常测温情况下,ds18b20的测温分辨力为0.5,可采用下述方法获得高分辨率的温度测量结果:首先用ds18b20提供的读暂存器指令(beh)读出以0.5为分辨率的温度测量结果,然后切去测量结果中的最低有效位(lsb),得到所测实际温度的整数部分tz,然后再用beh指令取计数器1的计数剩余值cs和每度计数值cd。实际温度ts可用式(2.1)计算:ts=(tz-0.25)+(cd-cs)/cd (2.1)设计的温度采集电路如图2.9所示。图2.9 温度采集电路图2.3显示电路的设计2.3.1 led数码管led数码管,也叫led数码显示器,由于它具有很高的性能价格比、显示清晰、亮度高、使用方便、电路简单、寿命长等诸多优点,长期以来一直在各类电子产品和工程控制中得到非常广泛的应用。在单片机控制系统中,因为单片机的硬件简单、灵活等特点,非常适合使用led数码管作为其输出设备,这样既满足了控制系统硬件简单,又能如实地显示被控系统的温度、压力、流量、高度等一些单片机的处理结果。led数码管的基本组成是半导体发光二极管,它是将若干个发光二极管,按照一定的笔段组合起来构成的一个整体。led数码管能显示09十个数字及部份英文字母。常见的八段led数码管结构如图2.10所示。图2.10 数码管的内部结构它由8个发光二极管组成,其中7个长条形的发光二极管排列成”日”字形,另一个发光二极管在整个数码管的右下角,用来显示小数点。根据8个发光二极管的不同连接形式,可以将led数码管分成共阳极和共阴极两种。将8个发光二极管的阳极都连在一起的,称之为共阳极led数码管;将8个发光二极管的阴极都连在一起的,称之为共阴极led数码管。共阴极和共阳极结构的led数码管各笔段名和安排位置是相同的。当发光二极管导通时,相应的笔段发亮,由发亮的笔段组合成09十个数字及部分英文字母。这里我们以共阴极led数码管为例,当让其显示数字”3”时,只要a、b、c、d、g段的发光二极管点亮,e、f、dp段的发光二极管不亮,即a、b、c、d、g段发光二极管的阳极加上高电平”1”, e、f、dp段发光二极管的阳极加上低电平”0”,同时使led数码管的公共阴极接低电平”0”,则led数码管此时就能显示数字”3”。如果加到各笔段对应发光二极管阳极上的代码不同,则就能控制led数码管显示不同的字符和数字,这个代码称为段码。通常将这个段码用单片机系统中的一个字节进行存储,正好这个字节中的8个二进制位(d7、d6、d5、d4、d3、d2、d1、d0),依次对应led数码管的8个笔段dp、g、f、e、d、c、b、a。2.3.2显示电路显示电路采用4个共阴极led数码管,从p1口并行输出温度段码,用p3.0p3.3四个端口输出选择脉冲,控制数码管的点亮。其具体电路图如图2.11所示。图2.11 显示电路其工作过程如下:(1)并行数据由p1口送至4个数码管。(2)这时p3.0、p3.1、p3.2、p3.3轮流输出低电平,led数码管依次被点亮,显示p1传送来的数据。由于数码管余辉效应和人眼的视觉延迟,当数码管每秒点亮50次时,就会出现静止显示的温度值。3 系统的软件设计软件设计关键在于ds18b20的使用。ds18b20属于单线式器件,它在一根数据线上实现数据的双向传输,这就需要一定的协议,来对读写数据提出严格的时序要求,而at89c51单片机并不支持单线传输,因此必须采用软件的方法来模拟单线的协议时序。3.1 ds18b20的单线协议和命令ds18b20有严格的通信协议来保证各为数据传输的正确性和完整性。主机操作单线器件ds18b20必须遵循下面的顺序。3.1.1初始化单线总线上的所有操作都是从初始化开始的。过程如下:1、请求主机通过拉低单线480us以上,产生复位脉冲,然后释放该线,进入rx接收模式。主机释放总线时,会产生一个上升沿脉冲。2、响应ds18b20检测到该上升沿后,延时1560us,通过拉低总线60240us来产生应答脉冲。3、接收响应主机接收到从机的应答脉冲后,说明有单线器件在线。至此,初始化完成。3.1.2 rom操作命令当主机检测到应答脉冲,便可发起rom操作命令。共有5类rom操作命令,如表3.1所示。表3.1 rom操作命令指令类型命令字节功能说明read rom读rom33h读取激光rom中的64位,只能用于总线上单个ds18b20器件情况,多挂时会发生数据冲突;match rom匹配rom55h此命令后跟64位rom序列号,寻址多挂总线上的对应ds18b20,只有序列号完全匹配的ds18b20才能响应后面的内存操作命令,其他不匹配的将等待复位脉冲,可用于单挂或多挂两种情况;skip rom跳过romcch可无须提供64位rom序列号即可运行内存操作命令,只能用于单挂;search rom搜索romf0h通过一个排除法过程,识别出总线上所有器件的rom序列号;alarmsearch报警搜索ech命令流程与search rom相同,但ds18b20只有最近的一次温度测量时满足了报警触发条件的,才会响应此命令。3.1.3 内存操作命令在成功执行rom操作命令后,才可使用内存操作命令。共有6种内存操作命令,如表3.2所示。表3.2内存操作命令指令类型命令字节功能说明write scratchpad写暂存器4eh写暂存器中地址2地址4的3个字节(th,tl和配置寄存器)在发起复位脉冲之前,3个字节都必须要写;read scratchpad读暂存器beh读取暂存器内容,从字节0一直到字节8,共9个字节,主机可随时发起复位脉冲,停止此操作,通常我们只需读前5个字节;copy scratchpad复制暂存器48h将暂存器中的内容复制进eeram,以便将温度告警触发字节存入非易失内存,如果此命令后主机产生读时隙,那么只要器件还在进行复制都会输出0,复制完成后输出1;convert t温度转换44h开始温度转换操作,若在此命令后主机产生时隙,那么只要器件还在进行温度转换就会输出0,转换完成后输出1;recall e2重调e2暂存器b8h将存储在eeram中的温度告警触发值和配置寄存器值重新拷贝到暂存器中,此操作在ds18b20加电时自动产生;read power supply读供电方式b4h主机发起此命令后每个读数时隙内,ds18b20会发信号通知它的供电方式:0寄生电源,1外部供电。3.1.4 数据处理ds18b20要求有严格的时序来保证数据的完整性。在单线dq上存在复位脉冲、应答、写”0”、写”1”读”0”和读”1”几种型号类型,其中除了应答脉冲以外,均有主机产生7。1、ds18b20的复位时序图3.1 ds18b20的复位时序数据位的读和写则是通过使用读、写是时序实现的。首先来看写时序,时序图如图3.2所示。当主机将数据线从高电平拉至低电平时产生写时序。有两种类型的写时序:写”1”和写”0”。所有写时序必须在60us以上(即有高拉低后持续60us以上),各个写时序之间必须保证最短1us的恢复时间。ds18b20在dq线变低后的15us至60us的窗口时间内对dq线进行采样,如果为高电平就写为”1”,如果为低电平就写为”0”。对于主机产生写”1”时隙的情况,数据线必须先被拉低,然后释放,在写时序开始后的15us内允许dq线拉至高电平。对于主机产生写”0”时隙的情况,dq线必须被拉至低电平且至少保持低电平60us的时间。图3.2写时序再来看读时序,时序图如图3.3所示。当主机从ds18b20读数据时,把数据线从高电平拉至低电平,产生读时序数据线dq必须保持低电平至少1us,来自ds18b20的输出数据在读时序下降沿之后15us内有效,因此在此15us内,主机必须停止将dq引脚置低。在读时序结束时,dq引脚将通过外部上拉电阻拉回至高

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论