代码
filter.c
#include <stdio.h>
#include "stm32f429xx.h"
#include <string.h>
#define DEVIATION 10
float limit_filter(float new_value)
{static int num = 0;static float value = 0; num ++;if(num == 1)value = new_value;if ( ( new_value - value > DEVIATION ) || ( value - new_value > DEVIATION )){return value;}else{ value = new_value;return new_value;}
}int limit_filter_test(void)
{int i = 0;float result[20];int a[20] = {15,11,65536,13,16,18,21,100,25,25,31,35,120,38,9,46,50,58,68,5};for(i = 0; i < 20; i++){result[i] = limit_filter(a[i]);}return 0;
}
#define MIDDLE_FILTER_N 3float middle_filter( float new_value)
{static int mid_filter_count;static float value_buf[MIDDLE_FILTER_N];float temp_buff[MIDDLE_FILTER_N];float temp ;unsigned char count, i;mid_filter_count++;for ( count = 0; count < MIDDLE_FILTER_N - 1; count++){value_buf[count] = value_buf[count + 1] ;}value_buf[MIDDLE_FILTER_N - 1] = new_value;__nop();for(i=0;i<MIDDLE_FILTER_N;i++){temp_buff[i] = value_buf[i];}for(char k=0;k<MIDDLE_FILTER_N-1;k++) { for(char j=0;j<MIDDLE_FILTER_N-1-k;j++){if(temp_buff[j]>temp_buff[j+1]){temp=temp_buff[j];temp_buff[j]=temp_buff[j+1];temp_buff[j+1]=temp;}}}if(mid_filter_count < MIDDLE_FILTER_N)return new_value;elsereturn temp_buff[(MIDDLE_FILTER_N - 1) / 2];
}int middle_filter_test(void)
{int i = 0;float result[20];int a[20] = {15,11,65536,13,16,18,21,100,25,25,31,35,120,38,9,46,50,58,68,5};for(i = 0; i < 20; i++){result[i] = middle_filter(a[i]);}return 0;
}
#define AVERAGE_N 5
float average_filter(float new_value)
{static float value_buf[AVERAGE_N];float average_sum = 0;unsigned char count;for ( count = 0; count < AVERAGE_N - 1; count++){value_buf[count] = value_buf[count + 1] ;}value_buf[AVERAGE_N - 1] = new_value;__nop();for(uint8_t i=0;i<AVERAGE_N;i++){average_sum += value_buf[i];}return (average_sum /(AVERAGE_N * 1.0) );
}int average_filter_test(void)
{int i = 0;float result[20];int a[20] = {15,11,65536,13,16,18,21,100,25,25,31,35,120,38,9,46,50,58,68,5};for(i = 0; i < 20; i++){result[i] = average_filter(a[i]);}return 0;
}
#define alpha 0.05
float low_pass_filter(float value)
{ static float out_last = 0; float out; out = out_last + alpha*(value - out_last); out_last = out; return out;
}
int low_pass_filter_test(void)
{int i = 0;float result[10];int a[10] = {15,11,65,13,31,15,16,17,68,15};for(i = 0; i < 20; i++){result[i] = low_pass_filter(a[i]);}return 0;
}
#include <stdio.h>
#include <stdint.h>
#define WEIGHT_AVERAGE_N 3 uint8_t coe[WEIGHT_AVERAGE_N] = {1, 2, 3};
uint8_t sum_coe = 1 + 2 + 3;
float weighted_filter(float new_value)
{static float weight_average_buf[WEIGHT_AVERAGE_N];uint8_t count;float sum = 0;for ( count = 0; count < WEIGHT_AVERAGE_N - 1 ; count++){weight_average_buf[count] = weight_average_buf[count+ 1] ;}weight_average_buf[WEIGHT_AVERAGE_N - 1] = new_value;__nop();for (count = 0 ; count < WEIGHT_AVERAGE_N; count++)sum += weight_average_buf[count] * coe[count];return (sum / (sum_coe * 1.0));
}int weighted_filter_test(void)
{int i = 0;float result[10] ;int a[10] = {15,11,25,13,31,15,16,17,68,15};for(i = 0; i < 10; i++){result[i] = weighted_filter(a[i]);}return 0;
}
#include <stdio.h>
#include <stdint.h>
#define SHAKE_N 3
float shake_filter( float new_value , float now_value)
{static uint8_t count = 0;if(now_value != new_value){count++;if (count >= SHAKE_N){count = 0;return new_value;}}return now_value;
}int shake_filter_test()
{int i = 0;float result[10]={0};int a[10] = {15,11,255,13,31,15,16,17,68,15};for(i = 0; i < 9; i++){result[i] = shake_filter(a[0],a[i+1]);}return 0;
}
filter.h
#ifndef _FILTER_H_
#define _FILTER_H_
int limit_filter_test(void);
int middle_filter_test(void);
int average_filter_test(void);
int low_pass_filter_test(void);
int weighted_filter_test(void);
int shake_filter_test(void);
#endif