当前位置:首页 > 模拟 > 模拟
[导读]本文描述的应用旨在展示MAXQ7654的混合信号特性。微控制器利用一个I)AC产生带噪声的正弦波。DA(:输出被接入一个ADC输入通道进行采样。得到的采样通过一个简易的有限激励响应(FIR)滤波器

本文描述的应用旨在展示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简单的演示代码和高集成设计可使性能最大化,该器件可在信号滤波应用领域为设计者提供易于使用的解决方案。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭