




免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include #include intrins.hsbit AD7798_CS=P22; / 1sbit AD7798_SCLK=P23; / 1sbit AD7798_RDY=P21;/ 0sbit AD7798_DOUT=P21;sbit AD7798_DIN=P20;/ 1void Init_Serial( void );/串口初始化void WaiteRDY( void );/等待RDY变为低电平unsigned char ReadByte_7798( void );/读一个字节void ReadData_7798( void );/AD7798采集到得数据void Serial_Receive(unsigned char Data);/发送一个字节数据void WriteByte_7798(unsigned char Data);/写一个字节 void Init_Ad7798(unsigned char ChannelNum);/AD7798初始化unsigned char disp8 = 0x1f,0x00,0x00,0x00,0x00,0x00,0x00,0x04;unsigned char New_Data8 = 0x1f,0x00,0x00,0x00,0x00,0x00,0x00,0x04;unsigned char Next_Data8 = 0x1f,0x00,0x00,0x00,0x00,0x00,0x00,0x04;unsigned char Two_Data8 = 0x1f,0x00,0x00,0x00,0x00,0x00,0x00,0x04;unsigned char hData,lData;long int new,old,yy;/=主函数void main( void )unsigned char i,j;/AD7798读取的数据Init_Serial();P2 = 0x00;WriteByte_7798(0xff);/reset ad7798 WriteByte_7798(0xff); WriteByte_7798(0xff); WriteByte_7798(0xff);while(1) for(i=0;i3;i+)Init_Ad7798(i);/通道1、通道2、通道3初始化 ReadData_7798();new = hData * 256 +lData;old = (long int)(new - yy)/2); yy = (unsigned int)(old + yy);j=2*i+1;New_Dataj=yy / 256;New_Dataj+1=yy % 256;/Serial_Receive(hData); /发送数据/Serial_Receive(lData); /发送数据/=写一个字节void WriteByte_7798(unsigned char Data) unsigned char i ; /AD7798_CS=0; for(i=0;i8;i+) AD7798_SCLK=0 ;_nop_(); _nop_(); if(Data&0x80)AD7798_DIN=1 ; else AD7798_DIN=0 ;_nop_(); _nop_(); Data=Data1 ;_nop_(); _nop_(); AD7798_SCLK=1 ; _nop_(); _nop_(); /AD7798_CS=1;/=读一个字节unsigned char ReadByte_7798( void ) unsigned char i ; unsigned char ReadData ; /AD7798_CS=0; ReadData=0 ; for(i=0;i8;i+) AD7798_SCLK=0 ; _nop_(); _nop_(); ReadData=ReadData65500) WriteByte_7798(0xff);/reset ad7798 WriteByte_7798(0xff); WriteByte_7798(0xff); WriteByte_7798(0xff); Init_Ad7798(0); break; /=7798的初始化void Init_Ad7798(unsigned char ChannelNum) WriteByte_7798(0xff);/reset ad7798 WriteByte_7798(0xff); WriteByte_7798(0xff); WriteByte_7798(0xff); WriteByte_7798(0x10);/写入通讯寄存器设置下一个操作,写信给配置寄存器 WriteByte_7798(0x27);/增益为128 WriteByte_7798(0x30+ChannelNum);/* /写入模式注册启动 系统满量程较准 WriteByte_7798(0x08);/写入通讯寄存器设置下一个操作,写信给模式寄存器 WriteByte_7798(0xe0); WriteByte_7798(0x0a); WaiteRDY();/等待及由RDY销去低显示最终的校准周期/写入模式注册启动 系统失调较准 WriteByte_7798(0x08);/写入通讯寄存器设置下一个操作,写信给模式寄存器 WriteByte_7798(0xc0); WriteByte_7798(0x0a); WaiteRDY();/等待及由RDY销去低显示最终的校准周期*/写入模式注册启动 内部零刻度校准 WriteByte_7798(0x08);/写入通讯寄存器设置下一个操作,写信给模式寄存器 WriteByte_7798(0x80); WriteByte_7798(0x0a); WaiteRDY();/等待及由RDY销去低显示最终的校准周期/写入模式注册启动 内部满刻度校准/ WriteByte_7798(0x08);/写入通讯寄存器设置下一个操作,写信给模式寄存器/ WriteByte_7798(0xa0);/ WriteByte_7798(0x0a);/ WaiteRDY();/等待及由RDY销去低显示最终的校准周期 WriteByte_7798(0x08);/写入通讯寄存器设置下一个操作,写信给模式寄存器 WriteByte_7798(0x00); WriteByte_7798(0x0a);/=读AD的数据void ReadData_7798( void ) int ConverData ; unsigned char ADSAT ;unsigned char ErrNUM; WaiteRDY();/RDY为低电平时读取数据,读取完成后变为高电平 WriteByte_7798(0x40); ADSAT=ReadByte_7798();/出错或者读写异常/Serial_Receive(ADSAT); while(ADSAT&0x40)|(ADSAT&0x08)/0x40 错误位 0x08 必须为1 WriteByte_7798(0xff); WriteByte_7798(0xff); WriteByte_7798(0xff); WriteByte_7798(0xff); Init_Ad7798(0); WaiteRDY(); WriteByte_7798(0x40); ADSAT=ReadByte_7798(); ErrNUM+; if(ErrNUM5)break; WriteByte_7798(0x58);/写入通讯寄存器设置下一个操作是连续的读取数据寄存器 WaiteRDY();/等待及由RDY销去低显示最终的校准周期 if(!AD7798_RDY) ConverData=0 ; hData=ReadByte_7798(); ConverData=hData; ConverData=ConverData8 ;lData=ReadByte_7798(); ConverData=lData+ConverData ; ReadByte_7798(); /*WriteByte_7798(0x60);/读IDADSAT=ReadByte_7798();Serial_Receive(ADSAT); /ID 显示 */=波特率初始化void Init_Serial( void )TMOD=0X20; /设置定时器1为方式2TH1=0xfa; /装入初值TL1=0Xfa; /装入初值TR1=1; /启动定时器1SM0=0; /设置串口为方式1SM1=1; /设置串口为方式1REN=1; /接收始能EA=1; /打开总中断开关ES=1; /打开串口中断开关/=串口发送void Serial_Receive(unsigned char Data)ES=0;/关闭串口中断开关SBUF=Data;/将数据发送给电脑while(!TI); /等待数据发送结束TI=0;ES=1;/=串口接受void serial() interrupt 4unsigned char k;unsigned char a;static unsigned char index_a=0;static unsigned char index_b=0; a=SBUF;RI=0;if(index_b)for(k=1;k7;k+)Two_Datak=Next_Datak; for(k=1;k=Next_Datak)&(Next_Datak=Two_Datak) dispk=Next_Datak;if(New_Datak =Two_Datak) &(Two_Datak =Next_Datak) dispk=Two_Datak;if(Next_Datak=New_Datak) &(New_Datak =Two_Datak) dispk=New_Datak;if(Next_Datak=Two_Datak) &(Two_Datak =New_Datak) dispk=Two_Datak;if(Two_Datak =New_Datak) &(New_Datak =Next_Datak) dispk=New_Data
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 象棋延时服务课件
- 2025版高新技术产业聘用员工合同协议示范文本
- 2025版企业绿色转型项目咨询与服务合同
- 2025年度礼品定制采购合同-附加礼品定制及品牌合作计划
- 2025大蒜产业链金融支持服务合同
- 2025年度农业合作社三方租地合作合同范本
- 2025版网络安全防护软件源码授权与保密协议标准范本
- 2025年度电力照明设施安全检测合同
- 2025年股权代持转让及管理服务三方合同
- 诸子论与课件
- 小学科学新教科版二年级上册全册教案(2025秋版)
- 2025年海南省通信网络技术保障中心招聘考试笔试试题(含答案)
- 2025年国家卫生健康委医药卫生科技发展研究中心招聘考试笔试试题(含答案)
- 2025至2030中国PE微粉蜡市场需求量预测及前景动态研究报告
- 2025年辅警招聘公安基础知识题库附含参考答案
- 2025年理赔专业技术职务任职资格考试(理赔员·保险基础知识)历年参考题库含答案详解(5套)
- 2025年北京标准租房合同范本下载
- 中华人民共和国治安管理处罚法2025修订版测试题及答案
- 第一单元复习与提高(单元测试)-五年级上册数学沪教版
- 2025年湖北高考历史试题(含答案解析)
- 新学期教学工作会议上校长讲话:把功夫下在课堂里把心思放在学生上把质量落到细节中
评论
0/150
提交评论