LQB手打,18B20读取温度,放大一百倍

news2024/12/28 6:27:42

https://blog.csdn.net/qq_45225613/article/details/110303632?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522167798888716800215065334%2522%252C%2522scm%2522%253A%252220140713.130102334…%2522%257D&request_id=167798888716800215065334&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allsobaiduend~default-3-110303632-null-null.142v73insert_down1,201v4add_ask,239v2insert_chatgpt&utm_term=%E8%93%9D%E6%A1%A5%E6%9D%AF18b20&spm=1018.2226.3001.4187

DS18B20遵循onewire总线协议,只需一根线即可与单片机进行通讯。

onewire总线
onewire总线具体概念等这里不展开叙述,只讲比赛相关的内容。
竞赛中资源包里有头文件onewire.h和源文件oneire.c。只需进行修改即可操作DS18B20传输温度数据。

在这里插入图片描述

修改代码

以第十届(2019)的赛点资源包为例进行说明,之后的赛点资源包大概率不会变,不必过于担心。
因为赛点资源包给的是51的通信程序,而比赛用的是15单片机,在相同晶振条件下15单片机的速度是51单片机的8-12倍,所以将oneire.c里面的延迟函数统统乘以10倍。
这里给出修改完后的代码。同学们可自行进行对比。

添加代码。温度值小数实现代码如下

这里注意小数点,比赛需要显示多少个小时点


unsigned int read18b20()
{
    unsigned char low,high;
    unsigned inttemp;
    
    init_ds18b20();
    Write_DS18B20(0xcc);
    Write_DS18B20(0x44);
    Delay_OneWire(200);
    
    init_ds18b20();
    Write_DS18B20(0xcc);
    Write_DS18B20(0xbe);
    low=Read_DS18B20();
    high=Read_DS18B20();
    
//    temp=((high&0x0f)<<8)|(low);
//    temp*=6.25;
    
    temp=high&0x0f;
    temp=temp<<8;
    temp=temp|low;
    temp=temp*6.25;
    
    return temp;
    
}


这里定义使用unsigned int,代码中将温度值高八位中高四位符号位清零,默认我们温度在零上。将所有有效数字组合得到的值乘以0.0625就可以得到真实的温度值。

本人为了后面编写代码方便,直接扩大100倍,在主函数里面调用并将温度显示在数码管上时就可减少不必要的麻烦。
举个例子室温23.65°,温度传感器暂存器数据为23.65°,驱动程序返回2365°,
在主函数里数码管显示只需要将百位3的数码管点亮小数点即可。

可根据自己的需求扩大倍数。

     wendu=read18b20();
       buff[0]=tab[10];
       buff[1]=tab[10];
       buff[2]=tab[10];
       buff[3]=tab[10];
       buff[4]=tab[wendu/1000];
       buff[5]=tab[wendu/100%10]&0x7f;//添加小数点
       buff[6]=tab[wendu/10%10];
       buff[7]=tab[wendu%10];
       display();     

上面是别人的代码,我们实际使用的代码。如下:
实验目的:读取当前数据,然后显示出来在数码管上面

主函数

#include <stc15.h>
#include <intrins.h>
#include <onewire.h>
//接口
sbit S7=P3^0;
sbit S6=P3^1;
sbit S5=P3^2;
sbit S4=P3^3;
//宏定义
#define     LED       4   //定义主时钟
#define     ULN       5   //定义主时钟
#define     COM       6   //定义主时钟
#define     ABC       7   //定义主时钟
typedef     unsigned char   u8;
typedef     unsigned int    u16;
typedef     unsigned long   u32;
//-----------------------------------------------

#define FOSC 11059200L

#define T1MS (65536-FOSC/1000)      //1T模式
//#define T1MS (65536-FOSC/12/1000) //12T模式

//全局变量
u8 LEDbuf=0xFF;
u8 ULNbuf=0x00;
u8 SMGbuf[20];
u8 SMGdat[8];//8个数码管,所以8个元素

u32 tim1ms=0;//u32类型,几十天才溢出
/*************  本地常量声明   ,这是共阴的 **************/
u8 code table[]={                       //标准字库
//   0    1    2    3    4    5    6    7    8    9    A    B    C    D    E    F
    0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x77,0x7C,0x39,0x5E,0x79,0x71,
//black  -     H    J    K    L    N    o   P    U     t    G    Q    r   M    y
    0x00,0x40,0x76,0x1E,0x70,0x38,0x37,0x5C,0x73,0x3E,0x78,0x3d,0x67,0x50,0x37,0x6e,
    0xBF,0x86,0xDB,0xCF,0xE6,0xED,0xFD,0x87,0xFF,0xEF,0x46};    //0. 1. 2. 3. 4. 5. 6. 7. 8. 9. -1

u8 code T_COM[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};      //位码
//函数声明
void delayms(u16 tms);
void Delay1ms();		//@11.0592MHz
void sel(u8 x); //选择四个分支哪一个?
void sysinit();//系统初始化,关闭所有的外部设备
void disp();
//主函数
void main()
{
	//main局部变量
	
	unsigned int wendu=1025;
	//外设初始化
	  sysinit();
	
	init_ds18b20();
	read18B20();
	read18B20();
	
	//系统定时器初始化
	  AUXR |= 0x40;                   //定时器1为1T模式
    TMOD = 0x00;                    //设置定时器为模式0(16位自动重装载)
    TL1 = T1MS;                     //初始化计时值
    TH1 = T1MS >> 8;
    TR1 = 1;                        //定时器1开始计时
    ET1 = 1;                        //使能定时器0中断
    EA = 1;
	//大循环
	//这里,可以加一点测试代码,测试是不是每个外设都成功;
  	

	while(1)
	{
	  if(S7==0)
		{
			delayms(10);
			if(S7==0)
			{
			}
			while(S7==0);

		}
		
		else  if(S6==0)
		{
			delayms(10);
			if(S6==0)
			{
			  
			}
		  while(S6==0);
		
		
		}
		
		if(S5==0)
	{
	  	delayms(10);
			if(S5==0)
			{
				
			}
			while(S5==0);//松开按键
	}
	
	else	if(S4==0)
	{
	  	delayms(10);
			if(S4==0)
			{
			
			}
			while(S4==0);//松开按键
			
			
	}	
	
	  if(tim1ms%500==0)  //500ms读取一次数据,刷新数据
		{
		  
			  wendu=read18B20();  //读取温度,在这个函数里面,放大了一百倍
        SMGdat[0]= table[wendu/1000];
				SMGdat[1]= table[wendu/100%10]|0x80 ;//添加小数点
			
				SMGdat[2]=table[wendu/10%10];
			
				SMGdat[3]= table[wendu%10];
				SMGdat[4]= 0x39;  //C
				SMGdat[5]= 0x00;
			
				SMGdat[6]= 0x00;
				SMGdat[7]= 0x00;

	
		}
	 
	
	 	  

	}
	
	
	
}

//函数定义
//-----------------------------------------------

/* Timer1 interrupt routine */
void tm1_isr() interrupt 3 using 1
{
    
	  tim1ms++;
	  disp();//1ms显示一次数码管
}
void Delay1ms()		//@11.0592MHz
{
	unsigned char i, j;

	_nop_();
	_nop_();
	_nop_();
	i = 11;
	j = 190;
	do
	{
		while (--j);
	} while (--i);
}

void delayms(u16 tms)
{
	u16 i=0;
	for(i=0;i<tms;i++)
	{
		  Delay1ms();
	}
}

void sel(u8 x)  //选择四个分支哪一个?
{
	//背下来了吗?
	switch(x)
	{
		case 0:P2=P2&0x1F;break;
		case LED:P2=P2&0x1F|0x80;break;
		case ULN:P2=P2&0x1F|0xA0;break;
		case COM:P2=P2&0x1F|0xC0;break;
		case ABC:P2=P2&0x1F|0xE0;break;
	}
}
void sysinit()//系统初始化,关闭所有的外部设备
{
	sel(LED);LEDbuf=0xFF;P0=LEDbuf;sel(0);
  sel(ULN);ULNbuf=0x00;P0=ULNbuf;sel(0);
	sel(COM);P0=0x00;sel(0);
	sel(ABC);P0=0xFF;sel(0);
}


void disp()
{
	//背下来
	static u8 i=0;
	//消隐
	sel(COM);P0=0x00;sel(0);
	sel(ABC);P0=0xFF;sel(0);
//显示
	sel(COM);P0=T_COM[i];sel(0);
	sel(ABC);P0=~SMGdat[i];sel(0);
	
	i++;
	if(i>=8)i=0;
}


 

onewire.h

#ifndef __ONEWIRE_H
#define __ONEWIRE_H

unsigned char rd_temperature(void);  //; ;
unsigned int read18B20(); //放大了一百倍
#endif

onewire.c


```c
/*
  程序说明: 单总线驱动程序
  软件环境: Keil uVision 4.10 
  硬件环境: CT107单片机综合实训平台(外部晶振12MHz) STC89C52RC单片机
  日    期: 2011-8-9
*/
#include "stc15.h"

sbit DQ = P1^4;  //单总线接口

//单总线延时函数
void Delay_OneWire(unsigned int t)  //STC89C52RC
{
	t=t*12; //stc15单片机运行速度比stc89快10-12倍
	while(t--);
}

//通过单总线向DS18B20写一个字节
void Write_DS18B20(unsigned char dat)
{
	unsigned char i;
	for(i=0;i<8;i++)
	{
		DQ = 0;
		DQ = dat&0x01;
		Delay_OneWire(5);
		DQ = 1;
		dat >>= 1;
	}
	Delay_OneWire(5);
}

//从DS18B20读取一个字节
unsigned char Read_DS18B20(void)
{
	unsigned char i;
	unsigned char dat;
  
	for(i=0;i<8;i++)
	{
		DQ = 0;
		dat >>= 1;
		DQ = 1;
		if(DQ)
		{
			dat |= 0x80;
		}	    
		Delay_OneWire(5);
	}
	return dat;
}

//DS18B20设备初始化
bit init_ds18b20(void)
{
  	bit initflag = 0;
  	
  	DQ = 1;
  	Delay_OneWire(12);
  	DQ = 0;
  	Delay_OneWire(80);
  	DQ = 1;
  	Delay_OneWire(10); 
    initflag = DQ;     
  	Delay_OneWire(5);
  
  	return initflag;
}
//背下来,初始cc44初始ccbe,读低读高,高与0xF左移8位或低
unsigned int read18B20()
{
	unsigned char high,low;
	unsigned int temp;
	 init_ds18b20();
	 Write_DS18B20(0xCC); //跳过ROM
	 Write_DS18B20(0x44);//开始温度转换
	 Delay_OneWire(500);
	
	 init_ds18b20();
	 Write_DS18B20(0xCC); //跳过ROM
	 Write_DS18B20(0xBE);//开始读温度
   Delay_OneWire(500);
	
  low	 = Read_DS18B20(); //Figure7 先LSB
  high =  Read_DS18B20();//再高MSB
	temp =(high&0x0F)<<8 | low;
	
	temp=(unsigned int)(temp*6.25); //0.0625
	
	return temp;
}







本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/389146.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RCNN

1.RCNN 1.1算法流程 一张图像生成1k~2k个候选区域(使用Selective Search方法)对每个候选区域&#xff0c;使用深度网络提取特征特征送入每一类的SVM分类器&#xff0c;判断是否属于该类使用回归器精细修正候选框位置 1.候选区域的生成 利用selective Search算法通过图像分割的方…

【erlang】入门篇

欢迎入坑Erlang&#xff0c;关键字&#xff1a; 函数式&#xff0c;高并发&#xff0c;容错&#xff0c;热更新&#xff0c;分布式 安装 erlang的安装非常简单&#xff0c;直接去官网下载编译好的二进制安装包即可。需要注意的是文件名格式是OTP_平台_版本.后缀&#xff0c;其…

2021天梯赛真题题解 L1-3 强迫症 (10 分) C语言版本 整数转换为字符串数组

L1-3 强迫症 (10 分) 题目描述 小强在统计一个小区里居民的出生年月&#xff0c;但是发现大家填写的生日格式不统一&#xff0c;例如有的人写 199808&#xff0c;有的人只写 9808。有强迫症的小强请你写个程序&#xff0c;把所有人的出生年月都整理成 年年年年-月月 格式。对于…

一文说透容器跨主机网络

文章目录一、Flannel1、UDP2、VXLAN&#xff08;1&#xff09;VXLAN核心流程总结&#xff08;2&#xff09;VTEP隧道通信流程详解【1】封装 inner Ethernet header&#xff08;依据VTEP IP查MAC&#xff09;【2】设置VNI&#xff08;标识数据包应该交给那个处理设备&#xff09…

AI绘画第二步,抄作业复现超赞的效果!

上一篇&#xff0c;讲了如何安装AI绘画软件&#xff0c;但是装完后发现生成效果很渣&#xff01;而网上那些效果都很赞。真的是理想很丰满&#xff0c;现实很骨感。今天就是来聊聊如何抄作业&#xff0c;最大程度的还原那些超赞的效果。换一种说法就是&#xff0c;教大家如何使…

spark sql(一)源码分析sql解析流程

spark sql解析sql主要基于Catalyst框架&#xff0c;它将复杂的sql解析分为很多的阶段&#xff0c;每个阶段基本都有专属的工具类和扩展接口&#xff0c;最终实现将sql转换为DataFrame或RDD任务的功能。如果对于这些中间阶段和工具类没有一个整体概念性的了解&#xff0c;那阅读…

JUC并发编程与源码分析笔记11-Java对象内存布局和对象头

先从阿里及其它大厂面试题说起 你觉得目前面试&#xff0c;你还有那些方面理解的比较好&#xff0c;我没问到的&#xff0c;我说了juc和jvm以及同步锁机制那先说juc吧&#xff0c;说下aqs的大致流程cas自旋锁&#xff0c;是获取不到锁就一直自旋吗?cas和synchronized区别在哪…

国内的PMP考试通过率高达97%?

自认为是虚高&#xff0c;虽然国人在考试方面的确独树一帜的强&#xff0c;应该也没有这样夸张。 如果自学&#xff0c;大概是50%&#xff0c;如果有老师教&#xff0c;那大概是60%到80%&#xff0c;还是比较高的。 为什么自学那么低&#xff1f;除了自身的自制力的问题&…

【编程基础之Python】9、Python中的变量

【编程基础之Python】9、Python中的变量Python中的变量变量的定义和赋值变量的命名规范变量的类型变量的作用域变量的赋值特殊的变量删除变量总结Python中的变量 在Python中&#xff0c;变量是用来存储数据的一种方式。Python是一种动态类型语言&#xff0c;因此在声明变量时不…

JWT利用在ctfhub-easy_login拿到flag

目录 什么是JWT&#xff1f; jwt由三个部分组成&#xff1a;header.payload.signature header部分&#xff1a; payload部分&#xff1a;声明 signature部分&#xff1a; JWT验证过程&#xff1a; ctfhub-easy_login 目的&#xff1a;拿到flag 过程分析以及实操&#x…

阿里云轻量服务器--Docker--Nacos安装(使用外部Mysql数据存储)

前言&#xff1a;docker 安装nacos 如果不设置外部的mysql 默认使用内嵌的内嵌derby为数据源&#xff0c;这个时候如果&#xff0c;重新部署nacos 则会造成原有数据丢失情况&#xff1b; 1 默认安装的nacos 启动后使用的是内嵌的存储&#xff1a; 2 使用外部mysql 作为存储&a…

Ubuntu 18.04 出现GLIBC_2.28 not found的解决方法

关于/lib/x86_64-linux-gnu/libc.so.6: version GLIBC_2.28’ not found出现报错&#xff0c;建议不要使用源码包去编译并升级。在下文有分享一个使用官方的Debian软件包去升级使用的方法。仅供参考&#xff01; 环境 # uname -a Linux Ubuntu 5.4.0-144-generic #161~18.04.…

[1.4]计算机系统概述——操作系统的体系结构

第一章 计算机系统概述 操作系统的体系结构 大内核/单内核/宏内核微内核 通过之前的学习&#xff0c;我们知道计算机系统的层次结构是这样的。 但是操作系统的内部其实还可以再进一步地划分。 一部分是内核的功能&#xff0c;一部分是非内核的功能。 操作系统最核心的功能&…

计及需求响应的粒子群算法求解风能、光伏、柴油机、储能容量优化配置(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5;&#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密…

【云原生】Trace、Metrics、Logging 选型

背景分布式追踪的起源自从微服务的兴起开始&#xff0c;整个系统架构开始变得极为庞大和复杂&#xff0c;但是服务之间的调用关系&#xff0c;调用消耗时间等等信息却依然是半黑盒的状态。为了能够将调用的链路进行串联&#xff0c;将系统的各种指标数据展示出来以使得系统的链…

哈希->模拟实现+位图应用

致前行路上的人&#xff1a; 要努力&#xff0c;但不要着急&#xff0c;繁花锦簇&#xff0c;硕果累累都需要过程&#xff01; 目录 1. unordered系列关联式容器 1.1 unordered_map 1.1.1概念介绍&#xff1a; 1.1.2 unordered_map的接口说明 1.2unordered_set 1.3常见面试题oj…

到底什么才是幻读?

&#x1f497;推荐阅读文章&#x1f497; &#x1f338;JavaSE系列&#x1f338;&#x1f449;1️⃣《JavaSE系列教程》&#x1f33a;MySQL系列&#x1f33a;&#x1f449;2️⃣《MySQL系列教程》&#x1f340;JavaWeb系列&#x1f340;&#x1f449;3️⃣《JavaWeb系列教程》…

【NLP相关】基于现有的预训练模型使用领域语料二次预训练

❤️觉得内容不错的话&#xff0c;欢迎点赞收藏加关注&#x1f60a;&#x1f60a;&#x1f60a;&#xff0c;后续会继续输入更多优质内容❤️&#x1f449;有问题欢迎大家加关注私戳或者评论&#xff08;包括但不限于NLP算法相关&#xff0c;linux学习相关&#xff0c;读研读博…

《七》JavaScript 中的作用域、作用域链、执行上下文、执行上下文栈

JS 引擎会在执行所有代码之前&#xff0c;先在堆内存中创建一个全局对象&#xff08;Global Object、GO&#xff09;&#xff0c;包含 String、Math、Date、parseInt() 等属性和方法。所有作用域都可以访问这个全局对象。 在浏览器中 Global Object 就是 Window 对象。 执行上…

不用机器学习不用大数据,给你讲通ChatGPT的深层原理

ChatGPT现在看来已经异常火爆了&#xff0c;很多人已经熟知&#xff0c;并且开始练习使用或者开始利用他开始实践了。但仍然有很多人在观望&#xff0c;在疑惑&#xff0c;今天狗哥不用那些高端大气的机器学习亦或是大数据还给你讲通ChatGPT深层到底是个啥逻辑。 目录 1. 聊家…