微波EDA网,见证研发工程师的成长!
首页 > 应用设计 > 汽车电子 > 基于AMR磁阻传感器和加速度传感器的电子罗盘

基于AMR磁阻传感器和加速度传感器的电子罗盘

时间:10-04 来源:电子发烧友 点击:

从单片机计数输入端,观察信号波形。为便于分析,在高、低电平段设置了几个干扰尖峰脉冲,分别标示为Section A和Section C,占空比信号下降沿、上升沿分别标示为Section B和Section D。单片机按计数时钟周期性采样,采样值中"1"表示采到的是高电平,"0"表示低电平。I/O口采样占空比信号输出端口中状态,利用1个字节型变量R来动态存储采样值。控制器每采样1次,变量R中数据向左移1个二进制位,R原最高位电平状态被移除,而当前时刻新的采样状态保存到R的最低位,变量R被更新了,状态存储器R中保存着最近8个采样周期的采样值。

在图1中,从正常下降沿过程(Section B),可以看到变量R中的数据经历了从各位全为1,到1、0共存,再变化到全为0的过程;然而,在高电平段的干扰部分(SectionA),变量R经历了从全为1,到1、0混合,再回到全为1的过程。类似地,正常上升沿(Section D)变量R经历了各位全为0,到0、1共存,再变化到全为1的状态变化过程;在低电平段的干扰部分(Section C),变量R经历了采样状态从全为0,到0、1混合,再回到全为0的过程。通过判断此4种情况下变量R中数据的不同变化过程,可以达到从正常变化中辨别出干扰的目的。这就是本设计所采用的软件滤波抗干扰方法的基本思想。

3 软件滤波算法的实现

3.1 软件滤波分析

根据软件滤波设计思想,滤波子程序由主程序在信号状态发生变化,进入中断时调用,图2给出了滤波程序流程。对照图1中4种Section来分析流程图。当有边沿或干扰信号(信号周期大于计数时钟周期)到来时,VRS51L3074单片机的PWC计数停止条件满足,系统进入中断服务子程序。在中断子程序中,首先重置脉宽计数条件,然后对当前状态进行采样,采样1次,状态寄存器左移1位,采样到高电平记为"1",采样到低电平记为"0"。如正常下降沿Section B,前面处于高电平段,初始状态变量Flag全为1,当出现低电平,控制器进人中断,紧接着进行16次采样。前已提及系统处理的尖峰干扰约1~2 ms,每个采样周期约为0.4 ms,其尖峰干扰脉宽达不到8个采样周期。系统设计时采样16次,只取最后8次的存储状态与原状态进行比较,如果最后采样的状态全为"0"则与原状态相反,就可判断出这是1个正常下降沿。如果是干扰信号引起计数中断,前面8个采样状态不全为"1",后面8个状态全为"1",最后采样的状态与原状态相同,就可判断出这是1个干扰信号,如Section A。在信号状态采样期间,计数条件满足PWC继续计数,直到真正的下降沿到来,计数停止并保存,计数寄存器还原为初始值,这样干扰信号即被滤除。类似地,正常上升沿Section D,存储器原状态为"0",上升沿来临后存储器状态为"1",与原状态相反,PWC计数停止并保存,计数寄存器还原为初始值,退出中断子程序。有干扰信号出现后采样状态与原状态相同,干扰尖峰脉冲可被滤除。如果要使脉宽计数更精确,可判断前8个采样周期中系统不正常计数的周期,然后与最终计数周期相加即可。此时,程序流程体现出软件滤波功能。


3.2 源程序代码分析

对应程序流程图,给出了单片机通过P4.2口对ADXL202某一输出通道采样滤波并完成脉宽计数的源程序。源程序如下:

源程序中定义了3个变量,其中变量Flag存储原状态值;FlagReg存储当前采样值;变量i记录采样次数;改变i的值可控制滤除尖峰脉冲的等待时间。程序通过对原状态与当前采样状态异或之后的值来判断当前信号是有效信号还是干扰信号,从而对上升沿、下降沿的中间过度或尖峰脉冲干扰进行相应处理,退出中断子程序。实现了对正常信号计数、滤掉尖峰脉冲干扰的目的。

4 测试结果

由于条件限制以及干扰的随机性,对基于ADXL202构成的车载屯子罗盘进行的测试,无法对所测量的角度以及方向角进行精确标定。实验时,通过相同条件下同一物理量多次测量值的标准差来对相应算法进行评估。测试结果如表1所列。

从实验测试的标准差可以看出,经过软件滤波后σ小了很多,这种软件滤波算法对滤除尖峰脉冲干扰是非常有效的。

结 语

本文提出的软件滤波算法速度快,代码效率高,滤波效果理想,是一种实用的数字滤波设计方法,体现了将算法与具体硬件相结合的思想。另一方面,当脉冲干扰较宽时可将存储器变量适当扩展成多字节变量。这个算法还可以与FPGA结合,用于其他计数精度要求较高、易受尖峰脉冲干扰的应用结合。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top