免费预览已结束,剩余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年大学《应用气象学-气象数据处理与分析》考试备考题库及答案解析
- IT部门网络安全防护与应急响应计划
- 2025年大学《物流管理-物流管理概论》考试参考题库及答案解析
- 2025年大学《天文学-天体力学基础》考试备考题库及答案解析
- 【室内设计手绘效果图表现技法】课件
- JAVA从入门到精通教程(完整版)
- 工程技术职业规划
- 新教材外研版高中英语选择性必修第一册各单元重点语法归纳总结.文档
- 运动会招商方案
- 国画竹子课件
- 工程光学课件:光的干涉和干涉系统-
- 四体系条款对照表全套IATF16949、iSO9001、ISO14001、ISO45001
- 保健按摩师试题库与参考答案
- 给排水工程作业指导书
- 大队委竞选PPT模板
评论
0/150
提交评论