关于A/D采样值 ->送显示平滑处理思想求助?

2020-02-09 11:29发布

我使用的单片机是dspic30f2012 A/D产考基准采样的是MC1403 -> 2.5V 在电力系统中有1.2倍过载也就是X * 1.2 = 2.5v 单片机A/D最高被限定在2V。但单片机采样不了负极性,加1V偏移。12Bit A/D采样满度值就变成了±1638;如果想显示满度值866.0W  有:1638*21655>>12; ≈8659.8 这样处理是因为单片机内部含有16bit乘法器。处理除法要稍慢些。有此系数带来的就是A/D每变化一个字,显示值就变化了5个字!相对误差为0.6‰虽然可以达到技术要求但是5个字的蹦字看着难看!软件滤波方法不用说(采样频率6.4K,采样128点去掉一个最大值一个最小值平均,1s输出5次结果);我的问题来了,有什么样的思想可以稍微牺牲点响应速度,让显示值为一个字蹦字的假象!在输入信号不变的情况下,显示值尾数是±1为变化的范围还是5。要不然我也不会问这样的问题,刚在市场上买了一块表。也是用12位A/D的单片机处理的。回来测试,加上信号源。显示却很平滑。跳字范围也是5个字,但是他是以±1的循环变化。虽然响应速度有所下降,但是这种低价位的表,对于使用者来说没什么。希望处理过的同志给点思想!

前级采样的是时分割乘法器

(原文件名:plx.png)
Proteus仿真

(原文件名:dspic33fj32gp204.png)
Altium PCB

(原文件名:754.png)
硬件已经固定

(原文件名:752.png)
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
23条回答
my2009
2020-02-10 05:55
【4楼】 wangqh1983
------------------------------------------
“滑动平均"----就是这个意思, 我设想一个算法:

*   6.4k的采样频率, 取得8个AD值后平均AD值, AD_x=(AD0+AD1..+AD7)/8
*   AD_x 转换为显示值 disp_x

*   buf[pi++]=disp_x,   pi&=0x1f,   ----- 将这个disp_x值存入数组最后一位(不用移动数据, 只需改变指针)
*   disp_w = (buf1[0]+...buf[31)/32
*   显示 disp_w

   数据例子:  disp_x1=disp_x2....    =disp_x20=1000  ---->
               disp_x21=disp_x22......=disp_x32=1005  ---->   20个1000, 12个1005 数据跳变
   disp_w=(1000*20+1005*12)/32=1001.8 ------ 这个数跳变小一些

*  适当改变 参数 "32"  和 "8",  看一下什么数更合适


你的图画的很漂亮

一周热门 更多>