MAXQ7654在信号滤波中的应用

出处:sfy 发布于:2006-06-15 17:17:41

本文描述的应用旨在展示MAXQ7654的混合信号特性。微控制器利用一个I)AC产生带噪声的正弦波。DA(:输出被接入一个ADC输入通道进行采样。得到的采样通过一个简易的有限激励响应(FIR)滤波器,以衰减信号中的高频分量,从而在第二个DAC产生连续和光滑的正弦波输出。利用丰富的模拟和数字外设,在很多有意义的应用中都可施展MAXQ7654的能力。本文聚焦于MAXQ7654的信号处理能力,主要展示其ADC、DAC和硬件乘加单元。采用IAR编译器和MAXQ7654评估板(EV kit),通过一个应用实例说明如何从充满噪声的正弦波中滤出干净的低频信号。本应用的源代码、项目文件和原理图可在www.maxim—ic.com/MAXQ7654 Fiher。

1 集成的模拟功能和外设使信号滤波

MAXQ7654集成了16通道、12位ADC,完成转换仅需16个时钟周期。时钟频率为8MHz(值)时,每秒可完成500 000次采样。测量单端模拟信号时可对多达16路信号进行采样,测量差分信号时可对多达8路输入信号进行采样。该ADC也可进行温度测量--MAXQ7654内含温度传感器,可读取芯片(管芯)温度。MAXQ7654包括一个用于信号处理硬件乘加单元。它能在一个周期中进行二个16位乘法,并且还有可选的累加器功能,可工作于带符号或无符号模式。这样一来简化了FIR和IIR滤波器的实现;每个滤波因数只需3个机器周期的处理,其中包括调用滤波器的开销。JT7AG调试引擎是MAXQ平台公用的,当应用程序在目标硬件上运行时,利用它可完成寄存器和存储器的读、写操作。采用.JTAG后还省掉了昂贵的仿真器。主要的C编译器提供商,如Rowley、IAR和Python均支持MAXQ7654及其调试功能。

    MAXQ平台的一个新增外设是控制器局域网(CAN)2.0B接口,它是常用于工业和汽车领域的通信协议。MAXQ7654的CAN控制器支持15个消息中心,比特率高达1Mb/s。当收到或发出消息后以中断形式通知系统。SPI?接口支持从机或主机模式,可进行8位或16位数据传输。SPI常见于小型电路,如可编程充电器、数字电位器、DAC、ADC和存储器。MAXQ7654.有4个多功能定时器。这些定时器采用8位或16位计数方式,支持周期性中断、脉宽调制、捕获及比较功能的自动重装载。

2 滤波应用的软件架构

定时器产生中断时个DAC输出带噪声的正弦波,以确保输出采样具有固定的间隔。设计用于生成正弦波的代码涉及复杂的浮点计算,实现的运算量很大。考虑到正弦波数据是周期性重复出现的。重新计算那些不会随时间改变的正弦波数据会造成资源浪费,因此,在应用程序一开始就预先算出一组正弦波数据。在正弦波数据初始化之后,定时器产生周期性中断。定时器中断程序代码中的一个伪随机数产生器用来产生噪声,噪声被直接叠加到干净的正弦波数据中,结果被传给DAC产生输出信号。为了保持演示程序代码的简洁,在用于产生输出正弦波的定时中断中同时对模拟输入信号进行采样。当读取输入采样后,采样信号通过简易的FIR滤波软件处理,为使效率化,该滤波软件用汇编语言来实现。滤波后的采样信号随后从第2个DAC输出。用示波器来比较二个DAC的输出,可以发现一条正弦曲波较为粗糙,带有噪声,而另一条正弦比较干净,由于FIR滤波器的长度有限,因而带有轻微的相位延迟。

3 噪声正弦波的生成和采样

定时器中断程序代码如下,程序开始时已预先计算好正弦波数据,本段代码将其转换为噪声正弦波数据。

sample=static-sin-data[sinindex++];

sinnoise=((sinnoise^0x5C)*31)+0xabcd;

thisnoise=sinnoise;

if(thisnoise&Ox01)

{

thisnoise=thisnoise&0xlff;

}

else

{

thisnoise=-1*(thisnoise&Oxlff);

}

sample+=thisnoise;

if(sample<0)

sample=sample*-1;

if(sample>4095)

sample=8192-sample;

DACll=sample; //Send value to DAC#1

if(sinindex>:SIN_WAVE_STEPS)

sinindex=0:

sinnoise变量用来存储伪随机噪声(可能是正的或负的)。噪声被叠加到干净的正弦波数据后,所产生的噪声正弦波数据被直接赋给DACll寄存器以进行数/模转换。从ADC读取采样数据的过程几乎同样简单。设置完ADC的采样输入引脚后,软件可通过查询BUSY位或者使能中断来获知转换已经结束。本实例代码使用了查询方式。

inputsample=ADC_Convert_Poll(AIN0 | START CON

V | CONTINUOUS);

unsigned int ADC_Convert_Poll(unsigned int Con-

trol_Reg)

{

ACNT=Control Reg;//Set the ADC parameters

while(ACNT_bit.ADCBY==1); //Wait till

ADC is not busy

return ADCD; //Return the ADC result

}

注意,MAXQ7654中ADC的采样率是500ks/s。在8MHz时钟下,只需等待16个时钟周期便可完成转换。

4 简单的数字滤波器设计

本应用所产生的波形中包含一个强低频信号和大量的高频噪声。用一个简单的低通滤波器可净高的浮点滤波因数。不过,由于MAXQ7654有16位硬件乘加器,因此需要将浮点因数转换成16位的定点因数。这一转换会给理想的滤波器变换引入误差。因此,该Java程序也给出建立在定点因数之上的实际变换结果,并以图形方式给出了误差。注意:尽管该程序既支持极点(突出频率分量)也支持零点(衰减频率分量),但演示代码只使用零点。无限激励响应滤波器(包含极点和零点)可以由另外的软件来实现。在应用程序窗口底部的文本框中给出了生成的16位定点滤波因数以及其中的小数位数。

5 结论

MAXQ7654是一个高性能、应用广泛的混合信号微处理器。MAXQ7654简单的演示代码和高集成设计可使性能化,该器件可在信号滤波应用领域为设计者提供易于使用的解决方案。



  
关键词:MAXQ7654在信号滤波中的应用4095

版权与免责声明

凡本网注明“出处:维库电子市场网”的所有作品,版权均属于维库电子市场网,转载请必须注明维库电子市场网,https://www.dzsc.com,违反者本网将追究相关法律责任。

本网转载并注明自其它出处的作品,目的在于传递更多信息,并不代表本网赞同其观点或证实其内容的真实性,不承担此类作品侵权行为的直接责任及连带责任。其他媒体、网站或个人从本网转载时,必须保留本网注明的作品出处,并自负版权等法律责任。

如涉及作品内容、版权等问题,请在作品发表之日起一周内与本网联系,否则视为放弃相关权利。

OEM清单文件: OEM清单文件
*公司名:
*联系人:
*手机号码:
QQ:
有效期:

扫码下载APP,
一键连接广大的电子世界。

在线人工客服

买家服务:
卖家服务:
技术客服:

0571-85317607

网站技术支持

13606545031

客服在线时间周一至周五
9:00-17:30

关注官方微信号,
第一时间获取资讯。

建议反馈

联系人:

联系方式:

按住滑块,拖拽到最右边
>>
感谢您向阿库提出的宝贵意见,您的参与是维库提升服务的动力!意见一经采纳,将有感恩红包奉上哦!