基于51单片机的铂电阻PT100温度计proteus仿真

在这里插入图片描述

#include <REGX51.H>
#include <intrins.h>

#define Disdata P0
#define discan P2

sbit adrd=P3^7;          //IO口定义
sbit adwr=P3^6;
sbit csad=P3^4;
sbit  DIN=P0^7;       //LED小数点控制

unsigned char j,k,ad_data,t;
unsigned char dis[4]={0x00,0x00,0x00,0x00};

unsigned char code dis_7[12]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x40};
            
unsigned char code  scan_con[4]={0xfe,0xfd,0xfb,0xf7};      // 列扫描控制字    

void delay(unsigned int t)  
{  
  for(;t>0;t--)
  {
    ;
  }  
}  //11微秒延时函数

void scan()  
{  
   char k;      
   
   for(k=0;k<4;k++)        //四位LED扫描控制       
   {        
     Disdata=dis_7[dis[k]];        
	 if(k==1)
	 {
	   DIN=1;				  //加入小数点
	 }        
	 discan=scan_con[k];
	 delay(90);
	 discan=0xff;       
   }   
}
void ad0804()
{
  P1=0xff;              //读取P1口之前先给其写全1
  csad=0;               //选通ADCS
  adrd=0;               //AD读使能
  ad_data=P1;			//AD数据读取赋给P1口
  adrd=1;
  csad=1;               //关闭ADCS
  adwr=0;
}

void ad_compute()       //u=2.55+T/100, 2.55反映在AD上为0x83
{
  unsigned char t_temp;
    ad_data=ad_data-0x83;
    t_temp=ad_data*2-4;
	if(t_temp<=200)
	{
	 dis[3]=t_temp/100;
	 dis[2]=t_temp/10-dis[3]*10;
	 dis[1]=t_temp%10;
	 dis[0]=t%5*2;
	}
	else
	{
	  t_temp=256-t_temp;
      dis[3]=11;
      dis[2]=t_temp/10;
      dis[1]=t_temp%10;
      dis[0]=t%5*2;
	}
} 
void main()		//	主程序
{
  while(1)
  {
    ad0804();
	ad_compute();
	scan();
  }
}

链接:https://pan.baidu.com/s/1iFlHs2nka_32RpiBrqnF7Q
提取码:qdil

  • 9
    点赞
  • 99
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是基于51单片机PT100热敏电阻温度计的代码: ``` #include <reg51.h> #include <intrins.h> #define uchar unsigned char #define uint unsigned int sbit DQ = P1^0; // 定义DS18B20数据线 uchar code table[] = {0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f}; // 数码管显示表 uchar tempH, tempL; // 温度值的高位和低位 uchar temp; // 温度值 void delay(uint ms) { // 延时函数 uint i, j; for (i = 0; i < ms; i++) { for (j = 0; j < 110; j++); } } void init_ds18b20() { // 初始化DS18B20 uchar i; DQ = 1; delay(1); DQ = 0; delay(500); DQ = 1; delay(60); i = DQ; delay(500); } void write_byte(uchar dat) { // 写一个字节 uchar i; for (i = 0; i < 8; i++) { DQ = 0; _nop_(); DQ = dat & 0x01; delay(5); DQ = 1; dat >>= 1; } } uchar read_byte() { // 读一个字节 uchar i, dat = 0; for (i = 0; i < 8; i++) { dat >>= 1; DQ = 0; _nop_(); DQ = 1; if (DQ) { dat |= 0x80; } delay(5); } return dat; } void read_temp() { // 读取温度值 init_ds18b20(); write_byte(0xcc); // 跳过ROM操作 write_byte(0x44); // 启动温度转换 delay(100); init_ds18b20(); write_byte(0xcc); // 跳过ROM操作 write_byte(0xbe); // 读取温度寄存器 tempL = read_byte(); // 读取低位 tempH = read_byte(); // 读取高位 temp = (tempH << 8) | tempL; // 合成温度值 } void main() { while (1) { read_temp(); temp = temp * 0.0625; // 转换为实际温度值 P2 = table[temp / 10]; // 显示十位 P3 = 0xfe; // 选中个位 delay(1); P3 = 0xff; // 取消选中 P2 = table[temp % 10]; // 显示个位 P3 = 0xfd; // 选中十位 delay(1); P3 = 0xff; // 取消选中 } } ``` 以上代码中,使用了DS18B20来测量温度,并将温度值显示在数码管上。代码中使用了位运算来处理数据的高位和低位,以及将温度值乘上0.0625来转换为实际温度值。同时,使用了延时函数来控制数码管的刷新频率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值