收藏 分销(赏)

温湿度传感器与应用代码和仿真设计.doc

上传人:人****来 文档编号:3380943 上传时间:2024-07-03 格式:DOC 页数:17 大小:80KB
下载 相关 举报
温湿度传感器与应用代码和仿真设计.doc_第1页
第1页 / 共17页
温湿度传感器与应用代码和仿真设计.doc_第2页
第2页 / 共17页
温湿度传感器与应用代码和仿真设计.doc_第3页
第3页 / 共17页
温湿度传感器与应用代码和仿真设计.doc_第4页
第4页 / 共17页
温湿度传感器与应用代码和仿真设计.doc_第5页
第5页 / 共17页
点击查看更多>>
资源描述

1、 仿真图形 运营后结果#ifndef _TOU_H_#define _TOU_H_#include#include /#include /Keil library #define uchar unsigned charenum TEMP,HUMI;sbit DATA = P11;sbit SCK = P10;sbit RS = P20;sbit RW = P21;sbit E = P22;sfr DBPort = 0x80; /P0=0x80,P1=0x90,P2=0xA0,P3=0xB0.数据端口/* DS1602函数声明 */void LCD_Initial();void GotoXY(u

2、nsigned char x, unsigned char y);void Print(unsigned char *str);void LCD_Write(bit style, unsigned char input);/* SHT10函数声明 */void s_connectionreset(void);char s_measure(unsigned char *p_value, unsigned char *p_checksum, unsigned char mode);void calc_sth10(float *p_humidity ,float *p_temperature);/f

3、loat calc_dewpoint(float h,float t);#endif/*/SHT10程序(SHT10.c):/#include#define noACK 0/继续传输数据,用于判断是否结束通讯#define ACK 1 /结束数据传输;/地址 命令 读/写#define STATUS_REG_W 0x06 /000 0011 0#define STATUS_REG_R 0x07 /000 0011 1#define MEASURE_TEMP 0x03 /000 0001 1#define MEASURE_HUMI 0x05 /000 0010 1#define RESET 0x

4、1e /000 1111 0/写字节程序char s_write_byte(unsigned char value) unsigned char i,error=0; for (i=0x80;i0;i=1) /高位为1,循环右移 if (i&value) DATA=1; /和要发送的数相与,结果为发送的位 else DATA=0; SCK=1; _nop_();_nop_();_nop_(); /延时3us SCK=0;DATA=1; /释放数据线SCK=1; error=DATA; /检查应答信号,确认通讯正常_nop_();_nop_();_nop_();SCK=0; DATA=1;ret

5、urn error; /error=1 通讯错误/读字节程序char s_read_byte(unsigned char ack)/- unsigned char i,val=0;DATA=1; /释放数据线for(i=0x80;i0;i=1) /高位为1,循环右移 SCK=1; if(DATA) val=(val|i); /读一位数据线的值 SCK=0; DATA=!ack; /假如是校验,读取完后结束通讯;SCK=1; _nop_();_nop_();_nop_(); /延时3us SCK=0; _nop_();_nop_();_nop_(); DATA=1; /释放数据线return v

6、al;/启动传输void s_transstart(void)/ generates a transmission start / _ _/ DATA: |_|/ _ _/ SCK : _| |_| |_ DATA=1; SCK=0; /准备 _nop_(); SCK=1; _nop_(); DATA=0; _nop_(); SCK=0; _nop_();_nop_();_nop_(); SCK=1; _nop_(); DATA=1; _nop_(); SCK=0; /连接复位void s_connectionreset(void)/ communication reset: DATA-lin

7、e=1 and at least 9 SCK cycles followed by transstart/ _ _/ DATA: |_|/ _ _ _ _ _ _ _ _ _ _ _/ SCK : _| |_| |_| |_| |_| |_| |_| |_| |_| |_| |_| |_ unsigned char i; DATA=1; SCK=0; /准备for(i=0;i=1 in case of no response form the sensor */ /温湿度测量char s_measure(unsigned char *p_value, unsigned char *p_chec

8、ksum, unsigned char mode)/ 进行温度或者湿度转换,由参数mode决定转换内容; /enum TEMP,HUMI; /已经在头文献中定义unsigned error=0;unsigned int i;s_transstart(); /启动传输switch(mode) /选择发送命令 case TEMP : error+=s_write_byte(MEASURE_TEMP); break; /测量温度 case HUMI : error+=s_write_byte(MEASURE_HUMI); break; /测量湿度 default : break; for (i=0;

9、i100)rh_true=100; /湿度最大修正if(rh_true0.1)rh_true=0.1; /湿度最小修正*p_temperature=t_C; /返回温度结果*p_humidity=rh_true; /返回湿度结果/从相对温度和湿度计算露点/*float calc_dewpoint(float h,float t)float logEx,dew_point;logEx=0.66077+7.5*t/(237.3+t)+(log10(h)-2);dew_point = (logEx - 0.66077)*237.3/(0.66077+7.5-logEx);return dew_poi

10、nt; */*/DS1602程序(1602.c):/#include/内部等待函数*unsigned char LCD_Wait(void) RS=0; RW=1; _nop_(); E=1; _nop_(); E=0; return DBPort; /向LCD写入命令或数据*#define LCD_COMMAND 0 / Command#define LCD_DATA 1 / Data#define LCD_CLEAR_SCREEN 0x01 / 清屏#define LCD_HOMING 0x02 / 光标返回原点void LCD_Write(bit style, unsigned char

11、 input) E=0; RS=style; RW=0; _nop_(); DBPort=input; _nop_();/注意顺序 E=1; _nop_();/注意顺序 E=0; _nop_(); LCD_Wait(); /设立显示模式*#define LCD_SHOW 0x04 /显示开#define LCD_HIDE 0x00 /显示关 #define LCD_CURSOR 0x02 /显示光标#define LCD_NO_CURSOR 0x00 /无光标 #define LCD_FLASH 0x01 /光标闪动#define LCD_NO_FLASH 0x00 /光标不闪动void LC

12、D_SetDisplay(unsigned char DisplayMode) LCD_Write(LCD_COMMAND, 0x08|DisplayMode); /设立输入模式*#define LCD_AC_UP 0x02#define LCD_AC_DOWN 0x00 / default#define LCD_MOVE 0x01 / 画面可平移#define LCD_NO_MOVE 0x00 /defaultvoid LCD_SetInput(unsigned char InputMode) LCD_Write(LCD_COMMAND, 0x04|InputMode);/初始化LCD*vo

13、id LCD_Initial() E=0; LCD_Write(LCD_COMMAND,0x38); /8位数据端口,2行显示,5*7点阵 LCD_Write(LCD_COMMAND,0x38); LCD_SetDisplay(LCD_SHOW|LCD_NO_CURSOR); /启动显示, 无光标 LCD_Write(LCD_COMMAND,LCD_CLEAR_SCREEN); /清屏 LCD_SetInput(LCD_AC_UP|LCD_NO_MOVE); /AC递增, 画面不动/液晶字符输入的位置*void GotoXY(unsigned char x, unsigned char y)

14、if(y=0) LCD_Write(LCD_COMMAND,0x80|x); if(y=1) LCD_Write(LCD_COMMAND,0x80|(x-0x40);/将字符输出到液晶显示void Print(unsigned char *str) while(*str!=0) LCD_Write(LCD_DATA,*str); str+; /*/主函数(main.c):/#includetypedef union /定义共用同类型 unsigned int i;float f; value;/延时函数void delay(int z)/z为毫秒数int x,y;for(x=z;x0;x-)f

15、or(y=125;y0;y-);void main() unsigned int temp,humi;value humi_val,temp_val;/定义两个共同体,一个用于湿度,一个用于温度/float dew_point; /用于记录露点值unsigned char error; /用于检查是否出现错误unsigned char checksum;/CRC uchar wendu6; /用于记录温度uchar shidu6; /用于记录湿度 LCD_Initial(); /初始化液晶 GotoXY(0,0); /选择温度显示位置 Print(TEMP: %C); /5格空格 GotoXY

16、(0,1); /选择湿度显示位置 Print(HUMI: %RH); /5格空格s_connectionreset(); /启动连接复位while(1)error=0; /初始化error=0,即没有错误error+=s_measure(unsigned char*)&temp_val.i,&checksum,TEMP); /温度测量error+=s_measure(unsigned char*)&humi_val.i,&checksum,HUMI); /湿度测量 if(error!=0) s_connectionreset(); /假如发生错误,系统复位 else humi_val.f=(f

17、loat)humi_val.i; /转换为浮点数 temp_val.f=(float)temp_val.i; /转换为浮点数 calc_sth10(&humi_val.f,&temp_val.f); /修正相对湿度及温度/ dew_point=calc_dewpoint(humi_val.f,temp_val.f); /计算e dew_point temp=temp_val.f*10; humi=humi_val.f*10; GotoXY(5,0);/设立温度显示位置 wendu0=temp/1000+0; /温度百位 wendu1=temp%1000/100+0; /温度十位 wendu2=

18、temp%100/10+0;/温度个位 wendu3=0x2E;/小数点 wendu4=temp%10+0;/温度小数点后第一位Print(wendu);/输出温度 GotoXY(5,1);/设立湿度显示位置 shidu0=humi/1000+0; /湿度百位 shidu1=humi%1000/100+0; /湿度十位 shidu2=humi%100/10+0;/湿度个位 shidu3=0x2E;/小数点 shidu4=humi%10+0;/湿度小数点后第一位Print(shidu);/输出湿度 delay(800); /等待足够长的时间,以现行下一次转换 欢迎您的光顾,Word文档下载后可修改编辑.双击可删除页眉页脚.谢谢!希望您提出您宝贵的意见,你的意见是我进步的动力。赠语; 1、假如我们做与不做都会有人笑,假如做不好与做得好还会有人笑,那么我们索性就做得更好,来给人笑吧! 2、现在你不玩命的学,以后命玩你。3、我不知道年少轻狂,我只知道胜者为王。4、不要做金钱、权利的奴隶;应学会做“金钱、权利”的主人。5、什么时候离光明最近?那就是你觉得黑暗太黑的时候。6、最值得欣赏的风景,是自己奋斗的足迹。7、压力不是有人比你努力,而是那些比你牛几倍的人仍然比你努力。

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服