找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5187|回复: 0
收起左侧

DS18B20、LCD1602的使用单片机课程设计实验报告

[复制链接]
ID:424995 发表于 2018-11-12 14:14 | 显示全部楼层 |阅读模式
课程设计实验报告

实验名称:  实验三:温度测量  
班    级:     信息工程      
实验日期:  2018年11月12日  


一、    实验目的
1.    熟练电路设计、焊接操作;
2.    熟悉STC15W408AS芯片;
3.    实现DS18B20温度测量,并用LCD1602显示;
4、显示接收的CRC校验码。

二、    实验环境
1.    焊接工具:烙铁、焊锡丝、连接线、洞洞板;
2.    元器件:STC15W408AS芯片1片、温度传感DS18B20一枚、LCD1602显示屏一枚、5k电阻一只、10k电位器一只;
3.    软件开发环境:Keil uVision5。

三、    实验题目
实验:显示一支DS18B20温度值,并显示CRC校验码。

四、    实验原理
DS18B20主要由4部分组成:64 位ROM、温度传感器、非挥发的温度报警触发器TH和TL、配置寄存器。ROM中的64位序列号是出厂前被光刻好的,它可以看作是该DS18B20的地址序列码,每个DS18B20的64位序列号均不相同。64位ROM的排的循环冗余校验码(CRC=X^8+X^5+X^4+1)。 ROM的作用是使每一个DS18B20都各不相同,这样就可以实现一根总线上挂接多个DS18B20的目的。
LCD1602是一种工业字符型液晶,能够同时显示16x02即32个字符。LCD1602液晶显示原理 LCD1602液晶显示的原理是利用液晶的物理特性,通过电压对其显示区域进行控制,有电就有显示,这样即可以显示出图形。1602液晶也叫1602字符型液晶,它是一种专门用来显示字母、数字、符号等的点阵型液晶模块。
DS18B20的1脚接GND,2脚接5K的上拉电阻、接单片机的数据端,3脚接VCC;LCD的V0口需接入10K的电位器以控制亮与暗。

五、    实验代码

六、    实验总结
在本次实验中,通过对DS18B20以及LCD1602数据手册的学习,我学会了STC15W系列单片机的软件控制LCD1602的读写以及DS18B20有关温度的测量,增强了关于单片机功能实现的理解。
  1. #include"reg51.h"
  2. #include"intrins.h"
  3. #define FOSC 11059200L            
  4. #define BAUD 9600               
  5. #define NONE_PARITY 0
  6. #define PARITYBIT NONE_PARITY   
  7. #define ds P26                    // DS18B0、
  8. #define DataPort P1                // LCD1602
  9. #define uchar unsigned char
  10. #define uint unsigned char
  11. typedef unsigned char uint_8;
  12. typedef unsigned int uint_32;
  13. typedef unsigned short int uint_16;
  14. //LCD1602
  15. sbit LCM_RS=P3^7;           
  16. sbit LCM_RW=P3^6;               
  17. sbit LCM_EN=P3^5;
  18. sbit P22 = P2^2;
  19. sbit P26 = P2^6;
  20. sfr T2H = 0xD6;
  21. sfr T2L = 0xD7;
  22. sfr AUXR = 0x8E;   
  23. unsigned char code crc_array[256] = {
  24.   0x00, 0x5e, 0xbc, 0xe2, 0x61, 0x3f, 0xdd, 0x83, 0xc2, 0x9c, 0x7e, 0x20, 0xa3, 0xfd, 0x1f, 0x41,
  25.   0x9d, 0xc3, 0x21, 0x7f, 0xfc, 0xa2, 0x40, 0x1e, 0x5f, 0x01, 0xe3, 0xbd, 0x3e, 0x60, 0x82, 0xdc,
  26.   0x23, 0x7d, 0x9f, 0xc1, 0x42, 0x1c, 0xfe, 0xa0, 0xe1, 0xbf, 0x5d, 0x03, 0x80, 0xde, 0x3c, 0x62,
  27.   0xbe, 0xe0, 0x02, 0x5c, 0xdf, 0x81, 0x63, 0x3d, 0x7c, 0x22, 0xc0, 0x9e, 0x1d, 0x43, 0xa1, 0xff,
  28.   0x46, 0x18, 0xfa, 0xa4, 0x27, 0x79, 0x9b, 0xc5, 0x84, 0xda, 0x38, 0x66, 0xe5, 0xbb, 0x59, 0x07,
  29.   0xdb, 0x85, 0x67, 0x39, 0xba, 0xe4, 0x06, 0x58, 0x19, 0x47, 0xa5, 0xfb, 0x78, 0x26, 0xc4, 0x9a,
  30.   0x65, 0x3b, 0xd9, 0x87, 0x04, 0x5a, 0xb8, 0xe6, 0xa7, 0xf9, 0x1b, 0x45, 0xc6, 0x98, 0x7a, 0x24,
  31.   0xf8, 0xa6, 0x44, 0x1a, 0x99, 0xc7, 0x25, 0x7b, 0x3a, 0x64, 0x86, 0xd8, 0x5b, 0x05, 0xe7, 0xb9,
  32.   0x8c, 0xd2, 0x30, 0x6e, 0xed, 0xb3, 0x51, 0x0f, 0x4e, 0x10, 0xf2, 0xac, 0x2f, 0x71, 0x93, 0xcd,
  33.   0x11, 0x4f, 0xad, 0xf3, 0x70, 0x2e, 0xcc, 0x92, 0xd3, 0x8d, 0x6f, 0x31, 0xb2, 0xec, 0x0e, 0x50,
  34.   0xaf, 0xf1, 0x13, 0x4d, 0xce, 0x90, 0x72, 0x2c, 0x6d, 0x33, 0xd1, 0x8f, 0x0c, 0x52, 0xb0, 0xee,
  35.   0x32, 0x6c, 0x8e, 0xd0, 0x53, 0x0d, 0xef, 0xb1, 0xf0, 0xae, 0x4c, 0x12, 0x91, 0xcf, 0x2d, 0x73,
  36.   0xca, 0x94, 0x76, 0x28, 0xab, 0xf5, 0x17, 0x49, 0x08, 0x56, 0xb4, 0xea, 0x69, 0x37, 0xd5, 0x8b,
  37.   0x57, 0x09, 0xeb, 0xb5, 0x36, 0x68, 0x8a, 0xd4, 0x95, 0xcb, 0x29, 0x77, 0xf4, 0xaa, 0x48, 0x16,
  38.   0xe9, 0xb7, 0x55, 0x0b, 0x88, 0xd6, 0x34, 0x6a, 0x2b, 0x75, 0x97, 0xc9, 0x4a, 0x14, 0xf6, 0xa8,
  39.   0x74, 0x2a, 0xc8, 0x96, 0x15, 0x4b, 0xa9, 0xf7, 0xb6, 0xe8, 0x0a, 0x54, 0xd7, 0x89, 0x6b, 0x35,
  40. };
  41. bit ack = 0;                        //DS18B20
  42. bit busy;                           
  43. uint_8 dis[4];                       
  44. void SendData(uint_8 dat)//
  45. {
  46.     while(busy);
  47.     ACC = dat;
  48.     busy = 1;
  49.     SBUF = ACC;
  50. }
  51. void Uart() interrupt 4 using 1
  52. {
  53.     if (RI)
  54.     {
  55.         uint_8 a;   
  56.         RI = 0;
  57.         a=SBUF;
  58.         P22 = RB8;
  59.     }
  60.     if (TI)
  61.     {
  62.         TI = 0;
  63.         busy = 0;
  64.     }
  65. }
  66. void lcd_printf(uint_8 *s,int temp_data)//
  67. {
  68.     *s =temp_data/1000+0x30;
  69.     temp_data=temp_data%1000;   

  70.     *++s =temp_data/100+0x30;
  71.     temp_data=temp_data%100;
  72.    
  73.     *++s =temp_data/10+0x30;
  74.     temp_data=temp_data%10;   

  75.     *++s =temp_data+0x30;
  76. }
  77. void Delay30us()        //@11.0592MHz
  78. {
  79.     unsigned char i;

  80.     _nop_();
  81.     _nop_();
  82.     i = 80;
  83.     while (--i);
  84. }
  85. void Delay100us()        //@11.0592MHz
  86. {
  87.     unsigned char i, j;

  88.     _nop_();
  89.     _nop_();
  90.     i = 2;
  91.     j = 15;
  92.     do
  93.     {
  94.         while (--j);
  95.     } while (--i);
  96. }
  97. void Delay200us()        //@11.0592MHz
  98. {
  99.     unsigned char i, j;

  100.     i = 3;
  101.     j = 35;
  102.     do
  103.     {
  104.         while (--j);
  105.     } while (--i);
  106. }
  107. void ds_reset()//DS18B20
  108. {
  109.     ds = 1;
  110.     ds = 0;
  111.     Delay200us();
  112.     Delay200us();  
  113.     ds = 1;        
  114.     Delay30us();
  115.     if(0 == ds)
  116.     {
  117.         ack = 1;
  118.     }
  119.     else
  120.     {
  121.         ack = 0;
  122.     }
  123.     Delay200us();
  124.     Delay100us();
  125. }
  126. void ds_send_byte(unsigned char byte)
  127. {
  128.     unsigned char i;
  129.    
  130.     for(i = 0; i < 8; i++)
  131.     {
  132.         ds = 0;
  133.         _nop_();
  134.         _nop_();
  135.         ds = byte & 0x01;
  136.         byte >>= 1;
  137.         Delay30us();
  138.         ds = 1;
  139.     }
  140. }
  141. bit ds_read_bit()
  142. {
  143.     bit tmp;
  144.     ds = 1;
  145.     ds = 0;
  146.     _nop_();
  147.     _nop_();
  148.     ds = 1;
  149.     tmp = ds;
  150.     Delay30us();
  151.     return tmp;
  152. }
  153. unsigned char ds_read_byte()
  154. {
  155.     unsigned char i,j,k;
  156.    
  157.     for(i = 0; i < 8; i++)
  158.     {
  159.         j = ds_read_bit();
  160.         k = (j << 7) | (k >> 1);
  161.     }
  162.     return k;
  163. }
  164. void Delay200ms()      
  165. {
  166.     unsigned char i, j, k;
  167.     _nop_();
  168.     _nop_();
  169.     i = 10;
  170.     j = 31;
  171.     k = 147;
  172.     do
  173.     {
  174.         do
  175.         {
  176.             while (--k);
  177.         } while (--j);
  178.     } while (--i);
  179. }
  180. void intsend(int value)
  181. {
  182.     uint_8 i;
  183.     lcd_printf(dis, value);           
  184.     for(i=0;i<4;i++)
  185.     {
  186.         SendData(dis[i]);
  187.     }
  188. }
  189. void WaitForEnable(void)   
  190. {                  
  191.     DataPort=0xff;      
  192.     LCM_RS=0;LCM_RW=1;_nop_();
  193.     LCM_EN=1;_nop_();_nop_();
  194.     while(DataPort&0x80);   
  195.     LCM_EN=0;               
  196. }   
  197. void WriteCommandLCM(uchar CMD,uchar A)
  198. {                  
  199.     if(A)WaitForEnable();   
  200.     LCM_RS=0;LCM_RW=0;_nop_();
  201.     DataPort=CMD;_nop_();   
  202.     LCM_EN=1;_nop_();_nop_();LCM_EN=0;
  203. }                  
  204. void InitLcd()               
  205. {           
  206.     WriteCommandLCM(0x38,1);   
  207.     WriteCommandLCM(0x08,1);   
  208.     WriteCommandLCM(0x01,1);   
  209.     WriteCommandLCM(0x06,1);   
  210.     WriteCommandLCM(0x0c,1);
  211. }
  212. void WriteDataLCM(uchar dataW)
  213. {                  
  214.     WaitForEnable();      
  215.     LCM_RS=1; LCM_RW=0;_nop_();
  216.     DataPort=dataW;_nop_();   
  217.     LCM_EN=1;_nop_();_nop_();LCM_EN=0;
  218. }      
  219. void DisplayOneChar(uchar X,uchar Y,uchar DData)
  220. {                       
  221.     Y&=1;                       
  222.     X&=15;                       
  223.     if(Y)X|=0x40;                  
  224.     X|=0x80;           
  225.     WriteCommandLCM(X,0);      
  226.     WriteDataLCM(DData);      
  227. }
  228. void DisplayListChar(uchar X,uchar Y,uchar *DData,L)//
  229. {
  230.     uchar ListLength=0;
  231.     Y&=0x1;               
  232.     X&=0xF;               
  233.     while(L--)            
  234.     {                     
  235.         DisplayOneChar(X,Y,DData[ListLength]);
  236.         ListLength++;
  237.         X++;                       
  238.     }   
  239. }
  240. void Display10BitData(int value,uchar x,uchar y,uchar wei)
  241. {
  242.     lcd_printf(dis, value);           
  243.     DisplayListChar(x,y,dis,wei);   
  244. }           
  245. unsigned char CRC8_Table(unsigned char *p, char counter)//
  246. {
  247.     unsigned char crc8 = 0;
  248.     for(; counter>0; counter--)
  249.     {
  250.         crc8 = crc_array[crc8^*p];
  251.         p++;
  252.     }
  253.     return crc8;
  254. }
  255. void main(void)
  256. {
  257.     uint_8 T_low;                //
  258.     uint_8 DU[9];                //DS16B20
  259.     uint_8 CRCC;                //
  260.     uint_16 T_high;            //
  261.     uint_16 tmp;                //
  262.     uint_8 ii;
  263.     float temperature;    //
  264.    
  265.     //LCD1602
  266.     Delay200ms();
  267.     Delay200ms();   
  268.     InitLcd();
  269.     Delay200ms();
  270.    
  271.     SCON = 0x50;
  272.     T2L = (65536 - (FOSC/4/BAUD));
  273.     T2H = (65536 - (FOSC/4/BAUD))>>8;
  274.     AUXR = 0x14;
  275.     AUXR |= 0x01;
  276.     ES = 1;
  277.     EA=1;
  278.     ACC=AUXR;

  279.     while (1)
  280.     {   
  281.          ds_reset();
  282.         ds_send_byte(0xcc);
  283.         ds_send_byte(0x44);
  284.         ds_reset();
  285.         ds_send_byte(0xcc);
  286.         ds_send_byte(0xbe);               
  287.         DU[0] = ds_read_byte();
  288.         DU[1] = ds_read_byte();
  289.        DU[2] = ds_read_byte();                            //0075
  290.        DU[3] = ds_read_byte();                            //0070
  291.         DU[4] = ds_read_byte();                            //0127
  292.        DU[5] = ds_read_byte();                            //0255   
  293.         DU[6] = ds_read_byte();
  294.        DU[7] = ds_read_byte();
  295.         DU[8] = ds_read_byte();
  296.             CRCC=CRC8_Table(DU,8);                              
  297.             T_low = DU[0];                                   
  298.             T_high = DU[1];                                   
  299.        tmp = (T_high << 8) | T_low;                  
  300.         temperature = (float)tmp * 0.0625;               
  301.         intsend((int)(temperature));                                    DisplayListChar(0,0,"Temp:",5);                                Display10BitData((int)(temperature*100),5,0,2);   
  302.     DisplayOneChar(0,0,'.');                       
  303.         temperature=temperature-(int)temperature;      
  304.         temperature*=100;                              
  305.     Display10BitData((int)(temperature*100),8,0,2);      
  306.     DisplayOneChar(0,0,'C');                       
  307.     Display10BitData(CRCC*10,7,1,3);               
  308.     Display10BitData(DU[8]*10,12,1,3);               
  309.                
  310.         Delay200ms();
  311.     }
  312. }
复制代码

完整的Word格式文档51黑下载地址:
温度测量实验.docx (33.63 KB, 下载次数: 19)
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表