用C语言编写AT89C52与ADC0809、LED数码管、ptc热敏电阻、DS18b20、继电器、24c02的代码

时间: 2023-07-10 21:03:45 浏览: 43
以下是基于AT89C52单片机的ADC0809、LED数码管、PTC热敏电阻、DS18B20、继电器、24c02的C语言代码。 这里只提供了代码框架和基本函数,具体实现需要根据硬件电路进行调整和修改。 ``` #include <reg52.h> #define uchar unsigned char #define uint unsigned int // ADC0809定义 sbit ADC0809_CS = P1^0; sbit ADC0809_RD = P1^1; sbit ADC0809_WR = P1^2; sbit ADC0809_INTR = P1^3; // LED数码管定义 sbit LED_DIO = P0^0; sbit LED_CLK = P0^1; sbit LED_LAT = P0^2; // PTC热敏电阻定义 sbit PTC_DO = P3^3; sbit PTC_DIN = P3^4; sbit PTC_CLK = P3^5; // DS18B20定义 sbit DS18B20_DQ = P3^2; // 继电器定义 sbit Relay = P2^0; // 24C02定义 #define EEPROM_ADDR 0xA0 sbit EEPROM_SCL = P2^1; sbit EEPROM_SDA = P2^2; // ADC0809读取函数 uchar ADC0809_Read(uchar ch) { uchar result = 0; ADC0809_CS = 0; ADC0809_WR = 1; ADC0809_RD = 1; ADC0809_WR = 0; P0 = ch; ADC0809_WR = 1; while(!ADC0809_INTR); ADC0809_RD = 0; result = P0; ADC0809_RD = 1; ADC0809_CS = 1; return result; } // LED数码管显示函数 void LED_Display(uchar *buf, uchar len) { uchar i, j; for(i = 0; i < len; i++) { for(j = 0; j < 8; j++) { LED_CLK = 0; LED_DIO = buf[i] & 0x01; buf[i] >>= 1; LED_CLK = 1; } } LED_LAT = 0; LED_LAT = 1; } // PTC热敏电阻读取函数 uint PTC_Read() { uchar i; uint result = 0; PTC_DIN = 1; PTC_CLK = 1; PTC_CLK = 0; PTC_DIN = 0; PTC_CLK = 1; PTC_CLK = 0; for(i = 0; i < 16; i++) { PTC_CLK = 1; result <<= 1; result |= PTC_DO; PTC_CLK = 0; } return result; } // DS18B20复位函数 uchar DS18B20_Reset() { uchar result = 0; DS18B20_DQ = 1; DS18B20_DQ = 0; DS18B20_DQ = 1; while(DS18B20_DQ); result = DS18B20_DQ; while(!DS18B20_DQ); return result; } // DS18B20读取温度函数 int DS18B20_ReadTemp() { uchar i; int result = 0; DS18B20_Reset(); DS18B20_DQ = 1; DS18B20_DQ = 0; DS18B20_DQ = 1; while(DS18B20_DQ); DS18B20_DQ = 1; for(i = 0; i < 8; i++) { DS18B20_DQ = 0; DS18B20_DQ = 1; result >>= 1; if(DS18B20_DQ) { result |= 0x8000; } } return result; } // 继电器开关函数 void Relay_Control(uchar state) { Relay = state; } // 24C02写入函数 void EEPROM_Write(uchar addr, uchar data) { uchar i; EEPROM_SCL = 1; EEPROM_SDA = 1; EEPROM_SCL = 0; EEPROM_SDA = 0; for(i = 0; i < 8; i++) { EEPROM_SCL = 0; if(addr & 0x80) { EEPROM_SDA = 1; } else { EEPROM_SDA = 0; } EEPROM_SCL = 1; addr <<= 1; } EEPROM_SDA = 1; EEPROM_SCL = 0; EEPROM_SCL = 1; EEPROM_SDA = 0; for(i = 0; i < 8; i++) { EEPROM_SCL = 0; if(data & 0x80) { EEPROM_SDA = 1; } else { EEPROM_SDA = 0; } EEPROM_SCL = 1; data <<= 1; } EEPROM_SCL = 0; EEPROM_SDA = 1; } // 24C02读取函数 uchar EEPROM_Read(uchar addr) { uchar i, result = 0; EEPROM_SCL = 1; EEPROM_SDA = 1; EEPROM_SCL = 0; for(i = 0; i < 8; i++) { EEPROM_SCL = 0; if(addr & 0x80) { EEPROM_SDA = 1; } else { EEPROM_SDA = 0; } EEPROM_SCL = 1; addr <<= 1; } EEPROM_SDA = 1; EEPROM_SCL = 0; EEPROM_SCL = 1; for(i = 0; i < 8; i++) { EEPROM_SCL = 0; result <<= 1; if(EEPROM_SDA) { result |= 0x01; } EEPROM_SCL = 1; } EEPROM_SCL = 0; EEPROM_SDA = 1; return result; } void main() { uchar adc_result, led_buf[4], ptc_buf[4], eeprom_data; uint ptc_result; int ds18b20_temp; // 初始化LED数码管 LED_CLK = 0; LED_LAT = 1; LED_DIO = 0; while(1) { // 读取ADC0809 adc_result = ADC0809_Read(0); // 将ADC值转化为LED数码管显示数据 // ... // 显示LED数码管 LED_Display(led_buf, 4); // 读取PTC热敏电阻 ptc_result = PTC_Read(); // 将PTC值转化为LED数码管显示数据 // ... // 显示LED数码管 LED_Display(ptc_buf, 4); // 读取DS18B20温度 ds18b20_temp = DS18B20_ReadTemp(); // 判断温度是否超过阈值,控制继电器开关 // ... // 读取24C02数据 eeprom_data = EEPROM_Read(0x00); // 写入24C02数据 EEPROM_Write(0x00, eeprom_data + 1); // 延时 // ... } } ```

相关推荐

最新推荐

recommend-type

基于AT89C51和DS18B20的最简温度测量系统

本文介绍一种新型的可编程温度传感器DS18B20,他能代替模拟温度传感器和信号处理...DS18B20与AT89C51结合实现最简温度检测系统,该系统结构简单,抗干扰能力强,适合于恶劣环境下进行现场温度测量,有广泛的应用前景。
recommend-type

基于89C51和DS18B20的温度采集系统设计

本温度采集系统的下位机采用89C51单片机为主控制器,利用DS18B20温度传感器进行溫度测量,采用数码管进行显示,并通过串口将采集的数据传送到上位机(PC机),通过上位机对温度进行集中监视和管理,解决了温度测量通常...
recommend-type

一种基于DS18B20的温度采集系统设计

与传统的模拟温度传感器相比,数字式温度传感器在器件微小化、抗干扰能力、可靠性、分辨率以及精度方面都具有明显的优点,此外,其输出的温度数据以及相关的温度控制量能够与各种微处理器相适配。
recommend-type

基于AT89C51单片机与DS18B20的温度测量系统

DALLAS公司的单总线数字温度传感器DSl8B20以其线路简单、硬件...其中,详细介绍了AT89C51对DS18B20的操作流程,及使用DS18B20时候的注意事项。该温度测量系统具有结构简单、价格低廉、扩展方便和应用广泛等一系列优点。
recommend-type

DS18B20数据手册-中文版(带目录)

使用参见:https://handsome-man.blog.csdn.net/article/details/104530051
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。