在實驗運行7.1章節(jié)例程時 [CW32數(shù)字電壓電流表軟件進階教程-1.電壓電流同時顯示] ,會發(fā)現(xiàn)實時顯示更新的數(shù)據(jù)是當前采集值,并未做數(shù)據(jù)濾波處理。由于采集到的原始數(shù)據(jù)有一定的波動,因此在顯示更新速度較快時,數(shù)字有跳動現(xiàn)象。
因此,在數(shù)據(jù)處理前,可以增加常見的均值濾波算法。均值濾波原理在實驗七中已有講述。
在7.1實驗例程基礎(chǔ)上,增加均值濾波的核心代碼如下:
void Volt_Cal(void)
{
V_Buffer = Mean_Value_Filter(Volt_Buffer,ADC_SAMPLE_SIZE);; //使用均值濾波
I_Buffer = Mean_Value_Filter(Curr_Buffer,ADC_SAMPLE_SIZE);; //使用均值濾波
V_Buffer = (V_Buffer * ADC_REF_VALUE > > 12) * (R2 + R1)/R1;
// 四舍五入
if(V_Buffer % 10 >= 5)
{
V_Buffer = V_Buffer / 10 + 1;
}
else
{
V_Buffer = V_Buffer / 10;
}
I_Buffer=I_Buffer * ADC_REF_VALUE > > 12;
/**
mv =I_Buffer * ADC_REF_VALUE > > 12,
R = 100mr,
10ma = mv/R/10=mv/0.1/10 = mv
*/
}
在上述例程中,可以看到使用了均值濾波函數(shù):
Mean_Value_Filter(Volt_Buffer,ADC_SAMPLE_SIZE);; //使用均值濾波
Mean_Value_Filter(Curr_Buffer,ADC_SAMPLE_SIZE);; //使用均值濾波
其中,原始數(shù)據(jù)為每1MS采集一個數(shù)據(jù)點,共采集100次,即100MS內(nèi)的定時數(shù)據(jù)值。單點數(shù)據(jù)采集在定時器BTIM1中斷函數(shù)中完成。
均值濾波函數(shù)定義如下:
uint32_t Mean_Value_Filter(uint16_t *value, uint32_t size) //均值濾波
{
uint32_t sum = 0;
uint16_t max = 0;
uint16_t min = 0xffff;
int i;
for(i = 0; i < size; i++)
{
sum += value[i];
if(value[i] > max)
{
max = value[i];
}
if(value[i] < min)
{
min = value[i];
}
}
sum -= max + min;
sum = sum / (size - 2);
//if(sum >1)sum+=4; 后期校準
return sum;
}
審核編輯 黃宇
-
數(shù)據(jù)采集
+關(guān)注
關(guān)注
40文章
7196瀏覽量
116558 -
定時器
+關(guān)注
關(guān)注
23文章
3300瀏覽量
119039 -
均值濾波
+關(guān)注
關(guān)注
0文章
10瀏覽量
7208 -
CW32
+關(guān)注
關(guān)注
1文章
255瀏覽量
1258
發(fā)布評論請先 登錄
常規(guī)的電壓電流測量方式有哪些?

高壓電阻箱如何進行負載測試?


倍壓電路電流會有多少
電流計改裝成電壓表時刻度怎么刻
開關(guān)電源改可調(diào)電壓電流怎么改
基于CW32的儀表精度測量實現(xiàn)(三):標定與校準

評論