若需要采用中断方式进行AD转换,应如何设计实验程序代码?

若需要采用中断方式进行AD转换,应如何设计实验程序代码?,第1张

用中断的目的,就是要在A/D转换时段内做其他 *** 作,不让其他可利用资源空等。这就需要你程序里有个类似 *** 作系统作业调度的守护进程。这个守护进程维护的是个全局状态机,守护进程持续监测状态机状态,状态一旦具备进入下一个状态的条件,守护进程就会根据系统占用情况,决定是否发起到预定状态的新进程,或者送到某个有管理的批处理队列里。实时多任务系统里通常守护进程要比普通进程优先级高;没有实时要求的多任务系统里,支持多进程的,优先级也要比普通进程高;单进程系统通常不设高优先级的守护进程,因为只要有任务在处理就没资源会闲置,不妨等处理完毕再做同级调度。

中断方式的A/D,A/D转换完成后会触发中断,中断处理程序置位“A/D转换好”状态后退出即可。守护进程监测到这个状态改变,结合之前的系统状态,根据状态机下一状态发起预定的A/D转换的后处理程序。A/D后处理程序处理完成后置位“A/D后处理完毕”,守护进程会再根据你设计的状态转移图发起向下一状态进发的新进程.......

中断处理程序代码应极尽简洁,非必要避免在里面做过多的处理,因为它工作时所有进程都停下等,对有实时性要求的低级进程这种影响可能是致命的。

作业调度是程序设计里非常有趣的单元之一。

A/D转换步骤:

一、采样:

在A/D转换期间,为了使输入信号不变,保持在开始转换时的值,通常要采用一个采样电路。启动转换实际上是把采样开关接通,进行采样。

二、保持

在A/D转换期间,采样电路采样后,过一段时间后,开关断开,采样电路进入保持模式,才是A/D真正开始转换。

三、量化

模数转化是为了量数字系统不能识别的采集信息转化为能识别的结果,在数字系统中只有0和1两个状态,而模拟量的状态很多,而ADC的作用就是把这个模拟量分为很多一小份的量来组成数字量以便数字系统识别,所以量化的作用就是为了用数字量更精确表示模拟量。

四、编码

编码是将离散幅值经过量化以后变为二进制数字的过程。

C语言程序设计

Franklin C51交*编译器是专为51系列单片机设计的一种高效的C语言编译器,使用它可以缩短开发周期,降低开发成本,而且开发出的系统易于维护,可*性高,可移植性好。下面介绍用C语言编写的单点和定长数据采集子程序,假设所用的晶振频率为12MHz。单点采样子程序ADS7804()用来返回一个有符号整数形式的转换结果。定长采样子程序DAQ()根据入口参数interval(单位为μs)给定的采样间隔采样N点,并采用查询51单片机内置定时器的方式来控制采样时序,N点采样结果存储在定位于外部存储器的数组array中。需要注意的是,赋给计数寄存器TH和TL的值是定时器从开始计数到溢出所用的时间,这个时间再加上清TF和装载计数初值所需的时间(共5个机器周期,对于12MHz晶振即为5μs)才是所要的采样间隔,这一点在程序设计中必须注意。

源程序如下:

# include<reg51.h>

# include<absacc.h>

# define N 128 /*定采样长度,如128点*/sbit BYTE=F1^0;

sbit RC=P1^1

sbit BUSY=P1^2/*定义特殊位*/

int XDATA array(N)/*在外部存储器内定义长度为N的有符号整数数组*/

int ADS7804(void)

{ uint ul,uhint u

RC=0/*R/C低电平,进入转换模式*/

ul=XBYTE[0xffff]/*产生读脉冲,启动A/D转换*/

while (BUSY= =0)/*等待转换完成*/

RC=1;BYTE=0/*进入读模式,选择低字节*/

ul=XBYTE[0xffff]/*读转换结果低8位*/

BYTE=1; /*选择高字节*/

uh=XBYTE[0xffff]&0x0f/*读转换结果高4位*/

u=uh*256+ul/*得到12位转换结果*/

if(u>=0x0800)

u=u 0xf000/*如果为负值,则符号扩展*/

return(u)/*返回转换结果*/

}

uoid DAQ(uint interval)

{ uchar th,tl

interval=interval-5/*减去TF0清零和装载计数初值的时间5μs*/

th=255-(interval/256)

tl=255-(interval%256)/*计算计数初值*/

TMOD=0x01/*定时器0,方式1 */

TH0=thTL0=tl;/*装载计数初值*/

TR0=1;/*启动定时*/

for(I=0i<Ni++)

{ do{}whilt(!TF0)/*查询等待TF0复位*/

TF0=0/*清溢出标志*/

TH0=thTL0=tl; /*装载计数初值*/

Array[i]=ADS7804()/*采样、存储*/

}

TR0=0/*停止定时*/

}

6 结束语

ADS7804为12位的A/D转换器,它不仅分辨率高、转换速度快,而且接口方便,电路简单、应用灵活,因而具有广泛的应用前景。笔者在DLRS-1型检波器低频接收灵敏度特性测量仪中使用了ADS7804,取得了很好的效果


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7728304.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-09
下一篇 2023-04-09

发表评论

登录后才能评论

评论列表(0条)

保存