版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、#include <reg51.h>#include <math.h>#include <intrins.h>sbit DATA=P11; /定义通讯数据端口/#define DATA_IO TRISC7 /用于设置IO状态sbit SCK=P10; /定义通讯时钟端口#define noACK 0 /继续传输数据,用于判断是否结束通讯#define ACK 1 /结束数据传输; /地址 命令#define MEASURE_TEMP 0x03 /000 00011#define MEASURE_HUMI 0x05 /000 00101/void init_u
2、art(void); /初始化void s_connectionreset(void);void s_transstart(void);char s_measure(unsigned char *p_value, unsigned char *p_checksum, unsigned char mode);char s_write_byte(unsigned char value);char s_read_byte(unsigned char ack);void calc_sth11(float *p_humidity ,float *p_temperature);float calc_dew
3、point(float h,float t);void delay (unsigned int time); union unsigned int i; float f;humi_val,temp_val; /定义两个共同体,一个用于湿度,一个用于温度/*延时 1MS 带参数(int)子程序*/void delay (unsigned int time) unsigned int a,b; for(a=0;a<time;a+) for(b=0;b<88;b+); /-/void init_uart(void)/-/ 端口初始化/TRISC7=0;/TRISC6=0;/-void s
4、_connectionreset(void)/-/ 连接复位;/ _ _/ DATA: |_|/ _ _ _ _ _ _ _ _ _ _ _/ SCK : _| |_| |_| |_| |_| |_| |_| |_| |_| |_| |_| |_ unsigned char i; DATA=1; SCK=0; /准备 for(i=0;i<9;i+) /DATA保持高,SCK时钟触发9次,发送启动传输,通迅即复位 SCK=1; SCK=0; s_transstart(); /启动传输/-void s_transstart(void)/-/ 启动传输/ _ _/ DATA: |_|/ _ _
5、/ 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; /-char s_measure(unsigned char *p_value, unsigned char *p_checksum, unsigned char mode)/-/ 进行温度或者湿度转换,由参数mode决定转换内容; unsigned error=0; unsigned char i; s_
6、transstart(); /启动传输 switch(mode) case 02 : error+=s_write_byte(MEASURE_TEMP); break; case 01 : error+=s_write_byte(MEASURE_HUMI); break; default : break; for (i=0;i<110;i+) delay(2); if(DATA=0) break; /等待测量结束; if(DATA) error+=1; / 如果长时间数据线没有拉低,说明测量错误 *(p_value) =s_read_byte(ACK); /读第一个字节,高字节 (MSB
7、) *(p_value+1)=s_read_byte(ACK); /读第二个字节,低字节 (LSB) *p_checksum =s_read_byte(noACK); /read CRC校验码 return error;/-char s_write_byte(unsigned char value)/-/ 写字节函数 unsigned char i,error=0; for (i=0x80;i>0;i/=2) /高位为1,循环右移 if (i & value) DATA=1; /和要发送的数相与,结果为发送的位 else DATA=0; SCK=1; _nop_();_nop_(
8、);_nop_(); SCK=0; DATA=1; /释放数据线/ DATA_IO=1; SCK=1; error=DATA; /检查应答信号,确认通讯正常 SCK=0; return error; /error=1 通讯错误/-char s_read_byte(unsigned char ack)/-/ 读数据; unsigned char i,val=0; / DATA_IO=0; DATA=1; /数据线为高 /DATA_IO=1; for (i=0x80;i>0;i/=2) /右移位 SCK=1; if (DATA) val=(val | i); /读数据线的值 SCK=0; /
9、 DATA_IO=0; DATA=!ack; /如果是校验,读取完后结束通讯; SCK=1; _nop_();_nop_();_nop_(); SCK=0; DATA=1; /释放数据线 return val;/-void calc_sth11(float *p_humidity ,float *p_temperature)/-/ 补偿及输出温度和相对湿度 const float C1=-4.0; / for 12 Bit 湿度修正公式 const float C2=+0.0405; / for 12 Bit 湿度修正公式 const float C3=-0.0000028; / for 12
10、 Bit 湿度修正公式 const float T1=+0.01; / for 14 Bit 5V 温度修正公式 const float T2=+0.00008; / for 14 Bit 5V 温度修正公式 float rh=*p_humidity; float t=*p_temperature; float rh_lin; float rh_true; float t_C; t_C=t*0.01 - 40; /补偿温度 rh_lin=C3*rh*rh + C2*rh + C1; /相对湿度非线性补偿 rh_true=(t_C-25)*(T1+T2*rh)+rh_lin; /相对湿度对于温度
11、依赖性补偿 if(rh_true>100)rh_true=100; /湿度最大修正 if(rh_true<0.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.6607
12、7+7.5-logEx); return dew_point;/-void main()/-/ 示例程序,完成如下功能/ 1. 复位 / 2. 湿度的12测量以及温度的14位精度测量/ 3. 补偿及修正温湿度/ 4. 计数并得出绝对湿度 float dew_point; unsigned char error,checksum; unsigned char HUMI,TEMP; HUMI=0X01; TEMP=0X02; / init_uart(); s_connectionreset(); while(1) error=0; error+=s_measure(unsigned char*) &humi_val.i,&checksum,HUMI); /湿度测量 error+=s_measure(unsigned char*) &temp_val.i,&checksum,TEMP); /温度测量 if(error!=0) s_connectionreset(); /如果发生错误,系统复位 else humi_val.f=(float)humi_val.i; /转换为浮点数 temp_val.f=(float)temp_val.i; /转换为浮点数 calc_sth11(&humi_val.f,&temp
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 中山市博爱医院2026年人才招聘49人备考题库及参考答案详解一套
- 5G+AI辅助重症患者个体化治疗策略
- 2026年广州医科大学附属口腔医院招聘备考题库(一)完整答案详解
- 3D打印人工皮肤的美学与功能重建
- 2025年义乌市胜利幼儿园招聘备考题库及参考答案详解1套
- 2025年改则县审计局面向社会公开聘用编外工程师备考题库及一套答案详解
- 简约中国风地产营销策划方案
- 项目高处作业施工方案
- 2025年厦门市集美区乐安小学非在编教师招聘备考题库及答案详解1套
- 2025年四川省岳池银泰投资(控股)有限公司公开招聘急需紧缺专业人才备考题库有答案详解
- 《产科危急重症早期识别中国专家共识(2024年版)》解读
- 绿色建筑自评估报告参考样式
- 涉密文件解密管理制度
- 高中英语必背3500单词表完整版
- 巡特警(辅警)政审表
- 医用耗材知识培训课件
- 《竹木复合集装箱底板》(T-CSF 009-2019)
- 婚介协议书模板
- ISO14001及ISO45001法律法规清单
- 成人学历销售培训课件
- 民主测评及征求意见表
评论
0/150
提交评论